changeset 23:3ef2a66a8c5d

commit
author Shoshi TAMAKI
date Thu, 10 Jan 2013 23:22:42 +0900
parents 9fd57b7c6adb
children ec033569ab8f
files src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/TreeEditResult.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/TreeEditResultStatus.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/TreeEditor.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/TreeEditorError.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultAttributes.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultChildren.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultNode.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultTraversableTree.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultTreeEditResult.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultTreeEditor.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/logger/LoggingAttributes.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/logger/LoggingChildren.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/AppendChildAt.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/DefaultEditableChildren.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/DeleteAttribute.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/DeleteChildAt.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/EditableAttributes.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/EditableChildren.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/NodeEditResultStatus.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/NodeEditor.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/NodeEditorError.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/SetAttribute.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/DefaultTraversal.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/DefaultTraverser.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/Traversable.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/Traversal.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/TraverseEvaluator.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/TraverseResult.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/Traverser.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/util/DefaultEither.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/util/DefaultError.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/util/Error.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/util/IterableConverter.java src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/util/IterableWrapper.java
diffstat 34 files changed, 282 insertions(+), 159 deletions(-) [+]
line wrap: on
line diff
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/TreeEditResult.java	Mon Jan 07 23:22:36 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,7 +0,0 @@
-package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store;
-
-public interface TreeEditResult
-{
-	public TreeEditor getNewEditor();
-	public TreeEditResultStatus getStatus();
-}
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/TreeEditResultStatus.java	Mon Jan 07 23:22:36 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,6 +0,0 @@
-package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store;
-
-public enum TreeEditResultStatus
-{
-	NODEPATH_NOTFOUND;
-}
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/TreeEditor.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/TreeEditor.java	Thu Jan 10 23:22:42 2013 +0900
@@ -1,19 +1,18 @@
 package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store;
 
 import java.nio.ByteBuffer;
-
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.NodeEditor;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
 
 public interface TreeEditor
 {
 	public TraversableTree getTree();
-	public TreeEditResult appendChild(NodePath _path,int _pos);
-	public TreeEditResult deleteChild(NodePath _path,int _pos);
-	
-	public TreeEditResult putAttribute(NodePath _path,String _key,ByteBuffer _value);
-	public TreeEditResult deleteAttribute(NodePath _path,String _key);
-	
-	public TreeEditResult edit(NodePath _path,NodeEditor _transformer);
+	public Either<Error,TreeEditor> appendChild(NodePath _path,int _pos);
+	public Either<Error,TreeEditor> deleteChild(NodePath _path,int _pos);
+	public Either<Error,TreeEditor> putAttribute(NodePath _path,String _key,ByteBuffer _value);
+	public Either<Error,TreeEditor> deleteAttribute(NodePath _path,String _key);
+	public Either<Error,TreeEditor> edit(NodePath _path,NodeEditor _transformer);
 	
 	public boolean success();
 }
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/TreeEditorError.java	Thu Jan 10 23:22:42 2013 +0900
@@ -0,0 +1,9 @@
+package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store;
+
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultError;
+
+public class TreeEditorError 
+{
+	public static final Error NODEPATH_NOTFOUND = new DefaultError();
+}
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultAttributes.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultAttributes.java	Thu Jan 10 23:22:42 2013 +0900
@@ -7,6 +7,8 @@
 import fj.data.TreeMap;
 
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Attributes;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.EditableAttributes;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.EditableNode;
 
 public class DefaultAttributes implements Attributes
 {
@@ -39,4 +41,5 @@
 		Option<ByteBuffer> result = attrs.get(_key);
 		return result.isSome() ? result.some() : null;
 	}
+
 }
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultChildren.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultChildren.java	Thu Jan 10 23:22:42 2013 +0900
@@ -17,10 +17,6 @@
 	private final List<DefaultNode> children;
 	private static final List<DefaultNode> EMPTY = List.nil();
 	
-	public enum Error{
-		INVALID_POSITION;
-	}
-	
 	public DefaultChildren()
 	{
 		this(EMPTY);
@@ -82,7 +78,7 @@
 	}
 
 	@Override
