annotate src/main/java/jp/ac/u_ryukyu/ie/cr/jungle/transaction/DefaultTreeNode.java @ 0:44465893e8b8

first Commit
author Kazuma
date Wed, 30 Nov 2016 01:47:55 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
1 package jp.ac.u_ryukyu.ie.cr.jungle.transaction;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
2
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
3
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
4 import jp.ac.u_ryukyu.ie.cr.jungle.data.list.List;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
5 import jp.ac.u_ryukyu.ie.cr.jungle.store.impl.TreeNode;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
6 import jp.ac.u_ryukyu.ie.cr.jungle.store.impl.TreeNodeChildren;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
7 import jp.ac.u_ryukyu.ie.cr.jungle.util.Either;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
8 import jp.ac.u_ryukyu.ie.cr.jungle.util.Error;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
9 import jp.ac.u_ryukyu.ie.cr.jungle.data.treemap.TreeMap;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
10
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
11 import java.nio.ByteBuffer;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
12 import java.rmi.dgc.VMID;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
13
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
14 public class DefaultTreeNode implements TreeNode {
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
15 private List<TreeNode> children;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
16 private TreeMap<String, ByteBuffer> attrs;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
17 final String nodeId = new VMID().toString();
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
18
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
19 private static final List<TreeNode> NIL_LIST = new List<>();
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
20
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
21 public DefaultTreeNode() {
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
22 this(NIL_LIST, new TreeMap<>());
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
23 }
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
24
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
25 public DefaultTreeNode(List<TreeNode> _children, TreeMap<String, ByteBuffer> _attrs) {
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
26 attrs = _attrs;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
27 children = _children;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
28 }
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
29
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
30 @Override
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
31 public DefaultTreeNodeChildren getChildren() {
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
32 return new DefaultTreeNodeChildren(children, attrs);
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
33 }
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
34
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
35 @Override
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
36 public DefaultTreeNodeAttribute getAttributes() {
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
37 return new DefaultTreeNodeAttribute(children, attrs);
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
38 }
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
39
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
40 @Override
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
41 public DefaultTreeNode createNewNode() {
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
42 return new DefaultTreeNode();
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
43 }
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
44
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
45 public DefaultTreeNode clone() {
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
46 return new DefaultTreeNode(children, attrs);
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
47 }
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
48
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
49 @Override
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
50 public Either<Error, TreeNode> appendRootNode() {
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
51 TreeNodeChildren newRootChildren = new DefaultTreeNodeChildren(NIL_LIST, new TreeMap<>());
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
52 Either<jp.ac.u_ryukyu.ie.cr.jungle.util.Error, TreeNode> either = newRootChildren.addNewChildAt(0,this);
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
53 return either;
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
54 }
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
55
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
56 @Override
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
57 public int compareTo(TreeNode o) {
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
58 return this.hashCode() - o.hashCode();
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
59 }
44465893e8b8 first Commit
Kazuma
parents:
diff changeset
60 }