Mercurial > hg > Members > shoshi > jungle > jungle-core
view src/main/java/jp/ac/u_ryukyu/ie/cr/jungle/DefaultJungle.java @ 308:201cc75a9984
change Red Black Tree Edit Path Extends
author | tatsuki |
---|---|
date | Thu, 26 Jan 2017 15:23:25 +0900 |
parents | a5f7565f3a4b |
children | d6b81870216b |
line wrap: on
line source
package jp.ac.u_ryukyu.ie.cr.jungle; import jp.ac.u_ryukyu.ie.cr.jungle.data.list.List; import jp.ac.u_ryukyu.ie.cr.jungle.persistent.ChangeList; import jp.ac.u_ryukyu.ie.cr.jungle.persistent.Journal; import jp.ac.u_ryukyu.ie.cr.jungle.persistent.NullJournal; import jp.ac.u_ryukyu.ie.cr.jungle.query.traverser.DifferentialInterfaceTraverser; import jp.ac.u_ryukyu.ie.cr.jungle.query.traverser.InterfaceTraverser; import jp.ac.u_ryukyu.ie.cr.jungle.query.traverser.RedBlackTreeInterfaceTraverser; import jp.ac.u_ryukyu.ie.cr.jungle.store.TreeContext; import jp.ac.u_ryukyu.ie.cr.jungle.store.logger.DefaultTreeOperationLog; import jp.ac.u_ryukyu.ie.cr.jungle.store.logger.TreeOperationLog; import jp.ac.u_ryukyu.ie.cr.jungle.store.nodepath.DefaultNodePath; import jp.ac.u_ryukyu.ie.cr.jungle.store.operations.TreeOperation; import jp.ac.u_ryukyu.ie.cr.jungle.transaction.context.DefaultTreeContext; import jp.ac.u_ryukyu.ie.cr.jungle.transaction.context.DifferenceTreeContext; import jp.ac.u_ryukyu.ie.cr.jungle.transaction.editor.jungleTreeEditor.JungleTreeEditor; import jp.ac.u_ryukyu.ie.cr.jungle.transaction.editor.treeEditor.DefaultTreeEditor; import jp.ac.u_ryukyu.ie.cr.jungle.transaction.editor.treeEditor.DifferenceTreeEditor; import jp.ac.u_ryukyu.ie.cr.jungle.transaction.editor.treeEditor.RedBlackTreeEditor; import jp.ac.u_ryukyu.ie.cr.jungle.transaction.editor.treeEditor.TreeEditor; import jp.ac.u_ryukyu.ie.cr.jungle.transaction.node.Default.DefaultTreeNode; import jp.ac.u_ryukyu.ie.cr.jungle.transaction.node.Differencial.DifferencialTreeNode; import jp.ac.u_ryukyu.ie.cr.jungle.transaction.node.TreeNode; import jp.ac.u_ryukyu.ie.cr.jungle.transaction.node.redBlackTree.EmptyTreeNode; import jp.ac.u_ryukyu.ie.cr.jungle.traverser.DefaultTraverser; import jp.ac.u_ryukyu.ie.cr.jungle.query.traverser.DefaultInterfaceTraverser; import jp.ac.u_ryukyu.ie.cr.jungle.traverser.RedBlackTreeTraverser; import jp.ac.u_ryukyu.ie.cr.jungle.traverser.Traverser; import jp.ac.u_ryukyu.ie.cr.jungle.tree.DefaultJungleTree; import jp.ac.u_ryukyu.ie.cr.jungle.tree.DifferenceListJungleTree; import jp.ac.u_ryukyu.ie.cr.jungle.tree.JungleTree; import jp.ac.u_ryukyu.ie.cr.jungle.tree.RedBlackJungleTree; import jp.ac.u_ryukyu.ie.cr.jungle.util.Either; import jp.ac.u_ryukyu.ie.cr.jungle.util.Error.Error; import java.util.Enumeration; import java.util.Iterator; import java.util.concurrent.ConcurrentHashMap; public class DefaultJungle implements Jungle { private Journal journal; private ConcurrentHashMap<String, JungleTree> trees; private String uuid; private TreeEditor treeEditor; private TreeEditor differenceEditor; private TreeEditor redBlackTreeEditor; public static void main(String args[]) { DefaultJungle j = new DefaultJungle(null, "hoge"); JungleTree t = j.createNewTree("fuga"); JungleTreeEditor e1 = t.getJungleTreeEditor(); DefaultNodePath root = new DefaultNodePath(); Either<Error, JungleTreeEditor> either = e1.addNewChildAt(root, 0); e1 = either.b(); either = e1.addNewChildAt(root.add(0), 0); e1 = either.b(); e1.success(); } public DefaultJungle(Journal journal, String uuid) { this.journal = new NullJournal(); this.trees = new ConcurrentHashMap<String, JungleTree>(); this.uuid = uuid; Traverser defaultTraverser = new DefaultTraverser(); Traverser redBlackTreeTraverser = new RedBlackTreeTraverser(); this.treeEditor = new DefaultTreeEditor(defaultTraverser); this.differenceEditor = new DifferenceTreeEditor(defaultTraverser); this.redBlackTreeEditor = new RedBlackTreeEditor(redBlackTreeTraverser); } @Override public JungleTree getTreeByName(String name) { return trees.get(name); } @Override public JungleTree createNewTree(final String name) { return createNewTree(name, new DefaultTreeNode()); } @Override public JungleTree createNewTree(final String name, TreeNode rootNode) { ChangeList list = new ChangeList() { @Override public Iterator<TreeOperation> iterator() { List<TreeOperation> nil = new List<>(); return nil.iterator(); } @Override public String uuid() { return uuid; } @Override public String getTreeName() { return name; } @Override public TreeOperationLog getLog() { return new DefaultTreeOperationLog(); } }; InterfaceTraverser traverser = new DefaultInterfaceTraverser(rootNode, true); TreeContext tc = new DefaultTreeContext(rootNode, null, list, uuid, name, 0, traverser); JungleTree newTree = new DefaultJungleTree(tc, uuid, journal.getWriter(), treeEditor); if (trees.putIfAbsent(name, newTree) != null) { return null; } return newTree; } @Override public JungleTree createNewDifferenceTree(final String name) { TreeNode rootNode = new DifferencialTreeNode(); return createNewDifferenceTree(name, rootNode); } @Override public JungleTree createNewDifferenceTree(final String name, TreeNode rootNode) { ChangeList list = new ChangeList() { @Override public Iterator<TreeOperation> iterator() { List<TreeOperation> nil = new List<>(); return nil.iterator(); } @Override public String uuid() { return uuid; } @Override public String getTreeName() { return name; } @Override public TreeOperationLog getLog() { return new DefaultTreeOperationLog(); } }; InterfaceTraverser traverser = new DifferentialInterfaceTraverser(rootNode,rootNode, true); TreeContext tc = new DifferenceTreeContext(rootNode, rootNode, null, list, uuid, name, 0, traverser); JungleTree newTree = new DifferenceListJungleTree(tc, uuid, journal.getWriter(), differenceEditor); if (trees.putIfAbsent(name, newTree) != null) { return null; } return newTree; } @Override public JungleTree createNewRedBlackTree(String treeName, String balanceKey) { ChangeList list = new ChangeList() { @Override public Iterator<TreeOperation> iterator() { List<TreeOperation> nil = new List<>(); return nil.iterator(); } @Override public String uuid() { return uuid; } @Override public String getTreeName() { return treeName; } @Override public TreeOperationLog getLog() { return new DefaultTreeOperationLog(); } }; TreeNode rootNode = new EmptyTreeNode(); InterfaceTraverser traverser = new RedBlackTreeInterfaceTraverser(rootNode); TreeContext tc = new DefaultTreeContext(rootNode, null, list, uuid, treeName, 0, traverser); JungleTree newTree = new RedBlackJungleTree(tc, uuid, journal.getWriter(), redBlackTreeEditor, balanceKey); if (trees.putIfAbsent(treeName, newTree) != null) { return null; } return newTree; } @Override public Iterator<String> getTreeNames () { Enumeration<String> treeNames = trees.keys(); return new Iterator<String>() { @Override public boolean hasNext() { return treeNames.hasMoreElements(); } @Override public String next() { return treeNames.nextElement(); } }; } }