summaryrefslogtreecommitdiff
path: root/src/org/catacombae/rarx/Tree.java
diff options
context:
space:
mode:
authorAndrew Dolgov <[email protected]>2012-10-19 10:53:02 +0400
committerAndrew Dolgov <[email protected]>2012-10-19 10:53:02 +0400
commit354cef3a9c4e020aef9afeee12f846e4554ec7b7 (patch)
treeadee32a85721ae5afadf4440e206a0e74b077f4f /src/org/catacombae/rarx/Tree.java
parent7923b86a935343bd0bc990b392fc85ac733518cf (diff)
add rarlib stuff
Diffstat (limited to 'src/org/catacombae/rarx/Tree.java')
-rw-r--r--src/org/catacombae/rarx/Tree.java55
1 files changed, 55 insertions, 0 deletions
diff --git a/src/org/catacombae/rarx/Tree.java b/src/org/catacombae/rarx/Tree.java
new file mode 100644
index 0000000..1ec9eb0
--- /dev/null
+++ b/src/org/catacombae/rarx/Tree.java
@@ -0,0 +1,55 @@
+package org.catacombae.rarx;
+import java.util.LinkedList;
+
+public class Tree<A> extends TreeNode<A> {
+ public Tree(A value) { super(value); }
+ public Tree() { super(); }
+
+ private LinkedList<Pair<String, TreeNode<A>>> children = new LinkedList<Pair<String, TreeNode<A>>>();
+
+ private static class Pair<A, B> {
+ public A a;
+ public B b;
+ public Pair(A a, B b) {
+ this.a = a;
+ this.b = b;
+ }
+ }
+
+ public void put(String entryName, TreeNode<A> tn) {
+ children.addLast(new Pair<String, TreeNode<A>>(entryName, tn));
+ }
+ public TreeNode<A> get(String entryName) {
+ for(Pair<String, TreeNode<A>> p : children) {
+ if(p.a.equals(entryName))
+ return p.b;
+ }
+ return null;
+ }
+
+ public int childCount() {
+ return children.size();
+ }
+
+ public String[] listChildrenNames() {
+ String[] targetArray = new String[children.size()];
+ int i = 0;
+ for(Pair<String, TreeNode<A>> p : children)
+ targetArray[i++] = p.a;
+
+ return targetArray;
+
+ }
+
+ public A[] listChildren(A[] targetArray) {
+ if(targetArray.length != children.size())
+ throw new IllegalArgumentException("target array not matching number of children");
+ else {
+ int i = 0;
+ for(Pair<String, TreeNode<A>> p : children) {
+ targetArray[i++] = p.b.getValue();
+ }
+ return targetArray;
+ }
+ }
+}