-	public EditableNode addNewChildAt(int _pos)
+	public Either<Error,EditableNode> addNewChildAt(int _pos)
 	{
 		
 		return null;
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultNode.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultNode.java	Thu Jan 10 23:22:42 2013 +0900
@@ -1,21 +1,32 @@
 package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl;
 
+import java.nio.ByteBuffer;
+import java.util.Iterator;
+
+import fj.Ord;
+import fj.data.List;
+import fj.data.Option;
+import fj.data.TreeMap;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Node;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.EditableAttributes;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.EditableChildren;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.EditableNode;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
 
 public class DefaultNode implements EditableNode
 {
-	public final DefaultAttributes attrs;
-	public final DefaultChildren children;
+	public List<DefaultNode> children;
+	public TreeMap<String,ByteBuffer> attrs;
+	
+	private static final List<DefaultNode> NIL_LIST = List.nil();
+	private static final TreeMap<String,ByteBuffer> NIL_MAP = TreeMap.empty(Ord.stringOrd);
 	
 	public DefaultNode()
 	{
-		this(new DefaultChildren(),new DefaultAttributes());
+		this(NIL_LIST,NIL_MAP);
 	}
 	
-	public DefaultNode(DefaultChildren _children,DefaultAttributes _attrs)
+	public DefaultNode(List<DefaultNode> _children,TreeMap<String,ByteBuffer> _attrs)
 	{
 		attrs = _attrs;
 		children = _children;
@@ -24,12 +35,12 @@
 	@Override
 	public EditableChildren getChildren()
 	{
-		return children;
+		return new DefaultChildren(children,attrs);
 	}
 
 	@Override
 	public EditableAttributes getAttributes()
 	{
-		return attrs;
+		return new DefaultAttributes(children,attrs);
 	}
 }
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultTraversableTree.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultTraversableTree.java	Thu Jan 10 23:22:42 2013 +0900
@@ -3,8 +3,8 @@
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Node;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Tree;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TraversableTree;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.Traversal;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.TraverseEvaluator;
-import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.TraverseResult;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.Traverser;
 
 public class DefaultTraversableTree implements TraversableTree
@@ -25,7 +25,7 @@
 	}
 
 	@Override
-	public Iterable<TraverseResult> traverse(TraverseEvaluator _e)
+	public Iterable<Traversal> traverse(TraverseEvaluator _e)
 	{
 		return traverser.traverse(tree,_e);
 	}
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultTreeEditResult.java	Mon Jan 07 23:22:36 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,29 +0,0 @@
-package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl;
-
-import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TreeEditResult;
-import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TreeEditResultStatus;
-import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TreeEditor;
-
-public class DefaultTreeEditResult implements TreeEditResult
-{
-	private final TreeEditor editor;
-	private final TreeEditResultStatus status;
-	
-	public DefaultTreeEditResult(TreeEditor _editor,TreeEditResultStatus _status)
-	{
-		editor = _editor;
-		status = _status;
-	}
-
-	@Override
-	public TreeEditor getNewEditor()
-	{
-		return editor;
-	}
-
-	@Override
-	public TreeEditResultStatus getStatus()
-	{
-		return status;
-	}
-}
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultTreeEditor.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/DefaultTreeEditor.java	Thu Jan 10 23:22:42 2013 +0900
@@ -8,9 +8,8 @@
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.ChangeList;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.NodePath;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TraversableTree;
-import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TreeEditResult;
-import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TreeEditResultStatus;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TreeEditor;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.TreeEditorError;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.AppendChildAt;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.DeleteAttribute;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.DeleteChildAt;
@@ -18,8 +17,12 @@
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.SetAttribute;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.DefaultTraverseEvaluator;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.DefaultTraverser;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.Traversal;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.TraverseResult;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser.Traverser;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultEither;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
 
 public class DefaultTreeEditor implements TreeEditor
 {
@@ -39,26 +42,26 @@
 	}
 	
 	@Override
-	public TreeEditResult appendChild(NodePath _path,int _pos)
+	public Either<Error,TreeEditor> appendChild(NodePath _path,int _pos)
 	{
 		return edit(_path,new AppendChildAt(_pos));
 	}
 	
 
 	@Override
-	public TreeEditResult deleteChild(NodePath _path,int _pos)
+	public Either<Error,TreeEditor> deleteChild(NodePath _path,int _pos)
 	{
 		return edit(_path,new DeleteChildAt(_pos));
 	}
 
 	@Override
-	public TreeEditResult putAttribute(NodePath _path, String _key,ByteBuffer _value)
+	public Either<Error,TreeEditor> putAttribute(NodePath _path, String _key,ByteBuffer _value)
 	{
 		return edit(_path,new SetAttribute(_key,_value));
 	}
 
 	@Override
-	public TreeEditResult deleteAttribute(NodePath _path, String _key)
+	public Either<Error,TreeEditor> deleteAttribute(NodePath _path, String _key)
 	{
 		return edit(_path,new DeleteAttribute(_key));
 	}
@@ -70,23 +73,23 @@
 	}
 
 	@Override
