summaryrefslogtreecommitdiff
path: root/BJC-Utils2/src/main/java/bjc/utils/data
diff options
context:
space:
mode:
authorbculkin2442 <bjculkin@mix.wvu.edu>2017-02-22 02:49:28 -0500
committerbculkin2442 <bjculkin@mix.wvu.edu>2017-02-22 02:49:28 -0500
commit135500e2da83657e2e5425a10746e80d5c7990d5 (patch)
tree83c181da36d7949ef92120ba5a851e630e023844 /BJC-Utils2/src/main/java/bjc/utils/data
parent3c7460950c060d93bffc395f074f09c18948d91c (diff)
Iterative version of topDownTransform()
Diffstat (limited to 'BJC-Utils2/src/main/java/bjc/utils/data')
-rw-r--r--BJC-Utils2/src/main/java/bjc/utils/data/TopDownTransformIterator.java142
1 files changed, 142 insertions, 0 deletions
diff --git a/BJC-Utils2/src/main/java/bjc/utils/data/TopDownTransformIterator.java b/BJC-Utils2/src/main/java/bjc/utils/data/TopDownTransformIterator.java
new file mode 100644
index 0000000..73db2ee
--- /dev/null
+++ b/BJC-Utils2/src/main/java/bjc/utils/data/TopDownTransformIterator.java
@@ -0,0 +1,142 @@
+package bjc.utils.data;
+
+import java.util.Deque;
+import java.util.Iterator;
+import java.util.LinkedList;
+import java.util.NoSuchElementException;
+import java.util.function.Function;
+import java.util.function.UnaryOperator;
+
+public class TopDownTransformIterator<ContainedType> implements Iterator<ITree<ContainedType>> {
+ private Function<ContainedType, TopDownTransformResult> picker;
+ private UnaryOperator<ITree<ContainedType>> transform;
+
+ private ITree<ContainedType> preParent;
+ private ITree<ContainedType> postParent;
+
+ private Deque<ITree<ContainedType>> preChildren;
+ private Deque<ITree<ContainedType>> postChildren;
+
+ private TopDownTransformIterator<ContainedType> curChild;
+
+ private boolean done;
+ private boolean initial;
+
+ public TopDownTransformIterator(Function<ContainedType, TopDownTransformResult> pickr,
+ UnaryOperator<ITree<ContainedType>> transfrm,
+ ITree<ContainedType> tree) {
+ preParent = tree;
+
+ preChildren = new LinkedList<>();
+ postChildren = new LinkedList<>();
+
+ picker = pickr;
+ transform = transfrm;
+
+ done = false;
+ initial = true;
+ }
+
+ public boolean hasNext() {
+ return !done;
+ }
+
+ public ITree<ContainedType> next() {
+ if(done) throw new NoSuchElementException();
+
+ if(initial) {
+ TopDownTransformResult res = picker.apply(preParent.getHead());
+
+ switch(res) {
+ case PASSTHROUGH:
+ postParent = new Tree<>(preParent.getHead());
+
+ if(preParent.getChildrenCount() != 0) {
+ for(int i = 0; i < preParent.getChildrenCount(); i++) {
+ preChildren.add(preParent.getChild(i));
+ }
+
+ // Return whatever the first child is
+ break;
+ } else {
+ done = true;
+ return postParent;
+ }
+ case SKIP:
+ done = true;
+ return preParent;
+ case TRANSFORM:
+ done = true;
+ return transform.apply(preParent);
+ case PUSHDOWN:
+ if(preParent.getChildrenCount() != 0) {
+ for(int i = 0; i < preParent.getChildrenCount(); i++) {
+ preChildren.add(preParent.getChild(i));
+ }
+
+ // Return whatever the first child is
+ break;
+ } else {
+ done = true;
+ return transform.apply(new Tree<>(preParent.getHead()));
+ }
+ case PULLUP:
+ ITree<ContainedType> intRes = transform.apply(preParent);
+
+ postParent = new Tree<>(intRes.getHead());
+
+ if(intRes.getChildrenCount() != 0) {
+ for(int i = 0; i < intRes.getChildrenCount(); i++) {
+ preChildren.add(intRes.getChild(i));
+ }
+
+ // Return whatever the first child is
+ break;
+ } else {
+ done = true;
+ return postParent;
+ }
+ default:
+ throw new IllegalArgumentException("Unknown result type " + res);
+ }
+
+ initial = false;
+ }
+
+ if(curChild == null || !curChild.hasNext()) {
+ if(preChildren.size() != 0) {
+ curChild = new TopDownTransformIterator<>(picker, transform, preChildren.pop());
+
+ ITree<ContainedType> res = curChild.next();
+ postChildren.add(res);
+
+ return res;
+ } else {
+ ITree<ContainedType> res = null;
+
+ if(postParent == null) {
+ res = new Tree<>(preParent.getHead());
+
+ for(ITree<ContainedType> child : postChildren) {
+ res.addChild(child);
+ }
+
+ res = transform.apply(res);
+ } else {
+ res = postParent;
+
+ for(ITree<ContainedType> child : postChildren) {
+ res.addChild(child);
+ }
+ }
+
+ return res;
+ }
+ } else {
+ ITree<ContainedType> res = curChild.next();
+ postChildren.add(res);
+
+ return res;
+ }
+ }
+}