annotate src/main/java/alice/topology/manager/reconnection/CheckConnectionList.java @ 345:8f71c3e6f11d

Change directory structure Maven standard
author sugi
date Wed, 16 Apr 2014 18:26:07 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
345
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
1 package alice.topology.manager.reconnection;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
2
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
3 import java.util.ArrayList;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
4 import java.util.HashMap;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
5 import java.util.List;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
6
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
7 import org.msgpack.type.ValueFactory;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
8
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
9 import alice.codesegment.CodeSegment;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
10 import alice.datasegment.CommandType;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
11 import alice.datasegment.Receiver;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
12 import alice.topology.HostMessage;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
13
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
14 public class CheckConnectionList extends CodeSegment {
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
15
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
16 private Receiver name = ids.create(CommandType.TAKE);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
17 private Receiver connection = ids.create(CommandType.TAKE);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
18 private Receiver abs = ids.create(CommandType.PEEK);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
19 private Receiver clone = ids.create(CommandType.TAKE);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
20
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
21 public CheckConnectionList(){
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
22 name.setKey("_RECABSNAME");
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
23 connection.setKey("connection");
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
24 abs.setKey("_ABSIPTABLE");
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
25 clone.setKey("_HMCLONE");
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
26 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
27
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
28 @Override
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
29 public void run() {
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
30 @SuppressWarnings("unchecked")
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
31 HashMap<String, ArrayList<HostMessage>> connectionList = connection.asClass(HashMap.class);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
32 @SuppressWarnings("unchecked")
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
33 List<HostMessage> ABSIPList = abs.asClass(List.class);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
34 String absName = name.asClass(String.class);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
35 HostMessage oldInfo = clone.asClass(HostMessage.class);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
36 HostMessage newInfo = null;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
37 for (HostMessage mes : ABSIPList){
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
38 if (mes.absName.equals(absName)){
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
39 newInfo = mes;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
40 break;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
41 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
42 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
43
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
44 List<HostMessage> clist = connectionList.get(absName);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
45 for (HostMessage mes : clist){
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
46 mes.setFlag();
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
47 ods.put(absName, mes);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
48 for (HostMessage mes2 : ABSIPList){
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
49 if (mes.name.equals(mes2.name)&&mes.port == mes2.port){
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
50 String absName2 = mes2.getABSName();
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
51 List<HostMessage> clist2 = connectionList.get(absName2);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
52 for (HostMessage mes3 : clist2){
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
53 if (mes3.name.equals(oldInfo.name)&&mes3.port == oldInfo.port){
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
54 mes3.name = newInfo.name;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
55 mes3.port = newInfo.port;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
56 mes3.setFlag();
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
57 ods.put(absName2, "_RECODATA", mes3);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
58 break;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
59 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
60 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
61 break;
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
62 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
63 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
64 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
65 System.out.println("SendHost Data");
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
66 ods.put(absName, ValueFactory.createNilValue());
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
67 ods.update("connection", connectionList);
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
68 new ReceiveError();
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
69 }
8f71c3e6f11d Change directory structure Maven standard
sugi
parents:
diff changeset
70 }