-	public TreeEditResult edit(NodePath _path, NodeEditor _editor)
+	public Either<Error,TreeEditor> edit(NodePath _path, NodeEditor _editor)
 	{
 		Tree t = tip.getTree();
 		Traverser traverser = new DefaultTraverser();
 		DefaultTraverseEvaluator te = new DefaultTraverseEvaluator(_path);
-		Iterable<TraverseResult> result = traverser.traverse(t,te);
-		Iterator<TraverseResult> itr = result.iterator();
+		Iterable<Traversal> result = traverser.traverse(t,te);
+		Iterator<Traversal> itr = result.iterator();
 		
 		if(itr.hasNext()){
-			TraverseResult r = itr.next();
+			Traversal r = itr.next();
 			cloneAndApplyToNodeEditorFromRoot(r,_editor);
 		}
 		
-		return new DefaultTreeEditResult(null,TreeEditResultStatus.NODEPATH_NOTFOUND);
+		return DefaultEither.newA(TreeEditorError.NODEPATH_NOTFOUND);
 	}
 	
-	public void cloneAndApplyToNodeEditorFromRoot(TraverseResult _r,NodeEditor _editor)
+	public void cloneAndApplyToNodeEditorFromRoot(Traversal _r,NodeEditor _editor)
 	{
 		LinkedList<DefaultNode> path = new LinkedList<DefaultNode>();
 		
@@ -97,6 +100,4 @@
 		
 		
 	}
-	
-	
 }
\ No newline at end of file
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/logger/LoggingAttributes.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/logger/LoggingAttributes.java	Thu Jan 10 23:22:42 2013 +0900
@@ -7,6 +7,8 @@
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.SetAttributeOperation;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.EditableAttributes;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.EditableNode;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultEither;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
 
 public class LoggingAttributes implements EditableAttributes
 {
@@ -26,8 +28,14 @@
 	}
 
 	@Override
-	public EditableNode delete(final String _key)
+	public Either<Error,EditableNode> delete(final String _key)
 	{
+		
+		Either<Error,EditableNode> either = wrap.delete(_key);
+		if(either.isA()){
+			return either;
+		}
+		
 		Operation opDelete = new DeleteAttributeOperation(){
 			@Override
 			public String getKey(){
@@ -36,14 +44,20 @@
 		};
 		
 		Logger newLog = log.add(opDelete);
-		EditableNode newWrap = wrap.delete(_key);
+		EditableNode newWrap = either.b();
+		EditableNode newLoggingNode = new LoggingNode(newWrap,newLog);
 		
-		return new LoggingNode(newWrap,newLog);
+		return DefaultEither.newB(newLoggingNode);
 	}
 
 	@Override
-	public EditableNode put(final String _key,final ByteBuffer _value)
+	public Either<Error,EditableNode> put(final String _key,final ByteBuffer _value)
 	{
+		Either<Error,EditableNode> either = wrap.put(_key,_value);
+		if(either.isA()){
+			return either;
+		}
+		
 		Operation opPut = new SetAttributeOperation(){
 			@Override
 			public String getKey(){
@@ -57,8 +71,8 @@
 		};
 		
 		Logger newLog = log.add(opPut);
-		EditableNode newWrap = wrap.put(_key,_value);
+		EditableNode newLoggingNode = new LoggingNode(either.b(),newLog);
 		
-		return new LoggingNode(newWrap,newLog);
+		return DefaultEither.newB(newLoggingNode);
 	}
 }
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/logger/LoggingChildren.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/impl/logger/LoggingChildren.java	Thu Jan 10 23:22:42 2013 +0900
@@ -8,6 +8,8 @@
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.Operation;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.EditableChildren;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer.EditableNode;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultEither;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.IterableWrapper;
 
 public class LoggingChildren implements EditableChildren
@@ -35,8 +37,13 @@
 	}
 
 	@Override
