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