45
|
1 package jp.ac.u_ryukyu.ie.cr.shoshi.jungle;
|
|
2
|
|
3 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.persistent.ChangeListWriter;
|
|
4 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.ChangeSet;
|
54
|
5 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TreeEditor;
|
145
|
6 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.IndexTreeEditor;
|
54
|
7 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.TreeNode;
|
45
|
8 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.AtomicReservableReference;
|
|
9 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.DefaultJungleTreeEditor;
|
|
10 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.DefaultTransactionManager;
|
142
|
11 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.DefaultTreeContext;
|
54
|
12 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.TreeContext;
|
100
|
13 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.InterfaceTraverser;
|
142
|
14 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultEither;
|
|
15 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
|
|
16 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
|
|
17 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.GetOldTreeError;
|
151
|
18 import jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.store.index.Index;
|
134
|
19 import jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.store.index.IndexManager;
|
149
|
20 import jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.store.index.ParentIndex;
|
45
|
21
|
142
|
22 public class DefaultJungleTree implements JungleTree {
|
153
|
23
|
142
|
24 private final AtomicReservableReference<TreeContext> repository;
|
|
25 private final String uuid;
|
|
26 private final ChangeListWriter writer;
|
145
|
27 private final TreeEditor treeEditor;
|
151
|
28
|
153
|
29 public DefaultJungleTree(TreeContext tc, String uuid, ChangeListWriter writer, TreeEditor editor) {
|
142
|
30 this.repository = new AtomicReservableReference<TreeContext>(tc);
|
|
31 this.uuid = uuid;
|
|
32 this.writer = writer;
|
145
|
33 this.treeEditor = editor;
|
142
|
34 }
|
45
|
35
|
142
|
36 @Override
|
|
37 public JungleTreeEditor getTreeEditor() {
|
|
38 TreeContext tc = repository.get();
|
|
39 DefaultTransactionManager txManager = new DefaultTransactionManager(writer, tc, repository, uuid);
|
|
40 TreeNode root = tc.getTreeNode();
|
153
|
41 return new DefaultJungleTreeEditor(root, txManager, treeEditor);
|
142
|
42 }
|
|
43
|
|
44
|
|
45 @Override
|
|
46 public JungleTreeEditor getLocalTreeEditor() {
|
|
47 return getTreeEditor();
|
|
48 }
|
|
49
|
|
50 @Override
|
|
51 public TreeNode getRootNode() {
|
|
52 TreeContext tc = repository.get();
|
|
53 ChangeSet cs = tc.getChangeSet();
|
|
54 return cs.getRoot();
|
|
55 }
|
45
|
56
|
142
|
57 @Override
|
153
|
58 public InterfaceTraverser getTraverser(boolean useIndex) {
|
142
|
59 AtomicReservableReference<TreeContext>.Reservation reservation = repository.getReservation();
|
|
60 IndexManager indexManager = new IndexManager(reservation);
|
151
|
61 Index index = getIndex();
|
153
|
62 ParentIndex parentIndex = getParentIndex();
|
|
63 return new InterfaceTraverser(getRootNode(), index, parentIndex, indexManager,useIndex);
|
|
64 }
|
|
65
|
|
66 @Override
|
|
67 public ParentIndex getParentIndex() {
|
|
68 TreeContext tc = repository.get();
|
|
69 ChangeSet cs = tc.getChangeSet();
|
|
70 return cs.getParentIndex();
|
142
|
71 }
|
|
72
|
|
73 @Override
|
151
|
74 public Index getIndex() {
|
142
|
75 TreeContext tc = repository.get();
|
|
76 ChangeSet cs = tc.getChangeSet();
|
|
77 return cs.getIndex();
|
|
78 }
|
|
79
|
100
|
80
|
142
|
81 @Override
|
|
82 public long revision() {
|
|
83 TreeContext tc = repository.get();
|
|
84 ChangeSet cs = tc.getChangeSet();
|
|
85 return cs.revision();
|
|
86 }
|
|
87
|
|
88 @Override
|
|
89 public Either<Error, JungleTree> getOldTree(long revision) {
|
|
90 TreeContext tc = repository.get();
|
|
91 ChangeSet cs = tc.getChangeSet();
|
151
|
92
|
153
|
93 for (;cs.revision() != revision;) {
|
142
|
94 cs = cs.prev();
|
|
95 if (cs == null)
|
|
96 return DefaultEither.newA(GetOldTreeError.OLD_TREE_NOT_FOUND);
|
|
97 }
|
151
|
98
|
142
|
99 TreeNode root = cs.getRoot();
|
151
|
100
|
142
|
101 TreeContext oldTc = new DefaultTreeContext(root, cs);
|
|
102 String oldTreeUuid = uuid + revision;
|
153
|
103 JungleTree oldTree = new DefaultJungleTree(oldTc, oldTreeUuid, writer, treeEditor);
|
142
|
104 return DefaultEither.newB(oldTree);
|
|
105 }
|
|
106
|
153
|
107
|
45
|
108 }
|