-	public EditableNode addNewChildAt(final int _pos)
+	public Either<Error,EditableNode> addNewChildAt(final int _pos)
 	{
+		Either<Error,EditableNode> either = wrap.addNewChildAt(_pos);
+		if(either.isA()){
+			return either;
+		}
+		
 		Operation opAddChild = new AppendChildAtOperation(){
 			@Override
 			public int position(){
@@ -45,14 +52,20 @@
 		};
 		
 		Logger newLog = log.add(opAddChild);
-		EditableNode newWrap = wrap.addNewChildAt(_pos);
+		EditableNode newWrap = either.b();
+		EditableNode newLoggingNode = new LoggingNode(newWrap,newLog);
 		
-		return new LoggingNode(newWrap,newLog);
+		return DefaultEither.newB(newLoggingNode);
 	}
 
 	@Override
-	public EditableNode deleteChildAt(final int _pos)
+	public Either<Error,EditableNode> deleteChildAt(final int _pos)
 	{
+		Either<Error,EditableNode> either = wrap.deleteChildAt(_pos);
+		if(either.isA()){
+			return either;
+		}
+		
 		Operation opDeleteChild = new DeleteChildAtOperation(){
 			@Override
 			public int position(){
@@ -61,8 +74,8 @@
 		};
 		
 		Logger newLog = log.add(opDeleteChild);
-		EditableNode newWrap = wrap.deleteChildAt(_pos);
+		EditableNode newLoggingNode = new LoggingNode(either.b(),newLog);
 		
-		return new LoggingNode(newWrap,newLog);
+		return DefaultEither.newB(newLoggingNode);
 	}
 }
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/AppendChildAt.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/AppendChildAt.java	Thu Jan 10 23:22:42 2013 +0900
@@ -1,5 +1,8 @@
 package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer;
 
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultEither;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
+
 public class AppendChildAt implements NodeEditor
 {
 	private final int pos;
@@ -10,9 +13,14 @@
 	}
 
 	@Override
-	public NodeEditResult edit(EditableNode _e)
+	public Either<Error,EditableNode> edit(EditableNode _e)
 	{
-		EditableNode node = _e.getChildren().addNewChildAt(pos);
-		return new DefaultNodeEditResult(NodeEditResultStatus.SUCCESS,node);
+		Either<Error,EditableNode> either = _e.getChildren().addNewChildAt(pos);
+		if(either.isA()){
+			// error
+			
+		}
+		
+		return DefaultEither.newB(either.b());
 	}
 }
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/DefaultEditableChildren.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/DefaultEditableChildren.java	Thu Jan 10 23:22:42 2013 +0900
@@ -5,6 +5,7 @@
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Node;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.AppendChildAtOperation;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.operations.Operation;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
 
 public class DefaultEditableChildren implements EditableChildren
 {
@@ -30,7 +31,7 @@
 	}
 
 	@Override
