annotate src/jungle/app/bbs/JungleManager.java @ 66:29127ac788a6

move some files
author one
date Tue, 20 Aug 2013 17:38:09 +0900
parents src/jungle/test/bbs/JungleManager.java@ebf42371454b
children 89e39301ccaa
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
66
29127ac788a6 move some files
one
parents: 65
diff changeset
1 package jungle.app.bbs;
39
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
2
59
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
3 import java.io.IOException;
39
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
4 import java.nio.ByteBuffer;
59
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
5 import java.util.Iterator;
15
bf4a7f899c4e add some files
one
parents:
diff changeset
6
59
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
7 import alice.jungle.datasegment.store.operations.DefaultTreeOperationLogContainer;
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;
56
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
13 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultNodePath;
59
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
14 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.DefaultTreeOperationLog;
39
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
15 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.TreeOperationLog;
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
16 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.NodeOperation;
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
17 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.TreeOperation;
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
18 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
10359a815068 add alice.jungle.codesegment.remote
one
parents: 31
diff changeset
19 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
15
bf4a7f899c4e add some files
one
parents:
diff changeset
20
bf4a7f899c4e add some files
one
parents:
diff changeset
21 public class JungleManager {
45
bf3dc481cc9b modified JungleManager to singleton
one
parents: 43
diff changeset
22 private static JungleManager jm = new JungleManager();
43
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
23 private Jungle jungle;
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
24
45
bf3dc481cc9b modified JungleManager to singleton
one
parents: 43
diff changeset
25 private JungleManager() {
15
bf4a7f899c4e add some files
one
parents:
diff changeset
26
bf4a7f899c4e add some files
one
parents:
diff changeset
27 }
bf4a7f899c4e add some files
one
parents:
diff changeset
28
45
bf3dc481cc9b modified JungleManager to singleton
one
parents: 43
diff changeset
29 public static void setJungle(Jungle _j) {
bf3dc481cc9b modified JungleManager to singleton
one
parents: 43
diff changeset
30 jm.jungle = _j;
15
bf4a7f899c4e add some files
one
parents:
diff changeset
31 }
bf4a7f899c4e add some files
one
parents:
diff changeset
32
43
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
33 public static Jungle getJungle() {
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
34 return jm.jungle;
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
35 }
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
36
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
37 public static JungleTree createNewTree(String name) {
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
38 return jm.jungle.createNewTree(name);
15
bf4a7f899c4e add some files
one
parents:
diff changeset
39 }
bf4a7f899c4e add some files
one
parents:
diff changeset
40
56
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
41 public static Either<Error, JungleTreeEditor> edit(JungleTreeEditor _editor ,TreeOperationLog _log, int pos) {
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
42 JungleTreeEditor editor = _editor;
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
43 Either<Error, JungleTreeEditor> either = null;
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
44 for (TreeOperation op : _log) {
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
45 either = _edit(editor, op, pos);
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
46 if(either.isA()) {
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
47 return either;
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
48 }
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
49 editor = either.b();
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
50 }
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
51 return either;
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
52 }
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
53
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
54 private static Either<Error, JungleTreeEditor> _edit(JungleTreeEditor editor,
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
55 TreeOperation op, int pos) {
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
56 DefaultNodePath path = new DefaultNodePath();
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
57 NodeOperation nodeOp = op.getNodeOperation();
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
58 Command c = nodeOp.getCommand();
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
59 String key = "";
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
60 switch (c) {
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
61 case PUT_ATTRIBUTE:
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
62 path = path.add(pos);
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
63 key = nodeOp.getKey();
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
64 ByteBuffer value = nodeOp.getValue();
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
65 return editor.putAttribute(path, key, value);
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
66 case DELETE_ATTRIBUTE:
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
67 key = nodeOp.getKey();
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
68 return editor.deleteAttribute(path, key);
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
69 case APPEND_CHILD:
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
70 return editor.addNewChildAt(path, pos);
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
71 case DELETE_CHILD:
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
72 return editor.deleteChildAt(path, 0);
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
73 }
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
74 return null;
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
75 }
ccfe9b5e8f11 bug LogUpdateCodeSegment
one
parents: 45
diff changeset
76
59
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
77 public static Either<Error, JungleTreeEditor> update(DefaultTreeOperationLogContainer container) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
78 DefaultTreeOperationLog log = null;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
79 try {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
80 log = container.convert();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
81 } catch (IOException e) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
82 e.printStackTrace();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
83 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
84 String treeName = container.getTreeName();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
85 if (JungleManager.getJungle().getTreeByName(treeName) == null) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
86 if(null == JungleManager.getJungle().createNewTree(treeName)){
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
87 throw new IllegalStateException();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
88 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
89 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
90 JungleTree tree = JungleManager.getJungle().getTreeByName(treeName);
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
91 JungleTreeEditor editor = tree.getTreeEditor();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
92 int pos = checkTimeStamp(tree.getRootNode(), container.getTimeStamp(), container.getPosition());
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
93 Either<Error, JungleTreeEditor> either = JungleManager.edit(editor, log, pos);
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
94 if(either.isA()) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
95 throw new IllegalStateException();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
96 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
97 editor = either.b();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
98 either = editor.success();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
99 if(either.isA()) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
100 throw new IllegalStateException();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
101 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
102 return either;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
103 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
104
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
105
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
106
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
107 private static int checkTimeStamp(Node node, long newNodeTimeStamp, int containerPosition) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
108 int count = 0;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
109 long childTimeStamp = 0;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
110 for(Iterator<Node> iter = node.getChildren().iterator();iter.hasNext();) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
111 Node n = iter.next();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
112 if(n.getAttributes().get("timestamp") == null) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
113 return containerPosition;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
114 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
115 if(n.getAttributes().get("timestamp") != null) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
116 childTimeStamp = n.getAttributes().get("timestamp").getLong();
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
117 if (newNodeTimeStamp < childTimeStamp) {
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
118 break;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
119 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
120 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
121 count++;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
122 }
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
123 return count;
8a532ca5df80 refactoring LogUpdateCodeSegment and ChildLogCheckCodeSegment
one
parents: 56
diff changeset
124 }
15
bf4a7f899c4e add some files
one
parents:
diff changeset
125 }