annotate src/main/java/jp/ac/u_ryukyu/ie/cr/bbs/network/bbs/BulletinBoardJungleManager.java @ 9:2890ae6b1aef

network browsing
author tatsuki
date Fri, 03 Feb 2017 02:16:51 +0900
parents 766f7668521f
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
8
tatsuki
parents: 3
diff changeset
1 package jp.ac.u_ryukyu.ie.cr.bbs.network.bbs;
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
3
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
4 import jp.ac.u_ryukyu.ie.cr.jungle.DefaultJungle;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
5 import jp.ac.u_ryukyu.ie.cr.jungle.Jungle;
8
tatsuki
parents: 3
diff changeset
6 import jp.ac.u_ryukyu.ie.cr.jungle.store.nodepath.DefaultNodePath;
tatsuki
parents: 3
diff changeset
7 import jp.ac.u_ryukyu.ie.cr.jungle.store.nodepath.NodePath;
tatsuki
parents: 3
diff changeset
8 import jp.ac.u_ryukyu.ie.cr.jungle.transaction.editor.jungleTreeEditor.JungleTreeEditor;
tatsuki
parents: 3
diff changeset
9 import jp.ac.u_ryukyu.ie.cr.jungle.transaction.node.TreeNode;
tatsuki
parents: 3
diff changeset
10 import jp.ac.u_ryukyu.ie.cr.jungle.tree.JungleTree;
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
11 import jp.ac.u_ryukyu.ie.cr.jungle.util.Either;
8
tatsuki
parents: 3
diff changeset
12 import jp.ac.u_ryukyu.ie.cr.jungle.util.Error.Error;
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
13 import jp.ac.u_ryukyu.ie.cr.jungleNetwork.operations.NetworkTreeOperationLog;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
14 import jp.ac.u_ryukyu.ie.cr.jungleNetwork.transaction.JungleUpdater;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
15
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
16 import java.nio.ByteBuffer;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
17 import java.util.concurrent.atomic.AtomicInteger;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
18
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
19 public class BulletinBoardJungleManager {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
20 private static BulletinBoardJungleManager instance = new BulletinBoardJungleManager();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
21 private Jungle jungle;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
22 private static AtomicInteger requestCounter = new AtomicInteger(0);
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
23
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
24 private BulletinBoardJungleManager() {
8
tatsuki
parents: 3
diff changeset
25 jungle = new DefaultJungle(null,"default");
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
26 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
27
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
28 public static int requestGetAndIncrement() {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
29 return requestCounter.getAndIncrement();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
30 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
31
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
32 public static int requestIncrementAndGet() {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
33 return requestCounter.incrementAndGet();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
34 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
35
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
36 public static BulletinBoardJungleManager getInstantce() {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
37 return instance;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
38 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
39
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
40 public static void setJungle(Jungle _j) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
41 instance.jungle = _j;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
42 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
43 public static AtomicInteger getRequestCounter() {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
44 return requestCounter;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
45 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
46
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
47 public static Jungle getJungle() {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
48 return instance.jungle;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
49 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
50
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
51 public static JungleTree createNewTree(String name) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
52 return instance.jungle.createNewTree(name);
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
53 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
54
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
55 public static Either<Error, JungleTreeEditor> update(NetworkTreeOperationLog netLog) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
56 String treeName = netLog.getTreeName();
3
f3d30646c863 fix error
tatsuki
parents: 2
diff changeset
57 Jungle jungle = BulletinBoardJungleManager.getJungle();
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
58 if (jungle.getTreeByName(treeName) == null) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
59 if(null == jungle.createNewTree(treeName)){
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
60 throw new IllegalStateException();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
61 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
62 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
63 Either<Error, JungleTreeEditor> either = null;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
64 JungleTree tree = jungle.getTreeByName(treeName);
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
65
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
66 long timestamp = System.currentTimeMillis();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
67 ByteBuffer tBuffer = ByteBuffer.allocate(16);
8
tatsuki
parents: 3
diff changeset
68 NodePath root = new DefaultNodePath();
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
69 tBuffer.putLong(timestamp);
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
70 do {
8
tatsuki
parents: 3
diff changeset
71 JungleTreeEditor editor = tree.getJungleTreeEditor();
9
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
72 /*
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
73 * Merge.
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
74 * posが使われていない
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
75 * calculatePositionは何をしているのだろうか?
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
76 */
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
77 int pos = calculatePosition(tree.getRootNode(), netLog.getTimeStamp());
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
78 either = JungleUpdater.edit(editor, netLog, pos);
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
79 if(either.isA()) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
80 throw new IllegalStateException();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
81 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
82 editor = either.b();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
83 either = editor.putAttribute(root, "renewtime", tBuffer);
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
84 if(either.isA()) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
85 throw new IllegalStateException();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
86 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
87 editor = either.b();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
88 either = editor.success();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
89 }while(either.isA());
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
90 requestIncrementAndGet();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
91 return either;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
92 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
93
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
94 private static int calculatePosition(TreeNode node, long newNodeTimeStamp) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
95 int count = 0;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
96 long childTimeStamp = 0;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
97 for(TreeNode n : node.getChildren()) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
98 ByteBuffer timestamp = n.getAttributes().get("timestamp");
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
99 if(timestamp == null) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
100 return count;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
101 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
102 childTimeStamp = timestamp.getLong(0);
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
103 if (newNodeTimeStamp < childTimeStamp) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
104 break;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
105 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
106 count++;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
107 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
108 return count;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
109 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
110 }