annotate src/main/java/app/bbs/JungleManager.java @ 115:3f9c6ab43461

Adde PersistentJournalTest.java
author one
date Fri, 20 Dec 2013 06:51:35 +0900
parents 7d9b7fcb4d9a
children 895ab2907db3
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
112
8f9811a1e00c Moved app files
one
parents: 105
diff changeset
1 package app.bbs;
39
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
2
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
3 import java.nio.ByteBuffer;
59
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
4 import java.util.Iterator;
15
bf4a7f899c4e add some files
one
parents:
diff changeset
5
96
fcce7ca4adb9 Modified LogUpdateCodesegment
one
parents: 95
diff changeset
6 import alice.jungle.operations.NetworkTreeOperationLog;
93
75cf01a430a6 Added LocalTreeEditor
one
parents: 90
diff changeset
7 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.DefaultJungle;
15
bf4a7f899c4e add some files
one
parents:
diff changeset
8 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.Jungle;
bf4a7f899c4e add some files
one
parents:
diff changeset
9 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTree;
39
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
10 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTreeEditor;
59
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
11 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Node;
39
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
12 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.Command;
90
eef737ab3b2c Modified JungleManager class
one
parents: 75
diff changeset
13 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.NodePath;
56
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
14 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultNodePath;
93
75cf01a430a6 Added LocalTreeEditor
one
parents: 90
diff changeset
15 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultTreeEditor;
39
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
16 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.TreeOperationLog;
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
17 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.NodeOperation;
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
18 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.TreeOperation;
93
75cf01a430a6 Added LocalTreeEditor
one
parents: 90
diff changeset
19 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.DefaultTraverser;
39
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
20 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
21 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
15
bf4a7f899c4e add some files
one
parents:
diff changeset
22
bf4a7f899c4e add some files
one
parents:
diff changeset
23 public class JungleManager {
115
3f9c6ab43461 Adde PersistentJournalTest.java
one
parents: 113
diff changeset
24 private static JungleManager instance = new JungleManager();
43
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
25 private Jungle jungle;
90
eef737ab3b2c Modified JungleManager class
one
parents: 75
diff changeset
26 private static int NOT_CHANGE_POSITION = 0;
43
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
27
45
bf3dc481cc9b modified JungleManager to singleton
one
parents: 43
diff changeset
28 private JungleManager() {
93
75cf01a430a6 Added LocalTreeEditor
one
parents: 90
diff changeset
29 jungle = new DefaultJungle(null,"hogehoge",new DefaultTreeEditor(new DefaultTraverser()));
15
bf4a7f899c4e add some files
one
parents:
diff changeset
30 }
bf4a7f899c4e add some files
one
parents:
diff changeset
31
113
7d9b7fcb4d9a Add LogPutCodeSegment
one
parents: 112
diff changeset
32 public static JungleManager getInstantce() {
115
3f9c6ab43461 Adde PersistentJournalTest.java
one
parents: 113
diff changeset
33 return instance;
113
7d9b7fcb4d9a Add LogPutCodeSegment
one
parents: 112
diff changeset
34 }
7d9b7fcb4d9a Add LogPutCodeSegment
one
parents: 112
diff changeset
35
45
bf3dc481cc9b modified JungleManager to singleton
one
parents: 43
diff changeset
36 public static void setJungle(Jungle _j) {
115
3f9c6ab43461 Adde PersistentJournalTest.java
one
parents: 113
diff changeset
37 instance.jungle = _j;
15
bf4a7f899c4e add some files
one
parents:
diff changeset
38 }
bf4a7f899c4e add some files
one
parents:
diff changeset
39
43
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
40 public static Jungle getJungle() {
115
3f9c6ab43461 Adde PersistentJournalTest.java
one
parents: 113
diff changeset
41 return instance.jungle;
43
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
42 }
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
43
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
44 public static JungleTree createNewTree(String name) {
115
3f9c6ab43461 Adde PersistentJournalTest.java
one
parents: 113
diff changeset
45 return instance.jungle.createNewTree(name);
15
bf4a7f899c4e add some files
one
parents:
diff changeset
46 }
bf4a7f899c4e add some files
one
parents:
diff changeset
47
56
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
48 public static Either<Error, JungleTreeEditor> edit(JungleTreeEditor _editor ,TreeOperationLog _log, int pos) {
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
49 JungleTreeEditor editor = _editor;
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
50 Either<Error, JungleTreeEditor> either = null;
90
eef737ab3b2c Modified JungleManager class
one
parents: 75
diff changeset
51 for (TreeOperation op : _log) {
56
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
52 either = _edit(editor, op, pos);
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
53 if(either.isA()) {
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
54 return either;
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
55 }
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
56 editor = either.b();
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
57 }
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
58 return either;
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
59 }
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
60
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
61 private static Either<Error, JungleTreeEditor> _edit(JungleTreeEditor editor,
90
eef737ab3b2c Modified JungleManager class
one
parents: 75
diff changeset
62 TreeOperation op, int _pos) {
eef737ab3b2c Modified JungleManager class
one
parents: 75
diff changeset
63 NodePath path = new DefaultNodePath();
56
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
64 NodeOperation nodeOp = op.getNodeOperation();
90
eef737ab3b2c Modified JungleManager class
one
parents: 75
diff changeset
65 int pos = _pos;
eef737ab3b2c Modified JungleManager class
one
parents: 75
diff changeset
66 if (_pos == NOT_CHANGE_POSITION ) {
eef737ab3b2c Modified JungleManager class
one
parents: 75
diff changeset
67 pos = nodeOp.getPosition();
eef737ab3b2c Modified JungleManager class
one
parents: 75
diff changeset
68 }
56
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
69 Command c = nodeOp.getCommand();
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
70 String key = "";
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
71 switch (c) {
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
72 case PUT_ATTRIBUTE:
90
eef737ab3b2c Modified JungleManager class
one
parents: 75
diff changeset
73 path = op.getNodePath();
56
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
74 key = nodeOp.getKey();
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
75 ByteBuffer value = nodeOp.getValue();
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
76 return editor.putAttribute(path, key, value);
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
77 case DELETE_ATTRIBUTE:
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
78 key = nodeOp.getKey();
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
79 return editor.deleteAttribute(path, key);
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
80 case APPEND_CHILD:
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
81 return editor.addNewChildAt(path, pos);
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
82 case DELETE_CHILD:
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
83 return editor.deleteChildAt(path, 0);
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
84 }
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
85 return null;
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
86 }
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
87
96
fcce7ca4adb9 Modified LogUpdateCodesegment
one
parents: 95
diff changeset
88 public static Either<Error, JungleTreeEditor> update(NetworkTreeOperationLog netLog) {
fcce7ca4adb9 Modified LogUpdateCodesegment
one
parents: 95
diff changeset
89 String treeName = netLog.getTreeName();
93
75cf01a430a6 Added LocalTreeEditor
one
parents: 90
diff changeset
90 Jungle jungle = JungleManager.getJungle();
75cf01a430a6 Added LocalTreeEditor
one
parents: 90
diff changeset
91 if (jungle.getTreeByName(treeName) == null) {
75cf01a430a6 Added LocalTreeEditor
one
parents: 90
diff changeset
92 if(null == jungle.createNewTree(treeName)){
59
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
93 throw new IllegalStateException();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
94 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
95 }
93
75cf01a430a6 Added LocalTreeEditor
one
parents: 90
diff changeset
96 JungleTree tree = jungle.getTreeByName(treeName);
95
dcd767b76f8d Modified putDataSement for to use NetworkTreeOperationLog
one
parents: 93
diff changeset
97 JungleTreeEditor editor = tree.getLocalTreeEditor();
96
fcce7ca4adb9 Modified LogUpdateCodesegment
one
parents: 95
diff changeset
98
fcce7ca4adb9 Modified LogUpdateCodesegment
one
parents: 95
diff changeset
99 // int pos = calculatePosition(tree.getRootNode(), netLog.getTimeStamp());
fcce7ca4adb9 Modified LogUpdateCodesegment
one
parents: 95
diff changeset
100 int pos = 0;
fcce7ca4adb9 Modified LogUpdateCodesegment
one
parents: 95
diff changeset
101 Either<Error, JungleTreeEditor> either = JungleManager.edit(editor, netLog, pos);
59
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
102 if(either.isA()) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
103 throw new IllegalStateException();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
104 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
105 editor = either.b();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
106 either = editor.success();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
107 if(either.isA()) {
67
89e39301ccaa remove some warning
one
parents: 66
diff changeset
108 throw new IllegalStateException();
59
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
109 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
110 return either;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
111 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
112
90
eef737ab3b2c Modified JungleManager class
one
parents: 75
diff changeset
113 private static int calculatePosition(Node node, long newNodeTimeStamp) {
59
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
114 int count = 0;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
115 long childTimeStamp = 0;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
116 for(Iterator<Node> iter = node.getChildren().iterator();iter.hasNext();) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
117 Node n = iter.next();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
118 if(n.getAttributes().get("timestamp") == null) {
90
eef737ab3b2c Modified JungleManager class
one
parents: 75
diff changeset
119 return NOT_CHANGE_POSITION;
59
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
120 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
121 if(n.getAttributes().get("timestamp") != null) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
122 childTimeStamp = n.getAttributes().get("timestamp").getLong();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
123 if (newNodeTimeStamp < childTimeStamp) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
124 break;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
125 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
126 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
127 count++;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
128 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
129 return count;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
130 }
15
bf4a7f899c4e add some files
one
parents:
diff changeset
131 }