annotate src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/IndexTreeEditor.java @ 151:d9fbddf77bf6

add class Index
author one
date Sat, 22 Nov 2014 14:46:44 +0900
parents feb2346ace19
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
1 package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl;
72f454eb04ec add parentIndex
one
parents:
diff changeset
2
72f454eb04ec add parentIndex
one
parents:
diff changeset
3
72f454eb04ec add parentIndex
one
parents:
diff changeset
4
146
371b6ddb78f2 repair putAttributeIndex and deleteAttributeIndex
one
parents: 145
diff changeset
5
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
6 import fj.data.List;
72f454eb04ec add parentIndex
one
parents:
diff changeset
7 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.NodePath;
72f454eb04ec add parentIndex
one
parents:
diff changeset
8 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.LoggingNode;
72f454eb04ec add parentIndex
one
parents:
diff changeset
9 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.NodeEditor;
72f454eb04ec add parentIndex
one
parents:
diff changeset
10 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.DefaultEvaluator;
72f454eb04ec add parentIndex
one
parents:
diff changeset
11 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.Direction;
72f454eb04ec add parentIndex
one
parents:
diff changeset
12 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.Traversal;
72f454eb04ec add parentIndex
one
parents:
diff changeset
13 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.Traverser;
72f454eb04ec add parentIndex
one
parents:
diff changeset
14 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultEither;
72f454eb04ec add parentIndex
one
parents:
diff changeset
15 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
72f454eb04ec add parentIndex
one
parents:
diff changeset
16 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
72f454eb04ec add parentIndex
one
parents:
diff changeset
17
72f454eb04ec add parentIndex
one
parents:
diff changeset
18 public class IndexTreeEditor {
72f454eb04ec add parentIndex
one
parents:
diff changeset
19
72f454eb04ec add parentIndex
one
parents:
diff changeset
20 private final Traverser traverser;
72f454eb04ec add parentIndex
one
parents:
diff changeset
21
72f454eb04ec add parentIndex
one
parents:
diff changeset
22
72f454eb04ec add parentIndex
one
parents:
diff changeset
23 public IndexTreeEditor(Traverser traverser)
72f454eb04ec add parentIndex
one
parents:
diff changeset
24 {
72f454eb04ec add parentIndex
one
parents:
diff changeset
25 this.traverser = traverser;
72f454eb04ec add parentIndex
one
parents:
diff changeset
26 }
72f454eb04ec add parentIndex
one
parents:
diff changeset
27
72f454eb04ec add parentIndex
one
parents:
diff changeset
28
149
feb2346ace19 refactor ParentIndex
one
parents: 146
diff changeset
29 public Either<Error,LoggingNode> edit(TreeNode root,NodePath path,NodeEditor editor)
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
30 {
72f454eb04ec add parentIndex
one
parents:
diff changeset
31 DefaultEvaluator e = new DefaultEvaluator(path);
72f454eb04ec add parentIndex
one
parents:
diff changeset
32 Either<Error, Traversal> either = traverser.traverse(root,e);
72f454eb04ec add parentIndex
one
parents:
diff changeset
33
72f454eb04ec add parentIndex
one
parents:
diff changeset
34 if(either.isA()){
72f454eb04ec add parentIndex
one
parents:
diff changeset
35 return DefaultEither.newA(either.a());
72f454eb04ec add parentIndex
one
parents:
diff changeset
36 }
72f454eb04ec add parentIndex
one
parents:
diff changeset
37
72f454eb04ec add parentIndex
one
parents:
diff changeset
38 Traversal t = either.b();
149
feb2346ace19 refactor ParentIndex
one
parents: 146
diff changeset
39 Either<Error,LoggingNode> ret = clone(t,editor);
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
40
72f454eb04ec add parentIndex
one
parents:
diff changeset
41 return ret;
72f454eb04ec add parentIndex
one
parents:
diff changeset
42 }
72f454eb04ec add parentIndex
one
parents:
diff changeset
43
149
feb2346ace19 refactor ParentIndex
one
parents: 146
diff changeset
44 private Either<Error,LoggingNode> clone(Traversal t,NodeEditor editor)
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
45 {
72f454eb04ec add parentIndex
one
parents:
diff changeset
46 // copying nodes from bottom to root
72f454eb04ec add parentIndex
one
parents:
diff changeset
47 List<Direction<TreeNode>> path = List.nil();
72f454eb04ec add parentIndex
one
parents:
diff changeset
48 for (Direction<TreeNode> direction : t) {
72f454eb04ec add parentIndex
one
parents:
diff changeset
49 path = path.cons(direction);
72f454eb04ec add parentIndex
one
parents:
diff changeset
50 }
72f454eb04ec add parentIndex
one
parents:
diff changeset
51
72f454eb04ec add parentIndex
one
parents:
diff changeset
52 // target
72f454eb04ec add parentIndex
one
parents:
diff changeset
53 Direction<TreeNode> targetDirection = path.head();
72f454eb04ec add parentIndex
one
parents:
diff changeset
54 TreeNode target = targetDirection.getTarget();
72f454eb04ec add parentIndex
one
parents:
diff changeset
55
72f454eb04ec add parentIndex
one
parents:
diff changeset
56 Either<Error, LoggingNode> either = editor.edit(target);
72f454eb04ec add parentIndex
one
parents:
diff changeset
57 if (either.isA()) {
72f454eb04ec add parentIndex
one
parents:
diff changeset
58 return DefaultEither.newA(either.a());
72f454eb04ec add parentIndex
one
parents:
diff changeset
59 }
72f454eb04ec add parentIndex
one
parents:
diff changeset
60
72f454eb04ec add parentIndex
one
parents:
diff changeset
61 LoggingNode newWrap = either.b();
72f454eb04ec add parentIndex
one
parents:
diff changeset
62
72f454eb04ec add parentIndex
one
parents:
diff changeset
63 // top
72f454eb04ec add parentIndex
one
parents:
diff changeset
64 int pos = targetDirection.getPosition();
72f454eb04ec add parentIndex
one
parents:
diff changeset
65 TreeNode child = newWrap.getWrap();
146
371b6ddb78f2 repair putAttributeIndex and deleteAttributeIndex
one
parents: 145
diff changeset
66
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
67 for (Direction<TreeNode> parentDirection : path.tail()) {
146
371b6ddb78f2 repair putAttributeIndex and deleteAttributeIndex
one
parents: 145
diff changeset
68 TreeNode updateTargetNode = parentDirection.getTarget();
371b6ddb78f2 repair putAttributeIndex and deleteAttributeIndex
one
parents: 145
diff changeset
69 TreeNodeChildren chs = updateTargetNode.getChildren();
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
70
146
371b6ddb78f2 repair putAttributeIndex and deleteAttributeIndex
one
parents: 145
diff changeset
71
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
72
72f454eb04ec add parentIndex
one
parents:
diff changeset
73 Either<Error, TreeNode> ret = chs.replaceNode(pos, child);
72f454eb04ec add parentIndex
one
parents:
diff changeset
74 if (ret.isA()) {
72f454eb04ec add parentIndex
one
parents:
diff changeset
75 return DefaultEither.newA(ret.a());
72f454eb04ec add parentIndex
one
parents:
diff changeset
76 }
72f454eb04ec add parentIndex
one
parents:
diff changeset
77
72f454eb04ec add parentIndex
one
parents:
diff changeset
78 TreeNode newParent = ret.b();
72f454eb04ec add parentIndex
one
parents:
diff changeset
79
72f454eb04ec add parentIndex
one
parents:
diff changeset
80 child = newParent;
72f454eb04ec add parentIndex
one
parents:
diff changeset
81 pos = parentDirection.getPosition();
72f454eb04ec add parentIndex
one
parents:
diff changeset
82 }
72f454eb04ec add parentIndex
one
parents:
diff changeset
83
72f454eb04ec add parentIndex
one
parents:
diff changeset
84 TreeNode newRoot = child;
72f454eb04ec add parentIndex
one
parents:
diff changeset
85 LoggingNode logNode = editor.wrap(newRoot, newWrap.getOperationLog());
146
371b6ddb78f2 repair putAttributeIndex and deleteAttributeIndex
one
parents: 145
diff changeset
86
371b6ddb78f2 repair putAttributeIndex and deleteAttributeIndex
one
parents: 145
diff changeset
87
149
feb2346ace19 refactor ParentIndex
one
parents: 146
diff changeset
88 return DefaultEither.newB(logNode);
145
72f454eb04ec add parentIndex
one
parents:
diff changeset
89 }
72f454eb04ec add parentIndex
one
parents:
diff changeset
90
72f454eb04ec add parentIndex
one
parents:
diff changeset
91 }