annotate src/main/java/jp/ac/u_ryukyu/ie/cr/shoshi/jungle/store/trasnformer/replaceRootNodeAt.java @ 190:a01507a9f826 default tip

change TreeMapBenchMark
author tatsuki
date Tue, 21 Apr 2015 17:28:20 +0900
parents 550f51183d8a
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
176
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
1 package jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.trasnformer;
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
2
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
3 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.TreeNode;
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
4 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.LoggingNode;
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
5 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.OperationLog;
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
6 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.DefaultEither;
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
7 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
8 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
9
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
10 public class replaceRootNodeAt implements NodeEditor {
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
11
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
12
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
13 public Either<Error, LoggingNode> _edit(LoggingNode _e)
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
14 {
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
15 Either<Error,LoggingNode> either = _e.replaceNewRootNode();
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
16 if(either.isA()){
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
17 // error
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
18 return either;
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
19 }
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
20 return DefaultEither.newB(either.b());
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
21 }
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
22
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
23
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
24 @Override
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
25 public Either<Error, LoggingNode> edit(TreeNode _e) {
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
26 LoggingNode logNode = wrap(_e);
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
27 return _edit(logNode);
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
28 }
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
29
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
30 public LoggingNode wrap(TreeNode node) {
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
31 return new LoggingNode(node);
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
32 }
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
33
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
34
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
35 @Override
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
36 public LoggingNode wrap(TreeNode node, OperationLog op) {
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
37 return new LoggingNode(node, op);
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
38 }
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
39
550f51183d8a Merge with a2598139df64efd6f649ba9a02f2b7d652bee8c1
one
parents:
diff changeset
40 }