annotate src/main/java/jp/ac/u_ryukyu/ie/cr/tatsuki/jungle/query/PathNodeIterator.java @ 141:3071b1a471fd

add getKeys
author one
date Tue, 11 Nov 2014 18:57:52 +0900
parents ec166c8ff079
children 371b6ddb78f2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
98
95000ff9064d Create Query
one
parents:
diff changeset
1 package jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.query;
95000ff9064d Create Query
one
parents:
diff changeset
2
99
92d0c6e4655c refactoring to IteratorPathNode
one
parents: 98
diff changeset
3 import java.util.Iterator;
98
95000ff9064d Create Query
one
parents:
diff changeset
4 import java.util.Stack;
95000ff9064d Create Query
one
parents:
diff changeset
5
95000ff9064d Create Query
one
parents:
diff changeset
6 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.NodePath;
95000ff9064d Create Query
one
parents:
diff changeset
7 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultNodePath;
95000ff9064d Create Query
one
parents:
diff changeset
8 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.TreeNode;
99
92d0c6e4655c refactoring to IteratorPathNode
one
parents: 98
diff changeset
9 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.TreeNodeChildren;
98
95000ff9064d Create Query
one
parents:
diff changeset
10 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Pair;
95000ff9064d Create Query
one
parents:
diff changeset
11
101
c297f0015d9e create Update query
one
parents: 99
diff changeset
12 public class PathNodeIterator implements Iterator<Pair<TreeNode, NodePath>> {
98
95000ff9064d Create Query
one
parents:
diff changeset
13
101
c297f0015d9e create Update query
one
parents: 99
diff changeset
14 NodePath path;
99
92d0c6e4655c refactoring to IteratorPathNode
one
parents: 98
diff changeset
15 TreeNode root;
92d0c6e4655c refactoring to IteratorPathNode
one
parents: 98
diff changeset
16 TreeNode node;
92d0c6e4655c refactoring to IteratorPathNode
one
parents: 98
diff changeset
17 int childNumber;
101
c297f0015d9e create Update query
one
parents: 99
diff changeset
18 private TreeNodeChildren children;
c297f0015d9e create Update query
one
parents: 99
diff changeset
19 private Stack<TreeNode> nodeStack = new Stack<TreeNode>();
c297f0015d9e create Update query
one
parents: 99
diff changeset
20 private Stack<Integer> searchStack = new Stack<Integer>();
105
78ef456c98a0 add Query Status but has error
one
parents: 101
diff changeset
21
78ef456c98a0 add Query Status but has error
one
parents: 101
diff changeset
22 /*
78ef456c98a0 add Query Status but has error
one
parents: 101
diff changeset
23 * get queryIndexCondition from query
78ef456c98a0 add Query Status but has error
one
parents: 101
diff changeset
24 * if already index exists, use index
78ef456c98a0 add Query Status but has error
one
parents: 101
diff changeset
25 * otherwise traverse tree and create index
78ef456c98a0 add Query Status but has error
one
parents: 101
diff changeset
26 *
78ef456c98a0 add Query Status but has error
one
parents: 101
diff changeset
27 * */
141
3071b1a471fd add getKeys
one
parents: 139
diff changeset
28 public PathNodeIterator(Pair<TreeNode,NodePath> pair) {
3071b1a471fd add getKeys
one
parents: 139
diff changeset
29 this.root = pair.left();
3071b1a471fd add getKeys
one
parents: 139
diff changeset
30 path = pair.right();
101
c297f0015d9e create Update query
one
parents: 99
diff changeset
31 node = root;
98
95000ff9064d Create Query
one
parents:
diff changeset
32 }
95000ff9064d Create Query
one
parents:
diff changeset
33
95000ff9064d Create Query
one
parents:
diff changeset
34 @Override
95000ff9064d Create Query
one
parents:
diff changeset
35 public boolean hasNext() {
101
c297f0015d9e create Update query
one
parents: 99
diff changeset
36 return node != null;
98
95000ff9064d Create Query
one
parents:
diff changeset
37 }
95000ff9064d Create Query
one
parents:
diff changeset
38
95000ff9064d Create Query
one
parents:
diff changeset
39 @Override
95000ff9064d Create Query
one
parents:
diff changeset
40 public Pair<TreeNode, NodePath> next() {
101
c297f0015d9e create Update query
one
parents: 99
diff changeset
41 TreeNode now = node;
c297f0015d9e create Update query
one
parents: 99
diff changeset
42 NodePath currentPath = path;
139
ec166c8ff079 add findAll and findInSubTreeAll
one
parents: 134
diff changeset
43 // System.out.println("path = " + currentPath.toString());
102
3d88bad21bc4 refactoring 9-11
one
parents: 101
diff changeset
44 if (node.getChildren().size() > 0) { //
101
c297f0015d9e create Update query
one
parents: 99
diff changeset
45 nodeStack.push(node);
c297f0015d9e create Update query
one
parents: 99
diff changeset
46 path = path.add(0);
c297f0015d9e create Update query
one
parents: 99
diff changeset
47 children = node.getChildren();
c297f0015d9e create Update query
one
parents: 99
diff changeset
48 node = children.at(0).b();
c297f0015d9e create Update query
one
parents: 99
diff changeset
49 childNumber = 1;
c297f0015d9e create Update query
one
parents: 99
diff changeset
50 searchStack.push(childNumber);
113
6a35bd6e5887 change Attribute
one
parents: 110
diff changeset
51 } else if (node == root) {
6a35bd6e5887 change Attribute
one
parents: 110
diff changeset
52 node = null; // no more node
6a35bd6e5887 change Attribute
one
parents: 110
diff changeset
53 children = null;
6a35bd6e5887 change Attribute
one
parents: 110
diff changeset
54 return new Pair<TreeNode, NodePath>(now, currentPath);
6a35bd6e5887 change Attribute
one
parents: 110
diff changeset
55 }else if (children != null && children.size() > childNumber) {
101
c297f0015d9e create Update query
one
parents: 99
diff changeset
56 childNumber = searchStack.pop();
c297f0015d9e create Update query
one
parents: 99
diff changeset
57 node = children.at(childNumber).b();
c297f0015d9e create Update query
one
parents: 99
diff changeset
58 path = path.tail().add(childNumber);
c297f0015d9e create Update query
one
parents: 99
diff changeset
59 searchStack.push(++childNumber);
c297f0015d9e create Update query
one
parents: 99
diff changeset
60 } else {
c297f0015d9e create Update query
one
parents: 99
diff changeset
61 path = path.tail();
c297f0015d9e create Update query
one
parents: 99
diff changeset
62 node = nodeStack.pop();
c297f0015d9e create Update query
one
parents: 99
diff changeset
63 children = node.getChildren();
c297f0015d9e create Update query
one
parents: 99
diff changeset
64 childNumber = searchStack.pop();
c297f0015d9e create Update query
one
parents: 99
diff changeset
65 for (; children.size() == childNumber;) {
c297f0015d9e create Update query
one
parents: 99
diff changeset
66 if (node == root) {
c297f0015d9e create Update query
one
parents: 99
diff changeset
67 node = null; // no more node
c297f0015d9e create Update query
one
parents: 99
diff changeset
68 children = null;
c297f0015d9e create Update query
one
parents: 99
diff changeset
69 return new Pair<TreeNode, NodePath>(now, currentPath);
c297f0015d9e create Update query
one
parents: 99
diff changeset
70 }
113
6a35bd6e5887 change Attribute
one
parents: 110
diff changeset
71 path = path.tail();
6a35bd6e5887 change Attribute
one
parents: 110
diff changeset
72 node = nodeStack.pop();
6a35bd6e5887 change Attribute
one
parents: 110
diff changeset
73 children = node.getChildren();
6a35bd6e5887 change Attribute
one
parents: 110
diff changeset
74 childNumber = searchStack.pop();
101
c297f0015d9e create Update query
one
parents: 99
diff changeset
75 }
c297f0015d9e create Update query
one
parents: 99
diff changeset
76 if (node != null && childNumber < children.size()) {
c297f0015d9e create Update query
one
parents: 99
diff changeset
77 path = path.add(childNumber);
c297f0015d9e create Update query
one
parents: 99
diff changeset
78 nodeStack.push(node);
c297f0015d9e create Update query
one
parents: 99
diff changeset
79 node = children.at(childNumber).b();
c297f0015d9e create Update query
one
parents: 99
diff changeset
80 searchStack.push(++childNumber);
c297f0015d9e create Update query
one
parents: 99
diff changeset
81 }
c297f0015d9e create Update query
one
parents: 99
diff changeset
82 }
c297f0015d9e create Update query
one
parents: 99
diff changeset
83 return new Pair<TreeNode, NodePath>(now, currentPath);
98
95000ff9064d Create Query
one
parents:
diff changeset
84 }
99
92d0c6e4655c refactoring to IteratorPathNode
one
parents: 98
diff changeset
85
101
c297f0015d9e create Update query
one
parents: 99
diff changeset
86 @Override
c297f0015d9e create Update query
one
parents: 99
diff changeset
87 public void remove() {
c297f0015d9e create Update query
one
parents: 99
diff changeset
88 // TODO Auto-generated method stub
99
92d0c6e4655c refactoring to IteratorPathNode
one
parents: 98
diff changeset
89
101
c297f0015d9e create Update query
one
parents: 99
diff changeset
90 }
c297f0015d9e create Update query
one
parents: 99
diff changeset
91
98
95000ff9064d Create Query
one
parents:
diff changeset
92 }