-	public EditableNode addNewChildAt(final int _pos)
+	public Either<Error,EditableNode> addNewChildAt(final int _pos)
 	{
 		AppendChildAtOperation op = new AppendChildAtOperation(){
 			@Override
@@ -43,7 +44,7 @@
 	}
 
 	@Override
-	public EditableNode deleteChildAt(int _pos)
+	public Either<Error,EditableNode> deleteChildAt(int _pos)
 	{
 		return null;
 	}
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/DeleteAttribute.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/DeleteAttribute.java	Thu Jan 10 23:22:42 2013 +0900
@@ -1,5 +1,7 @@
 package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer;
 
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
+
 public class DeleteAttribute implements NodeEditor
 {
 	private final String key;
@@ -10,9 +12,8 @@
 	}
 
 	@Override
-	public NodeEditResult edit(EditableNode _e)
+	public Either<Error,EditableNode> edit(EditableNode _e)
 	{
-		EditableNode node = _e.getAttributes().delete(key);
-		return new DefaultNodeEditResult(NodeEditResultStatus.SUCCESS,node);
+		return _e.getAttributes().delete(key);
 	}
 }
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/DeleteChildAt.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/DeleteChildAt.java	Thu Jan 10 23:22:42 2013 +0900
@@ -1,5 +1,7 @@
 package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer;
 
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
+
 public class DeleteChildAt implements NodeEditor
 {
 	private final int pos;
@@ -10,9 +12,8 @@
 	}
 
 	@Override
-	public NodeEditResult edit(EditableNode _e)
+	public Either<Error,EditableNode> edit(EditableNode _e)
 	{
-		EditableNode node = _e.getChildren().deleteChildAt(pos);
-		return new DefaultNodeEditResult(NodeEditResultStatus.SUCCESS,node);
+		return _e.getChildren().deleteChildAt(pos);
 	}
 }
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/EditableAttributes.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/EditableAttributes.java	Thu Jan 10 23:22:42 2013 +0900
@@ -3,9 +3,10 @@
 import java.nio.ByteBuffer;
 
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Attributes;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
 
 public interface EditableAttributes extends Attributes
 {
-	public EditableNode delete(String _key);
-	public EditableNode put(String _key,ByteBuffer _value);
+	public Either<Error,EditableNode> delete(String _key);
+	public Either<Error,EditableNode> put(String _key,ByteBuffer _value);
 }
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/EditableChildren.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/EditableChildren.java	Thu Jan 10 23:22:42 2013 +0900
@@ -1,9 +1,10 @@
 package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer;
 
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Children;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
 
 public interface EditableChildren extends Children
 {
-	public EditableNode addNewChildAt(int _pos);
-	public EditableNode deleteChildAt(int _pos);
+	public Either<Error,EditableNode> addNewChildAt(int _pos);
+	public Either<Error,EditableNode> deleteChildAt(int _pos);
 }
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/NodeEditResultStatus.java	Mon Jan 07 23:22:36 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,6 +0,0 @@
-package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer;
-
-public enum NodeEditResultStatus
-{
-	SUCCESS,FAIL;
-}
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/NodeEditor.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/NodeEditor.java	Thu Jan 10 23:22:42 2013 +0900
@@ -1,6 +1,8 @@
 package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer;
 
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
+
 public interface NodeEditor
 {
-	public NodeEditResult edit(EditableNode _e);
+	public Either<Error,EditableNode> edit(EditableNode _e);
 }
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/NodeEditorError.java	Thu Jan 10 23:22:42 2013 +0900
@@ -0,0 +1,9 @@
+package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer;
+
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultError;
+
+public class NodeEditorError
+{
+	public static final Error INDEX_OUT_OF_BOUNDS = new DefaultError();
+}
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/SetAttribute.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/SetAttribute.java	Thu Jan 10 23:22:42 2013 +0900
@@ -2,6 +2,8 @@
 
 import java.nio.ByteBuffer;
 
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
+
 public class SetAttribute implements NodeEditor
 {
 	private final String key;
@@ -14,9 +16,9 @@
 	}
 
 	@Override
