103
|
1 package jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.store.index;
|
|
2
|
|
3 import java.nio.ByteBuffer;
|
|
4
|
105
|
5 import fj.Ord;
|
103
|
6 import fj.data.List;
|
104
|
7 import fj.data.Option;
|
103
|
8 import fj.data.TreeMap;
|
110
|
9 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.NodePath;
|
103
|
10 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.TreeNode;
|
|
11 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.LoggingAttributes;
|
|
12 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.LoggingNode;
|
|
13 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.OperationLog;
|
|
14 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.DeleteAttributeOperation;
|
|
15 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.NodeOperation;
|
|
16 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.PutAttributeOperation;
|
|
17 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultEither;
|
|
18 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
|
|
19 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
|
|
20 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Pair;
|
|
21
|
|
22 public class LoggingIndexAttributes extends LoggingAttributes {
|
|
23
|
|
24 private final TreeNode wrap;
|
|
25 private final OperationLog log;
|
105
|
26 private TreeMap<String,TreeMap<String, List<TreeNode>>> index;
|
103
|
27
|
110
|
28 public LoggingIndexAttributes(TreeNode _wrap, OperationLog _log,TreeMap<String,TreeMap<String, List<TreeNode>>> index) {
|
103
|
29 super(_wrap, _log);
|
|
30 this.wrap = _wrap;
|
|
31 this.log = _log;
|
|
32 this.index = index;
|
|
33 }
|
|
34
|
|
35 private Either<Error,Logging> edit(NodeOperation _op)
|
|
36 {
|
|
37 Either<Error,TreeNode> either = _op.invoke(wrap);
|
|
38 if(either.isA()){
|
|
39 return DefaultEither.newA(either.a());
|
|
40 }
|
|
41
|
|
42 TreeNode newNode = either.b();
|
|
43 OperationLog newLog = log.add(_op);
|
|
44 Logging newLogNode = new LoggingNode(newNode,newLog);
|
|
45
|
|
46 return DefaultEither.newB(newLogNode);
|
|
47 }
|
|
48
|
|
49 public Either<Error,Logging> delete(final String key)
|
|
50 {
|
110
|
51 DeleteAttributeOperation deleteAttribute = new DeleteAttributeOperation(key);
|
103
|
52 Either<Error, Logging> either = edit(deleteAttribute);
|
|
53
|
|
54 if(either.isA())
|
|
55 return either;
|
|
56
|
|
57 Logging logNode = either.b();
|
|
58 TreeNode node = logNode.getWrap();
|
|
59 OperationLog log = logNode.getOperationLog();
|
|
60 index = index.delete(key);
|
|
61 Logging logIndexNode = new LoggingIndexNode(node, log, index);
|
110
|
62 return DefaultEither.newB(logIndexNode);
|
103
|
63 }
|
|
64
|
|
65 public Either<Error,Logging> put(final String key,final ByteBuffer value)
|
110
|
66 {return null;
|
|
67 /* PutAttributeOperation putAttribute = new PutAttributeOperation(key,value);
|
103
|
68 Either<Error, Logging> either = edit(putAttribute);
|
|
69 if(either.isA())
|
|
70 return either;
|
|
71
|
|
72 Logging logNode = either.b();
|
|
73 TreeNode newNode = logNode.getWrap();
|
|
74 OperationLog newLog = logNode.getOperationLog();
|
110
|
75
|
|
76
|
105
|
77
|
110
|
78 TreeMap<String, List<TreeNode>> list = TreeMap.empty(Ord.stringOrd);
|
|
79
|
|
80
|
|
81
|
|
82 Option<TreeMap<String, List<TreeNode>>> opAttributeIndex = index.get(key);
|
|
83 String indexKey = new String(value.array());
|
105
|
84 if (opAttributeIndex.isNone()) {
|
110
|
85 TreeMap<String, TreeNode> newNodeindex = TreeMap.empty(Ord.stringOrd);
|
|
86
|
|
87
|
105
|
88 } else {
|
|
89 Option<TreeNode> oplist = opAttributeIndex.some().get(indexKey);
|
110
|
90 list = list.cons(opAttributeIndex.some());
|
105
|
91 list = list.cons(newNode);
|
|
92 }
|
|
93
|
|
94
|
104
|
95 if (opList.isNone()) {
|
105
|
96 list = list.set(,newNode);
|
104
|
97 } else {
|
105
|
98 list = opList.some();
|
104
|
99 list = list.cons(newNode);
|
|
100 }
|
105
|
101 TreeMap<String,List<TreeNode>> newIndex = index.set(indexKey,list);
|
|
102 Logging logIndexNode = new LoggingIndexNode(newNode, newLog, newIndex);
|
107
|
103 return DefaultEither.newB(logIndexNode);*/
|
103
|
104 }
|
107
|
105 } |