annotate src/alice/jungle/codesegment/LogUpdateCodeSegment.java @ 47:686057add8a4

confirmed LogUpdateCodeSegment
author one
date Fri, 12 Jul 2013 11:45:12 +0900
parents fd3643699f83
children a89c3539bff2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
34
bf696a6334b2 add LogUpdateCodeSegment
one
parents:
diff changeset
1 package alice.jungle.codesegment;
bf696a6334b2 add LogUpdateCodeSegment
one
parents:
diff changeset
2
40
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
3 import java.io.IOException;
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
4
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
5 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTree;
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
6 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.JungleTreeEditor;
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
7 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.store.impl.logger.DefaultTreeOperationLog;
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
8 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Either;
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
9 import jp.ac.u_ryukyu.ie.cr.shoshi.jungle.util.Error;
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
10 import jungle.test.bbs.JungleManager;
34
bf696a6334b2 add LogUpdateCodeSegment
one
parents:
diff changeset
11 import alice.codesegment.CodeSegment;
bf696a6334b2 add LogUpdateCodeSegment
one
parents:
diff changeset
12 import alice.datasegment.CommandType;
bf696a6334b2 add LogUpdateCodeSegment
one
parents:
diff changeset
13 import alice.datasegment.Receiver;
40
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
14 import alice.jungle.datasegment.store.operations.DefaultTreeOperationLogContainer;
46
fd3643699f83 modified pom.xml. fix conflict log4j libraries
one
parents: 43
diff changeset
15 import alice.jungle.transaction.NetworkDefaultJungleTreeEditor;
34
bf696a6334b2 add LogUpdateCodeSegment
one
parents:
diff changeset
16
bf696a6334b2 add LogUpdateCodeSegment
one
parents:
diff changeset
17 public class LogUpdateCodeSegment extends CodeSegment {
bf696a6334b2 add LogUpdateCodeSegment
one
parents:
diff changeset
18
42
4419ac56cbfd implemented serverName filed
one
parents: 40
diff changeset
19 public Receiver arg1 = ids.create(CommandType.PEEK);
47
686057add8a4 confirmed LogUpdateCodeSegment
one
parents: 46
diff changeset
20 public Receiver host = ids.create(CommandType.PEEK);
39
10359a815068 add alice.jungle.codesegment.remote
one
parents: 34
diff changeset
21
47
686057add8a4 confirmed LogUpdateCodeSegment
one
parents: 46
diff changeset
22 public LogUpdateCodeSegment() {
686057add8a4 confirmed LogUpdateCodeSegment
one
parents: 46
diff changeset
23 host.setKey("host",0);
39
10359a815068 add alice.jungle.codesegment.remote
one
parents: 34
diff changeset
24 }
10359a815068 add alice.jungle.codesegment.remote
one
parents: 34
diff changeset
25
34
bf696a6334b2 add LogUpdateCodeSegment
one
parents:
diff changeset
26 public void run() {
42
4419ac56cbfd implemented serverName filed
one
parents: 40
diff changeset
27 System.out.println("--LogUpdateCodeSegment--");
4419ac56cbfd implemented serverName filed
one
parents: 40
diff changeset
28 int index = arg1.index;
47
686057add8a4 confirmed LogUpdateCodeSegment
one
parents: 46
diff changeset
29 String h = host.asString();
40
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
30 DefaultTreeOperationLogContainer container = arg1.asClass(DefaultTreeOperationLogContainer.class);
47
686057add8a4 confirmed LogUpdateCodeSegment
one
parents: 46
diff changeset
31 if(updaterIsMe(h, container)) {
686057add8a4 confirmed LogUpdateCodeSegment
one
parents: 46
diff changeset
32 LogUpdateCodeSegment updateCS = new LogUpdateCodeSegment();
686057add8a4 confirmed LogUpdateCodeSegment
one
parents: 46
diff changeset
33 updateCS.arg1.setKey("log", index+1);
42
4419ac56cbfd implemented serverName filed
one
parents: 40
diff changeset
34 return;
4419ac56cbfd implemented serverName filed
one
parents: 40
diff changeset
35 }
40
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
36 DefaultTreeOperationLog log = null;
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
37 try {
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
38 log = container.convert();
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
39 } catch (IOException e) {
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
40 e.printStackTrace();
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
41 }
43
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
42 JungleTree tree = JungleManager.getJungle().getTreeByName("boards");
40
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
43 JungleTreeEditor editor = tree.getTreeEditor();
43
12d87bb4b84d modified LogUpdateCodeSegment
one
parents: 42
diff changeset
44 Either<Error, JungleTreeEditor> either = JungleManager.edit(editor, log);
40
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
45 if(either.isA()) {
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
46 throw new IllegalStateException();
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
47 }
7e94de2d6bc0 add PutAnotherLogCodeSegment, PutHostLogCodeSegment
one
parents: 39
diff changeset
48 editor = either.b();
46
fd3643699f83 modified pom.xml. fix conflict log4j libraries
one
parents: 43
diff changeset
49 either = editor.success();
fd3643699f83 modified pom.xml. fix conflict log4j libraries
one
parents: 43
diff changeset
50 if(either.isA()) {
fd3643699f83 modified pom.xml. fix conflict log4j libraries
one
parents: 43
diff changeset
51 throw new IllegalStateException();
fd3643699f83 modified pom.xml. fix conflict log4j libraries
one
parents: 43
diff changeset
52 }
47
686057add8a4 confirmed LogUpdateCodeSegment
one
parents: 46
diff changeset
53 LogUpdateCodeSegment updateCS = new LogUpdateCodeSegment();
686057add8a4 confirmed LogUpdateCodeSegment
one
parents: 46
diff changeset
54 updateCS.arg1.setKey("log", index+1);
34
bf696a6334b2 add LogUpdateCodeSegment
one
parents:
diff changeset
55 }
42
4419ac56cbfd implemented serverName filed
one
parents: 40
diff changeset
56
47
686057add8a4 confirmed LogUpdateCodeSegment
one
parents: 46
diff changeset
57 private boolean updaterIsMe(String host, DefaultTreeOperationLogContainer container) {
686057add8a4 confirmed LogUpdateCodeSegment
one
parents: 46
diff changeset
58 return host.equals(container.getServerName());
42
4419ac56cbfd implemented serverName filed
one
parents: 40
diff changeset
59 }
4419ac56cbfd implemented serverName filed
one
parents: 40
diff changeset
60
4419ac56cbfd implemented serverName filed
one
parents: 40
diff changeset
61
4419ac56cbfd implemented serverName filed
one
parents: 40
diff changeset
62
34
bf696a6334b2 add LogUpdateCodeSegment
one
parents:
diff changeset
63 }