-	public NodeEditResult edit(EditableNode _e)
+	public Either<Error,EditableNode> edit(EditableNode _e)
 	{
 		EditableAttributes attrs = _e.getAttributes();
-		return new DefaultNodeEditResult(NodeEditResultStatus.SUCCESS,attrs.put(key,value));
+		return attrs.put(key,value);
 	}
 }
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/DefaultTraversal.java	Thu Jan 10 23:22:42 2013 +0900
@@ -0,0 +1,22 @@
+package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser;
+
+import java.util.Iterator;
+
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Node;
+
+public class DefaultTraversal implements Traversal
+{
+
+	@Override
+	public Iterator<Node> iterator()
+	{
+		return null;
+	}
+
+	@Override
+	public Node destination()
+	{
+		return null;
+	}
+
+}
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/DefaultTraverser.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/DefaultTraverser.java	Thu Jan 10 23:22:42 2013 +0900
@@ -1,30 +1,51 @@
 package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser;
 
 import java.util.Iterator;
-
 import fj.P;
 import fj.P2;
 import fj.data.List;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Node;
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Tree;
-import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.IterableWrapper;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.IterableConverter;
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.IterableConverter.Converter;
 
 public class DefaultTraverser implements Traverser
 {
 	@Override
-	public Iterable<TraverseResult> traverse(Tree _tree, TraverseEvaluator _evaluator)
+	public Iterable<Traversal> traverse(Tree _tree, TraverseEvaluator _evaluator)
 	{
 		Node root = _tree.getRoot();
 		
 		List<Node> current = List.nil();
 		TraverseEvaluator evaluator = _evaluator;
 		
-		List<TraverseResultImpl> totalResult = _traverse(current,root,evaluator);
+		List<List<Node>> totalResult = _traverse(current,root,evaluator);
 		
-		return new IterableWrapper<TraverseResult>(totalResult);
+		Converter<Traversal,List<Node>> converter = new IterableConverter.Converter<Traversal,List<Node>>(){
+			@Override
+			public Traversal conv(final List<Node> _b)
+			{
+				Traversal t = new Traversal(){
+					@Override
+					public Iterator<Node> iterator(){
+						return _b.iterator();
+					}
+
+					@Override
+					public Node destination() {
+						return _b.last();
+					}
+					
+				};
+				
+				return t;
+			}
+		};
+		
+		return new IterableConverter<Traversal,List<Node>>(totalResult,converter);
 	}
 	
-	private List<TraverseResultImpl> _traverse(List<Node> _path,Node _current,TraverseEvaluator _evaluator)
+	private List<List<Node>> _traverse(List<Node> _path,Node _current,TraverseEvaluator _evaluator)
 	{
 		List<Node> currentPath = _path.snoc(_current);
 		
@@ -46,36 +67,18 @@
 			}
 		}
 		
-		List<TraverseResultImpl> totalResult = List.nil();
+		List<List<Node>> totalResult = List.nil();
 		for(P2<Node,Evaluation> next : accepted){
 			Node node = next._1();
 			TraverseEvaluator evaluator = next._2().evaluator();
-			List<TraverseResultImpl> result = _traverse(currentPath,node,evaluator);
-			totalResult = totalResult.append(result);
+			List<List<Node>> result = _traverse(currentPath,node,evaluator);
+			
+			
+			for(List<Node> list : result){
+				totalResult = totalResult.snoc(list.cons(_current));
+			}
 		}
 		
 		return totalResult;
 	}
-	
-	public static class TraverseResultImpl implements TraverseResult
-	{
-		private final List<Node> result;
-		
-		public TraverseResultImpl(List<Node> _result)
-		{
-			result = _result;
-		}
-
-		@Override
-		public Iterator<Node> iterator()
-		{
-			return result.iterator();
-		}
-		
-		@Override
-		public Node destination()
-		{
-			return result.last();
-		}
-	}
 }
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/Traversable.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/Traversable.java	Thu Jan 10 23:22:42 2013 +0900
@@ -2,5 +2,5 @@
 
 public interface Traversable
 {
-	public Iterable<TraverseResult> traverse(TraverseEvaluator _e);
+	public Iterable<Traversal> traverse(TraverseEvaluator _e);
 }
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/Traversal.java	Thu Jan 10 23:22:42 2013 +0900
@@ -0,0 +1,8 @@
+package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser;
+
+import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Node;
+
+public interface Traversal extends Iterable<Node>
+{
+	public Node destination();
+}
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/TraverseEvaluator.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/TraverseEvaluator.java	Thu Jan 10 23:22:42 2013 +0900
@@ -1,7 +1,5 @@
 package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser;
 
