summaryrefslogtreecommitdiff
path: root/BJC-Utils2/src/main/java/bjc/utils/funcdata/ITree.java
diff options
context:
space:
mode:
authorbculkin2442 <bjculkin@mix.wvu.edu>2016-04-13 23:11:36 -0400
committerbculkin2442 <bjculkin@mix.wvu.edu>2016-04-13 23:11:36 -0400
commit9adff31e86603493c2a245e1e803d951675d5e00 (patch)
tree7374a6e4657333881db5621fbf23e18617470329 /BJC-Utils2/src/main/java/bjc/utils/funcdata/ITree.java
parentba07771f8333f1b098ab8a9ec9fec886b72b9cc0 (diff)
Implemented new tree abstraction
Diffstat (limited to 'BJC-Utils2/src/main/java/bjc/utils/funcdata/ITree.java')
-rw-r--r--BJC-Utils2/src/main/java/bjc/utils/funcdata/ITree.java145
1 files changed, 145 insertions, 0 deletions
diff --git a/BJC-Utils2/src/main/java/bjc/utils/funcdata/ITree.java b/BJC-Utils2/src/main/java/bjc/utils/funcdata/ITree.java
new file mode 100644
index 0000000..624c9d6
--- /dev/null
+++ b/BJC-Utils2/src/main/java/bjc/utils/funcdata/ITree.java
@@ -0,0 +1,145 @@
+package bjc.utils.funcdata;
+
+import java.util.function.Consumer;
+import java.util.function.Function;
+import java.util.function.Predicate;
+import java.util.function.UnaryOperator;
+
+import bjc.utils.funcdata.bst.TreeLinearizationMethod;
+
+/**
+ * A node in a homogenous tree with a unlimited amount of children
+ *
+ * @author ben
+ * @param <ContainedType>
+ * The type of data contained in the tree nodes
+ *
+ */
+public interface ITree<ContainedType> {
+ /**
+ * Add a child to this node
+ *
+ * @param child
+ * The child to add to this node
+ */
+ public void addChild(ITree<ContainedType> child);
+
+ /**
+ * Transform the value that is the head of this node
+ *
+ * @param <TransformedType>
+ * The type of the transformed value
+ * @param transformer
+ * The function to use to transform the value
+ * @return The transformed value
+ */
+ public <TransformedType> TransformedType transformHead(
+ Function<ContainedType, TransformedType> transformer);
+
+ /**
+ * Get a count of the number of direct children this node has
+ *
+ * @return The number of direct children this node has
+ */
+ public int getChildrenCount();
+
+ /**
+ * Transform one of this nodes children
+ *
+ * @param <TransformedType>
+ * The type of the transformed value
+ * @param childNo
+ * The number of the child to transform
+ * @param transformer
+ * The function to use to transform the value
+ * @return The transformed value
+ *
+ * @throws IllegalArgumentException
+ * if the childNo is out of bounds (0 <= childNo <=
+ * childCount())
+ */
+ public <TransformedType> TransformedType transformChild(int childNo,
+ Function<ITree<ContainedType>, TransformedType> transformer);
+
+ /**
+ * Collapse a tree into a single version
+ *
+ * @param <NewType>
+ * The intermediate type being folded
+ * @param <ReturnedType>
+ * The type that is the end result
+ * @param leafTransform
+ * The function to use to convert leaf values
+ * @param nodeCollapser
+ * The function to use to convert internal nodes and their
+ * children
+ * @param resultTransformer
+ * The function to use to convert a state to the returned
+ * version
+ * @return The final transformed state
+ */
+ public <NewType, ReturnedType> ReturnedType collapse(
+ Function<ContainedType, NewType> leafTransform,
+ Function<ContainedType, Function<IFunctionalList<NewType>, NewType>> nodeCollapser,
+ Function<NewType, ReturnedType> resultTransformer);
+
+ /**
+ * Expand the nodes of a tree into trees, and then merge the contents
+ * of those trees into a single tree
+ *
+ * @param mapper
+ * The function to use to map values into trees
+ * @return A tree, with some nodes expanded into trees
+ */
+ public ITree<ContainedType> flatMapTree(
+ Function<ContainedType, ITree<ContainedType>> mapper);
+
+ /**
+ * Transform some of the nodes in this tree
+ *
+ * @param nodePicker
+ * The predicate to use to pick nodes to transform
+ * @param transformer
+ * The function to use to transform picked nodes
+ */
+ public void selectiveTransform(Predicate<ContainedType> nodePicker,
+ UnaryOperator<ContainedType> transformer);
+
+ /**
+ * Transform the tree into a tree with a different type of token
+ *
+ * @param <MappedType>
+ * The type of the new tree
+ * @param transformer
+ * The function to use to transform tokens
+ * @return A tree with the token types transformed
+ */
+ public <MappedType> ITree<MappedType> transformTree(
+ Function<ContainedType, MappedType> transformer);
+
+ /**
+ * Perform an action on each part of the tree
+ *
+ * @param linearizationMethod
+ * The way to traverse the tree
+ * @param action
+ * The action to perform on each tree node
+ */
+ public void traverse(TreeLinearizationMethod linearizationMethod,
+ Consumer<ContainedType> action);
+
+ /**
+ * Rebuild the tree with the same structure, but different nodes
+ *
+ * @param <MappedType>
+ * The type of the new tree
+ * @param leafTransformer
+ * The function to use to transform leaf tokens
+ * @param operatorTransformer
+ * The function to use to transform internal tokens
+ * @return The tree, with the nodes changed
+ */
+ public <MappedType> ITree<MappedType> rebuildTree(
+ Function<ContainedType, MappedType> leafTransformer,
+ Function<ContainedType, MappedType> operatorTransformer);
+}