31
|
1 package alice.jungle.operations;
|
1
|
2
|
|
3 import java.util.Iterator;
|
|
4 import java.util.LinkedList;
|
|
5
|
|
6 import org.msgpack.annotation.Message;
|
|
7
|
|
8 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.NodePath;
|
|
9 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.TreeOperationLog;
|
|
10 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.NodeOperation;
|
|
11 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.TreeOperation;
|
|
12
|
|
13 @Message
|
|
14 public class NetworkTreeOperationLog implements TreeOperationLog
|
|
15 {
|
83
|
16 public LinkedList<NetworkTreeOperation> list;
|
2
|
17 public int size;
|
1
|
18
|
|
19 public NetworkTreeOperationLog() {
|
83
|
20 list = new LinkedList<NetworkTreeOperation>();
|
1
|
21 size = 0;
|
|
22 }
|
83
|
23
|
|
24 public NetworkTreeOperationLog(Iterable<TreeOperation> _list)
|
|
25 {
|
|
26 list = new LinkedList<NetworkTreeOperation>();
|
|
27 for(TreeOperation op: _list) {
|
|
28 NetworkTreeOperation nOp = new NetworkTreeOperation(op);
|
|
29 list.add(nOp);
|
|
30 }
|
|
31 size = list.size();
|
|
32 }
|
|
33
|
1
|
34 public NetworkTreeOperationLog(Iterable<TreeOperation> _list, int _size)
|
|
35 {
|
83
|
36 list = new LinkedList<NetworkTreeOperation>();
|
79
|
37 for(TreeOperation op: _list) {
|
|
38 NetworkTreeOperation nOp = new NetworkTreeOperation(op);
|
|
39 list.add(nOp);
|
|
40 }
|
1
|
41 size = _size;
|
|
42 }
|
|
43
|
|
44 @Override
|
|
45 public Iterator<TreeOperation> iterator() {
|
83
|
46 LinkedList<TreeOperation> opList = new LinkedList<TreeOperation>();
|
|
47 for(NetworkTreeOperation op : list) {
|
|
48 opList.add(op);
|
|
49 }
|
|
50 return opList.iterator();
|
1
|
51 }
|
|
52
|
|
53 @Override
|
|
54 public NetworkTreeOperationLog add(NodePath _p, NodeOperation _op)
|
|
55 {
|
79
|
56 NetworkTreeOperation op = new NetworkTreeOperation(_p, _op);
|
|
57 list.add(op);
|
83
|
58 return this;
|
1
|
59 }
|
|
60
|
|
61 @Override
|
|
62 public NetworkTreeOperationLog append(TreeOperationLog _log)
|
|
63 {
|
79
|
64 for (TreeOperation o : _log) {
|
|
65 NetworkTreeOperation op = new NetworkTreeOperation(o);
|
|
66 list.add(op);
|
1
|
67 }
|
83
|
68 return this;
|
1
|
69 }
|
|
70
|
|
71 @Override
|
|
72 public int length()
|
|
73 {
|
|
74 return size;
|
|
75 }
|
|
76
|
|
77 }
|