annotate src/main/java/alice/jungle/persistent/PersistentJungleTree.java @ 194:fd4064e110bd fjTreeMap

change TreeContext
author tatsuki
date Mon, 23 Mar 2015 16:18:47 +0900
parents 89c15aa2bc6d
children 82698be06c6c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
105
f9e29a52efd3 Move some files
one
parents: 96
diff changeset
1 package alice.jungle.persistent;
85
e641f559559c Added some files for persistent
one
parents:
diff changeset
2
194
fd4064e110bd change TreeContext
tatsuki
parents: 193
diff changeset
3 import fj.data.List;
180
2828205bdc3a fit JungleCore
tatsuki
parents: 179
diff changeset
4 import fj.data.TreeMap;
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
5 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.DefaultJungleTree;
85
e641f559559c Added some files for persistent
one
parents:
diff changeset
6 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTree;
e641f559559c Added some files for persistent
one
parents:
diff changeset
7 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTreeEditor;
e641f559559c Added some files for persistent
one
parents:
diff changeset
8 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.persistent.ChangeListWriter;
180
2828205bdc3a fit JungleCore
tatsuki
parents: 179
diff changeset
9 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.NodePath;
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
10 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TreeContext;
85
e641f559559c Added some files for persistent
one
parents:
diff changeset
11 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TreeEditor;
e641f559559c Added some files for persistent
one
parents:
diff changeset
12 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.TreeNode;
e641f559559c Added some files for persistent
one
parents:
diff changeset
13 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.DefaultJungleTreeEditor;
180
2828205bdc3a fit JungleCore
tatsuki
parents: 179
diff changeset
14 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.InterfaceTraverser;
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
15 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultEither;
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
16 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
17 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
18 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.GetOldTreeError;
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
19 import jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.store.index.ParentIndex;
85
e641f559559c Added some files for persistent
one
parents:
diff changeset
20
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
21 import java.util.concurrent.atomic.AtomicReference;
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
22
179
d6944d788121 fit Junglecore
tatsuki
parents: 177
diff changeset
23 public class PersistentJungleTree implements JungleTree {
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
24 private final AtomicReference<TreeContext> repository;
85
e641f559559c Added some files for persistent
one
parents:
diff changeset
25 private final String uuid;
e641f559559c Added some files for persistent
one
parents:
diff changeset
26 private final String treeName;
88
0c98717f186e Removed cast code
one
parents: 85
diff changeset
27 private final ChangeListWriter writer;
85
e641f559559c Added some files for persistent
one
parents:
diff changeset
28 private final TreeEditor editor;
e641f559559c Added some files for persistent
one
parents:
diff changeset
29
179
d6944d788121 fit Junglecore
tatsuki
parents: 177
diff changeset
30 public PersistentJungleTree(String _treeName, TreeContext _tc,String _uuid, ChangeListWriter _writer,TreeEditor _editor)
85
e641f559559c Added some files for persistent
one
parents:
diff changeset
31 {
e641f559559c Added some files for persistent
one
parents:
diff changeset
32 treeName = _treeName;
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
33 repository = new AtomicReference<TreeContext>(_tc);
85
e641f559559c Added some files for persistent
one
parents:
diff changeset
34 uuid = _uuid;
e641f559559c Added some files for persistent
one
parents:
diff changeset
35 writer = _writer;
e641f559559c Added some files for persistent
one
parents:
diff changeset
36 editor = _editor;
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 JungleTreeEditor getTreeEditor()
e641f559559c Added some files for persistent
one
parents:
diff changeset
41 {
179
d6944d788121 fit Junglecore
tatsuki
parents: 177
diff changeset
42 TreeContext tc = repository.get();
d6944d788121 fit Junglecore
tatsuki
parents: 177
diff changeset
43 PersistentTransactionManager txManager = new PersistentTransactionManager(treeName, writer,tc,repository,uuid);
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
44 TreeNode root = tc.getRoot();
179
d6944d788121 fit Junglecore
tatsuki
parents: 177
diff changeset
45 return new DefaultJungleTreeEditor(root,txManager,editor);
85
e641f559559c Added some files for persistent
one
parents:
diff changeset
46 }
e641f559559c Added some files for persistent
one
parents:
diff changeset
47
e641f559559c Added some files for persistent
one
parents:
diff changeset
48 @Override
177
6f104ab4eb81 fit jungle core but editMessage is not work
tatsuki
parents: 105
diff changeset
49 public TreeNode getRootNode()
85
e641f559559c Added some files for persistent
one
parents:
diff changeset
50 {
179
d6944d788121 fit Junglecore
tatsuki
parents: 177
diff changeset
51 TreeContext tc = repository.get();
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
52 return tc.getRoot();
85
e641f559559c Added some files for persistent
one
parents:
diff changeset
53 }
e641f559559c Added some files for persistent
one
parents:
diff changeset
54
96
fcce7ca4adb9 Modified LogUpdateCodesegment
one
parents: 88
diff changeset
55 @Override
fcce7ca4adb9 Modified LogUpdateCodesegment
one
parents: 88
diff changeset
56 public JungleTreeEditor getLocalTreeEditor() {
fcce7ca4adb9 Modified LogUpdateCodesegment
one
parents: 88
diff changeset
57 return getTreeEditor();
fcce7ca4adb9 Modified LogUpdateCodesegment
one
parents: 88
diff changeset
58 }
fcce7ca4adb9 Modified LogUpdateCodesegment
one
parents: 88
diff changeset
59
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
60 @Override
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
61 public long revision() {
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
62 TreeContext tc = repository.get();
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
63 return tc.revision();
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
64 }
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
65
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
66 @Override
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
67 public Either<Error, JungleTree> getOldTree(long revision) {
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
68 TreeContext tc = repository.get();
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
69
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
70 for (; tc.revision() != revision;) {
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
71 tc = tc.prev();
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
72 if (tc == null)
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
73 return DefaultEither.newA(GetOldTreeError.OLD_TREE_NOT_FOUND);
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
74 }
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
75
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
76
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
77 String oldTreeUuid = uuid + revision;
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
78 JungleTree oldTree = new DefaultJungleTree(tc, oldTreeUuid, writer, editor);
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
79 return DefaultEither.newB(oldTree);
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
80 }
180
2828205bdc3a fit JungleCore
tatsuki
parents: 179
diff changeset
81
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
82 @Override
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
83 public ParentIndex getParentIndex() {
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
84 TreeContext tc = repository.get();
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
85 return tc.getParentIndex();
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
86 }
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
87
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
88 @Override
194
fd4064e110bd change TreeContext
tatsuki
parents: 193
diff changeset
89 public TreeMap<String, TreeMap<String,List<TreeNode>>> getIndex() {
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
90 TreeContext tc = repository.get();
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
91 return tc.getIndex();
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
92 }
180
2828205bdc3a fit JungleCore
tatsuki
parents: 179
diff changeset
93
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
94 @Override
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
95 public InterfaceTraverser getTraverser(boolean useIndex) {
194
fd4064e110bd change TreeContext
tatsuki
parents: 193
diff changeset
96 TreeMap<String, TreeMap<String, List<TreeNode>>> index = getIndex();
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
97 ParentIndex parentIndex = getParentIndex();
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
98 return new InterfaceTraverser(getRootNode(), index, parentIndex, useIndex);
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
99 }
180
2828205bdc3a fit JungleCore
tatsuki
parents: 179
diff changeset
100
193
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
101 @Override
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
102 public Either<Error, TreeNode> getNodeOfPath(NodePath path) {
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
103 TreeNode node = repository.get().getRoot();
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
104 for (int num : path) {
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
105 if (num == -1)
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
106 continue;
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
107 Either<Error, TreeNode> either = node.getChildren().at(num);
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
108 if (either.isA())
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
109 return either;
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
110 node = either.b();
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
111 }
89c15aa2bc6d change transaction
tatsuki
parents: 191
diff changeset
112 return DefaultEither.newB(node);
191
5d0734fd859d fix error
tatsuki
parents: 190
diff changeset
113 }
85
e641f559559c Added some files for persistent
one
parents:
diff changeset
114
e641f559559c Added some files for persistent
one
parents:
diff changeset
115 }