Mercurial > hg > Members > tatsuki > bench > jungle-core
view src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/DefaultJungle.java @ 100:9a7b7af838e0
add index TreeNodeEditor
but node use
author | one |
---|---|
date | Thu, 11 Sep 2014 03:10:03 +0900 |
parents | fb1dc448ac8c |
children | f9a0e7069811 |
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.ChangeSet; 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.DefaultChangeSet; 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.util.Either; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error; import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Pair; 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(); //JungleTreeEditor e2 = 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) { journal = new NullJournal(); trees = new ConcurrentHashMap<String,JungleTree>(); uuid = _uuid; 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(); ChangeSet set = new DefaultChangeSet(root,null,list,uuid,_name,0,null); DefaultTreeContext tc = new DefaultTreeContext(root,set); TreeMap<String, String> attributeIndex = TreeMap.empty(Ord.stringOrd); TreeMap<String,TreeNode> nodeIndex = TreeMap.empty(Ord.stringOrd); JungleTree newTree = new DefaultJungleTree(tc,uuid,journal.getWriter(),editor , new Pair<TreeMap<String,TreeNode>,TreeMap<String,String>>(nodeIndex, attributeIndex)); if(trees.putIfAbsent(_name,newTree) != null){ return null; } return newTree; } }