-import java.util.Iterator;
-
 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Node;
 
 public interface TraverseEvaluator
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/TraverseResult.java	Mon Jan 07 23:22:36 2013 +0900
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,8 +0,0 @@
-package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.traverser;
-
-import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.core.Node;
-
-public interface TraverseResult extends Iterable<Node>
-{
-	public Node destination();
-}
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/Traverser.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/traverser/Traverser.java	Thu Jan 10 23:22:42 2013 +0900
@@ -4,5 +4,5 @@
 
 public interface Traverser
 {
-	public Iterable<TraverseResult> traverse(Tree _tree,TraverseEvaluator _evaluator);
+	public Iterable<Traversal> traverse(Tree _tree,TraverseEvaluator _evaluator);
 }
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/util/DefaultEither.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/util/DefaultEither.java	Thu Jan 10 23:22:42 2013 +0900
@@ -5,10 +5,20 @@
 	private final A theA;
 	private final B theB;
 	
-	public DefaultEither(A _theA)
+	private DefaultEither(A _theA,B _theB)
 	{
 		theA = _theA;
-		theB = null;
+		theB = _theB;
+	}
+	
+	public static final <A,B> DefaultEither<A,B> newA(A _theA)
+	{
+		return new DefaultEither<A,B>(_theA,null);
+	}
+	
+	public static final <A,B> DefaultEither<A,B> newB(B _theB)
+	{
+		return new DefaultEither<A,B>(null,_theB);
 	}
 
 	@Override
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/util/DefaultError.java	Thu Jan 10 23:22:42 2013 +0900
@@ -0,0 +1,5 @@
+package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util;
+
+public class DefaultError implements Error
+{
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/util/Error.java	Thu Jan 10 23:22:42 2013 +0900
@@ -0,0 +1,5 @@
+package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util;
+
+public interface Error {
+
+}
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/util/IterableConverter.java	Thu Jan 10 23:22:42 2013 +0900
@@ -0,0 +1,56 @@
+package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util;
+
+import java.util.Iterator;
+
+public class IterableConverter<A,B> implements Iterable<A>
+{
+	private final Iterable<B> iterable;
+	private final Converter<A,B> converter;
+	
+	public IterableConverter(Iterable<B> _iterable,Converter<A,B> _converter)
+	{
+		iterable = _iterable;
+		converter = _converter;
+	}
+	
+	@Override
+	public Iterator<A> iterator()
+	{
+		return new IteratorConverter<A,B>(iterable.iterator(),converter);
+	}
+	
+	private static final class IteratorConverter<A,B> implements Iterator<A>
+	{
+		private final Iterator<B> iterator;
+		private final Converter<A,B> converter;
+		
+		public IteratorConverter(Iterator<B> _iterator,Converter<A,B> _converter)
+		{
+			iterator = _iterator;
+			converter = _converter;
+		}
+		
+		@Override
+		public boolean hasNext()
+		{
+			return iterator.hasNext();
+		}
+
+		@Override
+		public A next()
+		{
+			return converter.conv(iterator.next());
+		}
+
+		@Override
+		public void remove()
+		{
+			iterator.remove();
+		}
+	}
+
+	public static interface Converter<A,B>
+	{
+		public A conv(B _b);
+	}
+}
--- a/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/util/IterableWrapper.java	Mon Jan 07 23:22:36 2013 +0900
+++ b/src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/util/IterableWrapper.java	Thu Jan 10 23:22:42 2013 +0900
@@ -10,7 +10,7 @@
 	{
 		iterable = _iterable;
 	}
-
+	
 	@Override
 	public Iterator<T> iterator()
 	{