Mercurial > hg > Members > tatsuki > bench > jungle-core
view src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/DefaultJungle.java @ 190:a01507a9f826 default tip
change TreeMapBenchMark
author | tatsuki |
---|---|
date | Tue, 21 Apr 2015 17:28:20 +0900 |
parents | 066d9c5758dc |
children |
line wrap: on
line source
package jp.ac.u_ryukyu.ie.cr.shoshi.jungle; import java.util.Iterator; import java.util.concurrent.ConcurrentHashMap; import fj.Ord; import fj.data.List; import fj.data.TreeMap; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.persistent.ChangeList; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.persistent.Journal; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.persistent.NullJournal; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TreeContext; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TreeEditor; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultNodePath; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.DefaultTreeEditor; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.TreeNode; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.TreeOperation; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.DefaultTreeContext; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.transaction.DefaultTreeNode; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.DefaultTraverser; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.InterfaceTraverser; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error; import jp.ac.u_ryukyu.ie.cr.tatsuki.jungle.store.index.ParentIndex; public class DefaultJungle implements Jungle { private Journal journal; private ConcurrentHashMap<String, JungleTree> trees; private String uuid; private TreeEditor editor; public static void main(String args[]) { DefaultJungle j = new DefaultJungle(null, "hoge", new DefaultTreeEditor(new DefaultTraverser())); JungleTree t = j.createNewTree("fuga"); JungleTreeEditor e1 = t.getTreeEditor(); 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, TreeEditor editor) { this.journal = new NullJournal(); this.trees = new ConcurrentHashMap<String, JungleTree>(); this.uuid = uuid; this.editor = editor; } @Override public JungleTree getTreeByName(String name) { return trees.get(name); } @Override public JungleTree createNewTree(final String name) { ChangeList list = new ChangeList() { @Override public Iterator<TreeOperation> iterator() { List<TreeOperation> nil = List.nil(); return nil.iterator(); } @Override public String uuid() { return uuid; } @Override public String getTreeName() { return name; } }; DefaultTreeNode root = new DefaultTreeNode(); InterfaceTraverser traverser = new InterfaceTraverser(root, true); TreeContext tc = new DefaultTreeContext(root, null, list, uuid, name, 0, traverser); JungleTree newTree = new DefaultJungleTree(tc, uuid, journal.getWriter(), editor); if (trees.putIfAbsent(name, newTree) != null) { return null; } return newTree; } }