annotate src/alice/jungle/persistence/PersistentTransactionManager.java @ 85:e641f559559c

Added some files for persistent
author one
date Mon, 28 Oct 2013 17:21:56 +0900
parents
children f142dd4abc74
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
85
e641f559559c Added some files for persistent
one
parents:
diff changeset
1 package alice.jungle.persistence;
e641f559559c Added some files for persistent
one
parents:
diff changeset
2
e641f559559c Added some files for persistent
one
parents:
diff changeset
3 import java.util.Iterator;
e641f559559c Added some files for persistent
one
parents:
diff changeset
4
e641f559559c Added some files for persistent
one
parents:
diff changeset
5 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Node;
e641f559559c Added some files for persistent
one
parents:
diff changeset
6 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.persistent.ChangeList;
e641f559559c Added some files for persistent
one
parents:
diff changeset
7 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.persistent.Result;
e641f559559c Added some files for persistent
one
parents:
diff changeset
8 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.ChangeSet;
e641f559559c Added some files for persistent
one
parents:
diff changeset
9 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.TreeNode;
e641f559559c Added some files for persistent
one
parents:
diff changeset
10 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.TreeOperationLog;
e641f559559c Added some files for persistent
one
parents:
diff changeset
11 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.TreeOperation;
e641f559559c Added some files for persistent
one
parents:
diff changeset
12 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.AtomicReservableReference;
e641f559559c Added some files for persistent
one
parents:
diff changeset
13 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.DefaultTreeContext;
e641f559559c Added some files for persistent
one
parents:
diff changeset
14 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.TransactionManager;
e641f559559c Added some files for persistent
one
parents:
diff changeset
15 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.TreeContext;
e641f559559c Added some files for persistent
one
parents:
diff changeset
16 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.AtomicReservableReference.Reservation;
e641f559559c Added some files for persistent
one
parents:
diff changeset
17 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultEither;
e641f559559c Added some files for persistent
one
parents:
diff changeset
18 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultError;
e641f559559c Added some files for persistent
one
parents:
diff changeset
19 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
e641f559559c Added some files for persistent
one
parents:
diff changeset
20 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
e641f559559c Added some files for persistent
one
parents:
diff changeset
21
e641f559559c Added some files for persistent
one
parents:
diff changeset
22 public class PersistentTransactionManager<T extends TreeNode<T>> implements TransactionManager<T> {
e641f559559c Added some files for persistent
one
parents:
diff changeset
23 private final AtomicReservableReference<TreeContext<T>> repository;
e641f559559c Added some files for persistent
one
parents:
diff changeset
24 private final TreeContext<T> tip;
e641f559559c Added some files for persistent
one
parents:
diff changeset
25 private final PersistentChangeListWriter writer;
e641f559559c Added some files for persistent
one
parents:
diff changeset
26 private final String uuid;
e641f559559c Added some files for persistent
one
parents:
diff changeset
27 private final String treeName;
e641f559559c Added some files for persistent
one
parents:
diff changeset
28
e641f559559c Added some files for persistent
one
parents:
diff changeset
29 public PersistentTransactionManager(String _treeName, PersistentChangeListWriter _writer,TreeContext<T> _tip,
e641f559559c Added some files for persistent
one
parents:
diff changeset
30 AtomicReservableReference<TreeContext<T>> _repository,String _uuid)
e641f559559c Added some files for persistent
one
parents:
diff changeset
31 {
e641f559559c Added some files for persistent
one
parents:
diff changeset
32 repository = _repository;
e641f559559c Added some files for persistent
one
parents:
diff changeset
33 tip = _tip;
e641f559559c Added some files for persistent
one
parents:
diff changeset
34 writer = _writer;
e641f559559c Added some files for persistent
one
parents:
diff changeset
35 uuid = _uuid;
e641f559559c Added some files for persistent
one
parents:
diff changeset
36 treeName = _treeName;
e641f559559c Added some files for persistent
one
parents:
diff changeset
37 }
e641f559559c Added some files for persistent
one
parents:
diff changeset
38
e641f559559c Added some files for persistent
one
parents:
diff changeset
39 @Override
e641f559559c Added some files for persistent
one
parents:
diff changeset
40 public Either<Error, TransactionManager<T>> commit(T _newRoot,final TreeOperationLog _log) {
e641f559559c Added some files for persistent
one
parents:
diff changeset
41 ChangeSet cs = tip.getChangeSet();
e641f559559c Added some files for persistent
one
parents:
diff changeset
42 long currentRevision = cs.revision();
e641f559559c Added some files for persistent
one
parents:
diff changeset
43 long nextRevision = currentRevision + 1;
e641f559559c Added some files for persistent
one
parents:
diff changeset
44
e641f559559c Added some files for persistent
one
parents:
diff changeset
45 ChangeList list = new ChangeList() {
e641f559559c Added some files for persistent
one
parents:
diff changeset
46 @Override
e641f559559c Added some files for persistent
one
parents:
diff changeset
47 public Iterator<TreeOperation> iterator(){
e641f559559c Added some files for persistent
one
parents:
diff changeset
48 return _log.iterator();
e641f559559c Added some files for persistent
one
parents:
diff changeset
49 }
e641f559559c Added some files for persistent
one
parents:
diff changeset
50 };
e641f559559c Added some files for persistent
one
parents:
diff changeset
51
e641f559559c Added some files for persistent
one
parents:
diff changeset
52 Node root = _newRoot.getAsNode();
e641f559559c Added some files for persistent
one
parents:
diff changeset
53 PersistentChangeSet newCs = new PersistentChangeSet(root, cs, list, uuid, nextRevision, treeName);
e641f559559c Added some files for persistent
one
parents:
diff changeset
54 DefaultTreeContext<T> newContext = new DefaultTreeContext<T>(_newRoot,newCs);
e641f559559c Added some files for persistent
one
parents:
diff changeset
55
e641f559559c Added some files for persistent
one
parents:
diff changeset
56 @SuppressWarnings("rawtypes")
e641f559559c Added some files for persistent
one
parents:
diff changeset
57 Reservation reservation = repository.makeReservation(tip, newContext);
e641f559559c Added some files for persistent
one
parents:
diff changeset
58 if(reservation == null) {
e641f559559c Added some files for persistent
one
parents:
diff changeset
59 return DefaultEither.newA((Error)new DefaultError());
e641f559559c Added some files for persistent
one
parents:
diff changeset
60 }
e641f559559c Added some files for persistent
one
parents:
diff changeset
61 // Result r = writer.write(list);
e641f559559c Added some files for persistent
one
parents:
diff changeset
62 Result r = writer.write(newCs);
e641f559559c Added some files for persistent
one
parents:
diff changeset
63 if(r != Result.SUCCESS) {
e641f559559c Added some files for persistent
one
parents:
diff changeset
64 return DefaultEither.newA((Error)new DefaultError());
e641f559559c Added some files for persistent
one
parents:
diff changeset
65 }
e641f559559c Added some files for persistent
one
parents:
diff changeset
66 reservation.confirm();
e641f559559c Added some files for persistent
one
parents:
diff changeset
67 TransactionManager<T> txManager = new PersistentTransactionManager<T>(treeName, writer, newContext, repository, uuid);
e641f559559c Added some files for persistent
one
parents:
diff changeset
68 return DefaultEither.newB(txManager);
e641f559559c Added some files for persistent
one
parents:
diff changeset
69 }
e641f559559c Added some files for persistent
one
parents:
diff changeset
70
e641f559559c Added some files for persistent
one
parents:
diff changeset
71 @Override
e641f559559c Added some files for persistent
one
parents:
diff changeset
72 public long getRevision()
e641f559559c Added some files for persistent
one
parents:
diff changeset
73 {
e641f559559c Added some files for persistent
one
parents:
diff changeset
74 ChangeSet cs = tip.getChangeSet();
e641f559559c Added some files for persistent
one
parents:
diff changeset
75 return cs.revision();
e641f559559c Added some files for persistent
one
parents:
diff changeset
76 }
e641f559559c Added some files for persistent
one
parents:
diff changeset
77
e641f559559c Added some files for persistent
one
parents:
diff changeset
78 @Override
e641f559559c Added some files for persistent
one
parents:
diff changeset
79 public String getUUID() {
e641f559559c Added some files for persistent
one
parents:
diff changeset
80 return uuid;
e641f559559c Added some files for persistent
one
parents:
diff changeset
81 }
e641f559559c Added some files for persistent
one
parents:
diff changeset
82
e641f559559c Added some files for persistent
one
parents:
diff changeset
83
e641f559559c Added some files for persistent
one
parents:
diff changeset
84
e641f559559c Added some files for persistent
one
parents:
diff changeset
85 }