annotate rep/SessionManager.java @ 382:4b87f89b3afd

REP Session Manager (Java version) new structure
author one@firefly.cr.ie.u-ryukyu.ac.jp
date Mon, 10 Nov 2008 22:07:45 +0900
parents c78569ab5fce
children bcdf5476b8e4
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
266
4a02c7f26794 *** empty log message ***
kono
parents: 264
diff changeset
1
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
2 package rep;
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
3
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
4 import java.io.IOException;
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
5 import java.net.InetSocketAddress;
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
6 import java.nio.channels.ClosedChannelException;
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
7 import java.nio.channels.SelectionKey;
83
9381b4734a0b *** empty log message ***
pin
parents: 82
diff changeset
8 import java.util.LinkedList;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
9 import java.util.List;
231
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
10 import java.util.Set;
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
11 import java.util.concurrent.BlockingQueue;
192
6fb97c7a0b42 *** empty log message ***
pin
parents: 191
diff changeset
12 import java.util.concurrent.LinkedBlockingQueue;
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
13
346
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
14 import org.xml.sax.SAXException;
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
15
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
16
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
17
337
5ba5b7a9761b use REPLogger
kono
parents: 336
diff changeset
18 import rep.channel.REPLogger;
123
5b1a0574b406 *** empty log message ***
pin
parents: 122
diff changeset
19 import rep.channel.REPServerSocketChannel;
133
8dce4348966c *** empty log message ***
kono
parents: 124
diff changeset
20 import rep.channel.REPSocketChannel;
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
21 import rep.gui.CloseButtonEvent;
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
22 import rep.gui.DoGUIUpdate;
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
23 import rep.gui.SelectButtonEvent;
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
24 import rep.gui.SessionManagerEvent;
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
25 import rep.gui.SessionManagerEventListener;
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
26 import rep.gui.SessionManagerGUI;
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
27 import rep.gui.SessionManagerGUIimpl;
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
28 import rep.handler.Dispatcher;
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
29 import rep.handler.Editor;
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
30 import rep.handler.REPNode;
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
31 import rep.handler.FirstConnector;
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
32 import rep.handler.Forwarder;
158
5cc8cd48bded *** empty log message ***
pin
parents: 155
diff changeset
33 import rep.channel.REPSelector;
56
6ead43b2475e *** empty log message ***
pin
parents: 53
diff changeset
34 import rep.xml.SessionXMLDecoder;
45
10f1adf6d74d *** empty log message ***
pin
parents: 39
diff changeset
35 import rep.xml.SessionXMLEncoder;
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
36 import rep.channel.REPSelectionKey;
264
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
37
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
38 /*
264
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
39 +-------+--------+--------+-------+--------+---------+------+
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
40 | cmd | session| editor | seqid | lineno | textsiz | text |
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
41 | | id | id | | | | |
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
42 +-------+--------+--------+-------+--------+---------+------+
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
43 o---------- header section (network order) ----------o
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
44
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
45 int cmd; kind of command
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
46 int sid; session ID : uniqu to editing file
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
47 int eid; editor ID : owner editor ID = 1。Session に対して unique
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
48 -1 session manager command
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
49 -2 merge command
264
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
50 int seqno; Sequence number : sequence number はエディタごとに管理
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
51 int lineno; line number
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
52 int textsize; textsize : bytesize
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
53 byte[] text;
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
54 */
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
55
250
5f357ca66714 *** empty log message ***
pin
parents: 246
diff changeset
56 public class SessionManager implements SessionManagerEventListener{
337
5ba5b7a9761b use REPLogger
kono
parents: 336
diff changeset
57 static public REPLogger logger = REPLogger.singleton();
5ba5b7a9761b use REPLogger
kono
parents: 336
diff changeset
58
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
59 SessionList sessionList;
280
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
60 private SessionManagerGUI gui;
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
61 // Main nio.Selector of this server
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
62 private REPSelector<REPCommand> selector;
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
63 // Known Session Manager List, At most one parent. No parent means master.
319
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
64 SessionManagerList smList;
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
65 // Known Editor list. Connected Editor has a channel.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
66 // Session Manager Channel may have dummy editors.
356
b18c24dcc5d2 Before chaning put/join scheme for ditributed select.
kono
parents: 355
diff changeset
67 EditorList editorList;
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
68 // Commands for busy editor are kept in this queue.
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
69 private List<PacketSet> waitingCommandInMerge;
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
70 // Command from gui. Synchronization is required.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
71 private BlockingQueue<SessionManagerEvent> waitingEventQueue
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
72 = new LinkedBlockingQueue<SessionManagerEvent>();;
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
73 // host name of this server. One of connecting SocketChannel's hostname
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
74 public String myHost;
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
75 // Single threaded write queueu. To avoid dead lock with too many writes.
317
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
76 private LinkedList<PacketSet> writeQueue = new LinkedList<PacketSet>();
336
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
77 private int receive_port;
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
78 private int parent_port;
101
612cb62151ce *** empty log message ***
pin
parents: 100
diff changeset
79 static final int DEFAULT_PORT = 8766;
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
80 // Queue limit for debugging purpose.
332
36faf76a087c *** empty log message ***
kono
parents: 330
diff changeset
81 private static final int packetLimit = 200;
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
82
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
83 // globalSessionID = SessionManagerID * MAXID + localSessionID
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
84 private static final int MAXID = 10000;
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
85 SessionXMLDecoder decoder = new SessionXMLDecoder();
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
86 SessionXMLEncoder encoder = new SessionXMLEncoder();
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
87 // SocketChannel for our parent. At most one parent is allowed.
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
88 private REPNode sm_join_channel;
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
89 // Routing table for session and session manager.
369
7d21eb209e27 *** empty log message ***
kono
parents: 367
diff changeset
90 private RoutingTable routingTable = new RoutingTable(this);
365
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
91 private SessionManagerEvent execAfterConnect = null;;
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
92
316
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
93 public static void main(String[] args) throws InterruptedException, IOException {
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
94
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
95 int port = DEFAULT_PORT;
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
96 int port_s = DEFAULT_PORT;
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
97 //System.setProperty("file.encoding", "UTF-8");
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
98 if(args.length > 0){
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
99 if (args.length!=2) {
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
100 logger.writeLog("Usage: sessionManager our_port parent_port");
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
101 return;
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
102 }
316
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
103 port = Integer.parseInt(args[0]);
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
104 port_s = Integer.parseInt(args[1]);
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
105 }
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
106 SessionManager sm = new SessionManager();
336
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
107 sm.setReceivePort(port);
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
108 sm.setParentPort(port_s);
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
109 // Ok start main loop
316
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
110 sm.init(port,new SessionManagerGUIimpl(sm));
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
111 }
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
112
336
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
113 public void setReceivePort(int port) {
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
114 receive_port = port;
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
115 }
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
116
280
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
117 public void init(int port, SessionManagerGUI gui) throws IOException, InterruptedException {
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
118 this.gui = gui;
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
119 init(port);
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
120 mainLoop();
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
121 }
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
122
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
123 private void init(int port) throws InterruptedException, IOException {
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
124 selector = REPSelector.<REPCommand>create();
186
d22384c0026c *** empty log message ***
kent
parents: 185
diff changeset
125 REPServerSocketChannel<REPCommand> ssc = REPServerSocketChannel.<REPCommand>open(new REPCommandPacker());
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
126 ssc.configureBlocking(false); // Selector requires this
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
127 ssc.socket().setReuseAddress(true); //reuse address 必須
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
128 //getAllByNameで取れた全てのアドレスに対してbindする
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
129 ssc.socket().bind(new InetSocketAddress(port));
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
130 ssc.register(selector, SelectionKey.OP_ACCEPT,
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
131 new Dispatcher(this)); // FirstConnector?
6
bdb91f4cea26 It Can connect SessionManagers each other.
pin
parents: 5
diff changeset
132
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
133 sessionList = new SessionList();
7
5067a6a93d01 *** empty log message ***
pin
parents: 6
diff changeset
134 smList = new SessionManagerList();
356
b18c24dcc5d2 Before chaning put/join scheme for ditributed select.
kono
parents: 355
diff changeset
135 editorList = new EditorList();
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
136 waitingCommandInMerge = new LinkedList<PacketSet>();
228
e6c7a56ff7f1 *** empty log message ***
pin
parents: 227
diff changeset
137
215
7649238aaf66 *** empty log message ***
pin
parents: 213
diff changeset
138
155
bbd2801d8ce0 *** empty log message ***
pin
parents: 152
diff changeset
139 }
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
140
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
141 /*
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
142 * The main loop.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
143 * Check incoming events and waiting writes.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
144 * Do select and call select() to check in coming packets.
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
145 * We wrote everything in one thread, but we can assign
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
146 * one thread for each communication channel and GUI event.
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
147 */
231
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
148 public void mainLoop() throws IOException {
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
149 while(true){
328
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
150 checkWaitingCommandInMerge();
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
151 if (checkInputEvent() ||
328
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
152 checkWaitingWrite()) {
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
153 // try to do fair execution for waiting task
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
154 if(selector.selectNow() > 0) select();
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
155 continue;
300
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
156 }
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
157 // now we can wait for input packet or event
233
dae90ded1bcd *** empty log message ***
pin
parents: 231
diff changeset
158 selector.select();
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
159 select();
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
160 }
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
161 }
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
162
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
163 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
164 * Synchronize GUI event in the main loop.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
165 */
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
166 private boolean checkInputEvent() {
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
167 SessionManagerEvent e;
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
168 if((e = waitingEventQueue.poll())!=null){
334
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
169 e.exec(this);
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
170 return true;
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
171 }
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
172 return false;
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
173 }
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
174
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
175 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
176 * Write a packet during the main loop.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
177 */
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
178 private boolean checkWaitingWrite() throws IOException {
317
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
179 PacketSet p = writeQueue.poll();
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
180 if (p!=null) {
327
7b6dede07f4a *** empty log message ***
kono
parents: 324
diff changeset
181 p.channel.write(p.command);
317
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
182 return true;
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
183 }
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
184 return false;
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
185 }
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
186
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
187 /**
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
188 * Check waiting command in merge
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
189 * @return true if there is a processed waiting command
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
190 * @throws IOException
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
191 */
346
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
192 private void checkWaitingCommandInMerge() {
328
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
193 List<PacketSet> w = waitingCommandInMerge;
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
194 waitingCommandInMerge = new LinkedList<PacketSet>();
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
195 for(PacketSet p: w) {
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
196 REPNode e = p.getEditor();
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
197 if(e.isMerging()) { // still merging do nothing
328
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
198 waitingCommandInMerge.add(p);
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
199 } else {
346
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
200 try {
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
201 if (sessionManage(e, p.command)) { // we don't need this
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
202 assert false;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
203 return;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
204 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
205 e.manage(p.command);
347
86935b872385 *** empty log message ***
kono
parents: 346
diff changeset
206 } catch (Exception e1) {
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
207 // should be e.close()?
346
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
208 close(p.channel);
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
209 }
328
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
210 }
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
211 }
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
212 }
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
213
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
214 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
215 * If we have waiting write commands, further sent commands also
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
216 * wait to avoid out of order packet sending.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
217 */
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
218 public boolean hasWaitingCommand(REPSocketChannel<REPCommand>c) {
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
219 for(PacketSet p:waitingCommandInMerge) {
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
220 if (p.channel==c) {
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
221 return true;
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
222 }
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
223 }
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
224 return false;
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
225 }
328
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
226
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
227 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
228 * Close a channel in case of exception or close.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
229 */
346
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
230 private void close(REPSocketChannel<REPCommand> channel) {
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
231 REPSelectionKey<REPCommand>key = channel.keyFor1(selector);
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
232 REPNode handler = (REPNode)key.attachment();
346
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
233 key.cancel();
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
234 handler.cancel(channel);
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
235 // we have to remove session/enditor
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
236 }
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
237
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
238
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
239 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
240 * Do select operation on the Selector. Each key has a forwarder.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
241 * A forwarder can be a firstConnector, a forwarder for Session Manager
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
242 * or an Editor.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
243 */
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
244 private void select() throws IOException {
231
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
245
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
246 Set<REPSelectionKey<REPCommand>> keys = selector.selectedKeys1();
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
247 for(REPSelectionKey<REPCommand> key : keys){
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
248 if(key.isAcceptable()){
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
249 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
250 * Incoming connection. We don't know which, editor or
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
251 * session manager. Assign FirstConnector to distinguish.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
252 */
199
456ba58cd042 *** empty log message ***
pin
parents: 198
diff changeset
253 REPSocketChannel<REPCommand> channel = key.accept(new REPCommandPacker());
337
5ba5b7a9761b use REPLogger
kono
parents: 336
diff changeset
254 logger.writeLog("SessionManager.select() : key.isAcceptable : channel = " + channel);
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
255 registerChannel(channel, new FirstConnector(this));
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
256 channel = null;
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
257 }else if(key.isReadable()){
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
258 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
259 * Incoming packets are handled by a various forwarder.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
260 * A hadler throw IOException() in case of a trouble to
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
261 * close the channel.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
262 */
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
263 REPNode handler = (REPNode)key.attachment();
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
264 try {
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
265 handler.handle(key);
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
266 } catch (IOException e) {
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
267 key.cancel();
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
268 handler.cancel(key.channel1());
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
269 }
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
270 }
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
271 }
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
272 }
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
273
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
274 public void registerChannel(REPSocketChannel<REPCommand> channel,REPNode handler) throws IOException {
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
275 if(channel == null) {
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
276 return;
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
277 }
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
278 handler.setChannel(channel);
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
279 channel.configureBlocking(false);
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
280 channel.register(selector, SelectionKey.OP_READ, handler);
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
281 }
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
282
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
283 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
284 * After loop detection, we give up session manager join.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
285 */
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
286 private void cancel_sm_join() {
364
c965ef2b5fd6 *** empty log message ***
kono
parents: 363
diff changeset
287 logger.writeLog("Loop detected "+this);
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
288 removeChannel(sm_join_channel);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
289 sm_join_channel=null;
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
290 }
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
291
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
292
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
293 private void removeChannel(REPNode channel) {
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
294 REPSelectionKey<REPCommand> key = channel.channel.keyFor1(selector);
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
295 key.cancel();
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
296 try {
364
c965ef2b5fd6 *** empty log message ***
kono
parents: 363
diff changeset
297 channel.channel.close1();
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
298 } catch (IOException e) {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
299 }
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
300 }
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
301
320
83790b8b8174 *** empty log message ***
kono
parents: 319
diff changeset
302
319
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
303 void updateGUI() {
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
304 //リストのコピーをGUIに渡す
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
305 LinkedList<Session> sList = new LinkedList<Session>(sessionList.values());
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
306 LinkedList<REPNode> eList;
365
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
307 if (false) {
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
308 // local editor only
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
309 eList = new LinkedList<REPNode>();
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
310 for(REPNode e:editorList.values()) {
365
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
311 if (getSMID(e.eid)==smList.sessionManagerID()) {
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
312 eList.add(e);
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
313 }
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
314 }
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
315 } else {
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
316 eList = new LinkedList<REPNode>(editorList.values());
365
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
317 }
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
318 //GUIに反映
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
319 Runnable doRun = new DoGUIUpdate(sList, eList, gui);
279
e58695b5118d *** empty log message ***
kono
parents: 274
diff changeset
320 gui.invokeLater(doRun);
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
321 }
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
322
83
9381b4734a0b *** empty log message ***
pin
parents: 82
diff changeset
323
139
d6b94713cf45 *** empty log message ***
pin
parents: 133
diff changeset
324
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
325 public void setMyHostName(String localHostName) {
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
326 myHost = localHostName + receive_port;
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
327 setHostToEditor(myHost);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
328 }
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
329
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
330 private void setHostToEditor(String myHost2) {
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
331 for(REPNode editor : editorList.values()){
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
332 if (editor.channel!=null)
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
333 editor.setHost(myHost2);
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
334 }
76
97ca5f5447cd *** empty log message ***
pin
parents: 75
diff changeset
335 }
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
336
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
337
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
338 /**
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
339 * GUI から、呼ばれて、Session Managerに接続する。
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
340 * Host 名のSession Manager に SM_JOIN する。自分は、Session を持っていては
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
341 * ならない。複数のSession Managerにjoinすることは出来ない。(NATを実装するまでは)。
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
342 * @param host
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
343 */
378
c78569ab5fce *** empty log message ***
kono
parents: 377
diff changeset
344 public void connectSessionManager(String host, int port) {
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
345 if (sm_join_channel!=null) return;
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
346 if (!sessionList.isEmpty()) return;
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
347 if (!smList.isMaster()) return;
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
348 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
349 * IPv6 対応では、複数のアドレスを取って、それのすべてに接続を試す必要が
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
350 * ある。
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
351 */
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
352 InetSocketAddress addr = new InetSocketAddress(host, port);
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
353 try {
186
d22384c0026c *** empty log message ***
kent
parents: 185
diff changeset
354 REPSocketChannel<REPCommand> sessionchannel = REPSocketChannel.<REPCommand>create(new REPCommandPacker());
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
355 sessionchannel.connect(addr);
337
5ba5b7a9761b use REPLogger
kono
parents: 336
diff changeset
356 while(!sessionchannel.finishConnect());
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
357 REPNode sm = new FirstConnector(this);
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
358 registerChannel(sessionchannel, sm);
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
359 sm_join(sm);
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
360 }catch (IOException e) {
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
361 }
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
362 }
364
c965ef2b5fd6 *** empty log message ***
kono
parents: 363
diff changeset
363
378
c78569ab5fce *** empty log message ***
kono
parents: 377
diff changeset
364 public void connectSessionManager(String host) {
c78569ab5fce *** empty log message ***
kono
parents: 377
diff changeset
365 connectSessionManager(host,parent_port);
364
c965ef2b5fd6 *** empty log message ***
kono
parents: 363
diff changeset
366 }
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
367
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
368 /**
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
369 * channel に SMCMD_SM_JOIN command を送る。
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
370 * @param channel
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
371 */
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
372 private void sm_join(REPNode channel){
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
373 sm_join_channel = channel;
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
374 //SM_JOINコマンドを生成。
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
375 REPCommand command = new REPCommand();
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
376 command.setCMD(REP.SMCMD_SM_JOIN);
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
377 command.setEID(-1); // request Parent SessionManagerID
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
378 command.setSID(-1); // request SessionManagerID
79
d1877cfd131d *** empty log message ***
pin
parents: 78
diff changeset
379
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
380 //hostnameをセット。
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
381 setMyHostName(channel.getLocalHostName());
82
4bb583553a42 *** empty log message ***
pin
parents: 81
diff changeset
382
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
383 String string = myHost;
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
384 command.setString(string);
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
385
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
386 //SM_JOINコマンドを送信。
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
387 channel.send(command);
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
388 // ack を受け取ったら、SessionManagerのListに追加。ここではやらない。
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
389 }
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
390
361
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
391 /*
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
392 * Select Session from Manager button
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
393 * selected editor is joined editor directly connected to this session
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
394 * manager.
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
395 */
316
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
396 public void selectSession(SelectButtonEvent event) throws IOException {
250
5f357ca66714 *** empty log message ***
pin
parents: 246
diff changeset
397 int sid = event.getSID();
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
398 Session session = sessionList.get(sid);
365
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
399 if (session==null) throw new IOException();
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
400 REPNode editor = event.getEditor();
324
e235998427a6 try to fix merger
kono
parents: 323
diff changeset
401 if (editor.hasSession()) return;
365
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
402 // assert(getSMID(editor.eid)==smList.sessionManagerID());
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
403 // assert(editor.channel!=null);
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
404 editor.setSID(sid); // mark as selected
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
405 selectSession0(sid, session, editor.getEID(), editor);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
406 }
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
407
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
408 private void selectSession0(int sid, Session session, int eid, REPNode editor) {
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
409 if (editor.isDirect()&&editor.getEID()==eid) {
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
410 selectSession(sid, session, editor.getEID(), editor);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
411 } else {
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
412 // we don't have this editor, search the editor first.
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
413 REPNode next = routingTable.toSessionManager(getSMID(eid));
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
414 // pass the select command to the next path.
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
415 REPCommand command = new REPCommand();
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
416 command.setCMD(REP.SMCMD_SELECT0);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
417 command.setSID(sid);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
418 command.setEID(eid);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
419 command.setString(editor.getHost());
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
420 next.send(command);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
421 }
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
422 }
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
423
361
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
424 /*
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
425 * Select Session Protocol handler
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
426 * called from GUI or incoming SMCMD_SELECT command.
361
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
427 */
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
428 private void selectSession(int sid, Session session, int eid, REPNode editor) {
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
429 if(session.hasOwner()){
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
430 // we have selected session.
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
431 REPCommand sendCommand = new REPCommand();
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
432 if (editor.isDirect()&&editor.getEID()==eid) {
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
433 // Found directly connected joined editor. Send join_ack().
361
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
434 session.addForwarder(editor);
359
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
435 sendUpdate(session.getSID());
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
436 sendCommand.setCMD(REP.SMCMD_JOIN_ACK);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
437 } else {
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
438 // We have a session, but joined editor is on the other sm.
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
439 // SELECT_ACK is sent to the session ring to
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
440 // find out the joined editor.
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
441 sendCommand.setCMD(REP.SMCMD_SELECT_ACK);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
442 }
370
46c95d8885ad fix put_ack in single server test.
kono
parents: 369
diff changeset
443 sendCommand.setSID(sid);
46c95d8885ad fix put_ack in single server test.
kono
parents: 369
diff changeset
444 sendCommand.string = session.getName();
46c95d8885ad fix put_ack in single server test.
kono
parents: 369
diff changeset
445 sendCommand.setEID(eid);
46c95d8885ad fix put_ack in single server test.
kono
parents: 369
diff changeset
446 editor.send(sendCommand);
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
447 }else {
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
448 forwardSelect(sid, session, eid, editor);
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
449 }
8
b774b87cc2c1 *** empty log message ***
pin
parents: 7
diff changeset
450 }
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
451
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
452 private void forwardSelect(int sid, Session session, int eid,
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
453 REPNode editor) {
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
454 REPNode next;
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
455 // session searching continue...
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
456 next = routingTable.toSessionManager(getSMID(sid));
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
457 // make a forwarding channel here
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
458 REPNode f = createSessionForwarder(sid, next);
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
459 session.setFirstForwarder(f);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
460 session.addForwarder(editor);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
461 // pass the select command to the next path.
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
462 REPCommand command = new REPCommand();
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
463 command.setCMD(REP.SMCMD_SELECT);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
464 command.setSID(sid);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
465 command.setEID(eid);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
466 command.setString(editor.getHost());
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
467 next.send(command);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
468 }
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
469
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
470 private REPNode createSessionForwarder(int sid, REPNode editor) {
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
471 REPNode f = new Forwarder(this);
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
472 f.setEID(makeID(editorList.newEid()));
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
473 f.setChannel(editor.channel); // incoming channel
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
474 f.setHost(myHost);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
475 f.setSID(sid);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
476 return f;
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
477 }
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
478
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
479 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
480 * Create and send UPDATE command.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
481 */
359
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
482 private void sendUpdate(int sid) {
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
483 REPCommand command = makeREPCommandWithSessionList(REP.SMCMD_UPDATE);
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
484 command.setSID(sid);
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
485 command.setEID(REP.SM_EID.id);
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
486 smList.sendToMaster(command);
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
487 }
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
488
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
489 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
490 * Create new editor in this sessin manager. A dummy editor
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
491 * is created also.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
492 */
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
493 public REPNode newEditor(REPSocketChannel<REPCommand> channel) {
359
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
494 int eid = makeID(editorList.newEid());
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
495 REPNode editor = new Editor(this, eid, channel);
359
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
496 editorList.add(editor);
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
497 return editor;
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
498 }
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
499
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
500 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
501 * Create new session.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
502 */
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
503 public Session newSession(REPNode master) {
359
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
504 int sid= makeID(sessionList.newSessionID());
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
505 Session session = new Session(sid, master);
360
b25f832f875d *** empty log message ***
kono
parents: 359
diff changeset
506 sessionList.put(sid, session);
359
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
507 return session;
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
508 }
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
509
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
510 public void addWaitingCommand(PacketSet set) {
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
511 waitingCommandInMerge.add(set);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
512 }
148
6a5fe529b192 *** empty log message ***
pin
parents: 146
diff changeset
513
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
514 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
515 * Synchronize GUI command in this session manager.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
516 */
222
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
517 public void buttonPressed(SessionManagerEvent event) {
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
518 try {
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
519 waitingEventQueue.put(event);
222
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
520 } catch (InterruptedException e) {}
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
521 selector.wakeup();
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
522 }
281
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
523
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
524 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
525 * Execute incoming event during the initialization for
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
526 * testing purpose.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
527 */
281
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
528 public void syncExec(SessionManagerEvent event) {
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
529 try {
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
530 waitingEventQueue.put(event);
281
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
531 } catch (InterruptedException e) {
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
532 }
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
533 }
222
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
534
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
535 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
536 * GUI command interface for close session.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
537 */
259
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
538 public void closeSession(SessionManagerEvent event) {
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
539 Session session = ((CloseButtonEvent) event).getSession();
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
540 session.closeSession();
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
541 sessionList.remove(session);
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
542 updateGUI();
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
543 }
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
544
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
545 /*
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
546 * Remove editors which has the cannel.
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
547 */
274
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
548 public void remove(REPSocketChannel<REPCommand> channel) {
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
549 int i = 0;
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
550 for(Session s:sessionList.values()) {
274
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
551 if (s.deleteEditor(channel)) {
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
552 i++;
274
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
553 }
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
554 }
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
555 assert(i==1);
274
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
556 // can be other session manager? what should I do?
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
557 }
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
558
317
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
559
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
560 public void addWriteQueue(PacketSet packetSet) {
324
e235998427a6 try to fix merger
kono
parents: 323
diff changeset
561 writeQueue.addLast(packetSet);
323
1e605880d49e *** empty log message ***
kono
parents: 322
diff changeset
562 assert(writeQueue.size()<packetLimit) ;
317
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
563 }
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
564
318
dc57e24ea3df *** empty log message ***
kono
parents: 317
diff changeset
565
dc57e24ea3df *** empty log message ***
kono
parents: 317
diff changeset
566 public void remove(Editor editor) {
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
567 Session s = sessionList.get(editor.getSID());
362
f0bd158dace6 *** empty log message ***
kono
parents: 361
diff changeset
568 if (s==null) {
f0bd158dace6 *** empty log message ***
kono
parents: 361
diff changeset
569 assert(false);
f0bd158dace6 *** empty log message ***
kono
parents: 361
diff changeset
570 editorList.remove(editor);
f0bd158dace6 *** empty log message ***
kono
parents: 361
diff changeset
571 } else if (editor.isMaster()) {
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
572 removeSession(s);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
573 } else {
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
574 s.deleteForwarder(editor);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
575 editorList.remove(editor);
318
dc57e24ea3df *** empty log message ***
kono
parents: 317
diff changeset
576 }
341
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
577 updateGUI();
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
578 }
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
579
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
580 private void removeSession(Session s0) {
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
581 s0.remove(this);
341
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
582 sessionList.remove(s0);
359
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
583 sendUpdate(s0.getSID());
318
dc57e24ea3df *** empty log message ***
kono
parents: 317
diff changeset
584 }
dc57e24ea3df *** empty log message ***
kono
parents: 317
diff changeset
585
334
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
586 public void setParentPort(int port) {
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
587 parent_port = port;
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
588 }
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
589 public int getParentPort() {
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
590 return parent_port;
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
591 }
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
592
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
593 public int getPort() {
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
594 return receive_port;
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
595 }
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
596
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
597
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
598 public boolean sessionManage(REPNode forwarder, REPCommand command) throws ClosedChannelException,
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
599 IOException {
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
600 switch(command.cmd){
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
601
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
602 // Session Manager Command
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
603
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
604 case SMCMD_JOIN:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
605 {
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
606 // first connection or forwarded command
367
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
607 routingTable.add(forwarder,getSMID(command.eid));
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
608 if(isMaster()) {
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
609 REPCommand ackCommand = new REPCommand();
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
610 ackCommand.setCMD(REP.SMCMD_JOIN_ACK);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
611 ackCommand.setEID(command.eid);
360
b25f832f875d *** empty log message ***
kono
parents: 359
diff changeset
612 ackCommand.setSID(command.sid);
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
613 ackCommand.string = command.string;
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
614 smList.sendToSlaves(ackCommand);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
615 registEditor(forwarder,ackCommand);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
616 } else {
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
617 smList.sendToMaster(command);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
618 }
360
b25f832f875d *** empty log message ***
kono
parents: 359
diff changeset
619 updateGUI();
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
620 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
621
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
622 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
623
361
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
624 case SMCMD_PUT_ACK:
366
e391433fa9f1 *** empty log message ***
kono
parents: 365
diff changeset
625 if (forwarder.isDirect()) {
e391433fa9f1 *** empty log message ***
kono
parents: 365
diff changeset
626 // send put_ack to the editor now.
e391433fa9f1 *** empty log message ***
kono
parents: 365
diff changeset
627 command.setCMD(REP.SMCMD_PUT_ACK);
e391433fa9f1 *** empty log message ***
kono
parents: 365
diff changeset
628 command.string = command.string;
e391433fa9f1 *** empty log message ***
kono
parents: 365
diff changeset
629 command.setEID(command.eid);
e391433fa9f1 *** empty log message ***
kono
parents: 365
diff changeset
630 command.setSID(command.sid);
e391433fa9f1 *** empty log message ***
kono
parents: 365
diff changeset
631 forwarder.send(command);
e391433fa9f1 *** empty log message ***
kono
parents: 365
diff changeset
632 }
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
633 case SMCMD_JOIN_ACK:
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
634 registEditor(forwarder,command);
360
b25f832f875d *** empty log message ***
kono
parents: 359
diff changeset
635 updateGUI();
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
636 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
637
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
638 case SMCMD_PUT:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
639 {
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
640 // first connection or forwarded command
367
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
641 routingTable.add(forwarder,getSMID(command.eid));
370
46c95d8885ad fix put_ack in single server test.
kono
parents: 369
diff changeset
642 REPCommand ack = new REPCommand(command); ack.setCMD(REP.SMCMD_PUT_ACK);
46c95d8885ad fix put_ack in single server test.
kono
parents: 369
diff changeset
643 if(isMaster()) {
371
97aa54c9afe6 *** empty log message ***
kono
parents: 370
diff changeset
644 // Reached to the top of the tree, multicast the ack.
370
46c95d8885ad fix put_ack in single server test.
kono
parents: 369
diff changeset
645 smList.sendToSlaves(ack);
46c95d8885ad fix put_ack in single server test.
kono
parents: 369
diff changeset
646 registEditor(forwarder,ack);
371
97aa54c9afe6 *** empty log message ***
kono
parents: 370
diff changeset
647 if (forwarder.isDirect()) {
97aa54c9afe6 *** empty log message ***
kono
parents: 370
diff changeset
648 // If put editor on the master, no SMCMD_PUT_ACK is
97aa54c9afe6 *** empty log message ***
kono
parents: 370
diff changeset
649 // generated. Send ack to the editor now.
97aa54c9afe6 *** empty log message ***
kono
parents: 370
diff changeset
650 forwarder.send(ack);
97aa54c9afe6 *** empty log message ***
kono
parents: 370
diff changeset
651 }
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
652 } else {
371
97aa54c9afe6 *** empty log message ***
kono
parents: 370
diff changeset
653 // Pass this to the master.
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
654 smList.sendToMaster(command);
361
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
655 // registEditor will be done by SMCMD_PUT_ACK
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
656 }
360
b25f832f875d *** empty log message ***
kono
parents: 359
diff changeset
657 updateGUI();
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
658
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
659 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
660 break;
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
661
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
662 case SMCMD_SELECT0:
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
663 /*
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
664 * finding joining editor, do not make the path.
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
665 */
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
666 REPNode editor = editorList.get(command.eid);
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
667 if (editor==null|| !editor.isDirect()) {
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
668 REPNode next = routingTable.toSessionManager(getSMID(command.eid));
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
669 next.send(command);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
670 break;
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
671 }
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
672 // we've found the editor, fall thru.
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
673 case SMCMD_SELECT:
361
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
674 {
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
675 /*
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
676 * finding active session ring from joined editor.
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
677 */
361
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
678 Session session = sessionList.get(command.sid);
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
679 if (session==null) {
365
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
680 session = new Session(command.sid, command.string,null);
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
681 sessionList.put(command.sid,session);
361
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
682 }
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
683 // Do not directly addForwarder(forwarder). It may be
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
684 // shared among sessions.
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
685 REPNode f = createSessionForwarder(command.sid, forwarder);
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
686 session.addForwarder(f); // f.next is set up here.
361
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
687 selectSession(command.sid, session, command.eid, forwarder);
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
688 }
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
689 break;
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
690 case SMCMD_SELECT_ACK:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
691 {
369
7d21eb209e27 *** empty log message ***
kono
parents: 367
diff changeset
692 // Sessionが見つかったので、select したeditorに教える。
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
693 Session session = sessionList.get(command.sid);
376
c4ffdac26132 *** empty log message ***
kono
parents: 372
diff changeset
694 searchSelectedEditor(command,session.getForwarder(forwarder.channel));
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
695 }
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
696 break;
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
697
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
698 case SMCMD_SM_JOIN:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
699 {
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
700 // SM_JOIN中にSMCMD_SM_JOINが来たら、これはループなので、
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
701 ///自分のSM_JOINを取り消す。
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
702 if (sm_join_channel!=null) cancel_sm_join();
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
703 // SMCMD_SM_JOIN は、master まで上昇する。
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
704 // masterでなければ、自分のparentに転送する。
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
705 if(isMaster()) {
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
706 // master であれば、SessionManager IDを決めて、
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
707 // 自分のsmList に登録
377
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
708 registSessionManager(forwarder, command);
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
709 } else {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
710 if (forwarder.sid==-1) {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
711 // direct link の場合は、識別のために、EIDに直上の
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
712 // smid を入れておく。
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
713 command.setEID(smList.sessionManagerID());
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
714 }
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
715 smList.sendToMaster(command);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
716 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
717 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
718 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
719
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
720 case SMCMD_SM_JOIN_ACK:
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
721 send_sm_join_ack(command.eid, command.sid, command);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
722 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
723
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
724 case SMCMD_UPDATE:
359
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
725 if (!isMaster()) {
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
726 command.setString(mergeUpdate(command));
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
727 // 上に知らせる
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
728 smList.sendToMaster(command);
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
729 break;
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
730 }
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
731 // fall thru
fa041bae35f1 all code written for distributed session except gather.
kono
parents: 358
diff changeset
732 command.setCMD(REP.SMCMD_UPDATE_ACK);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
733 case SMCMD_UPDATE_ACK:
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
734 command.setString(mergeUpdate(command));
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
735 // 下に知らせる
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
736 smList.sendToSlaves(command);
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
737 updateGUI();
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
738 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
739 default:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
740 return false;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
741 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
742 return true;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
743 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
744
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
745 private void registSessionManager(REPNode forwarder, REPCommand command) {
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
746 REPNode sm;
377
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
747 int psid = command.eid;
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
748 if (forwarder.sid!=-1) {
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
749 // すでに channelはSessionManager Idを持っていて、
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
750 // direct link ではないので、
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
751 // channel を持たないForwarderとして登録する
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
752 sm = new Forwarder(this);
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
753 } else {
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
754 sm = forwarder;
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
755 }
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
756 int sid = smList.addNewSessionManager(sm,command);
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
757 routingTable.add(forwarder,sid);
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
758
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
759 REPCommand sendCommand = makeREPCommandWithSessionList(REP.SMCMD_SM_JOIN_ACK);
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
760 // command.eid==smList.sesionManagerID() の場合は、
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
761 // 待っている自分の下のsessionManagerにsidをassignする必要がある。
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
762 sendCommand.setSID(sid); // new Session manager ID
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
763 // 複数のSM_JOIN_ACKを識別するには、最初にSM_JOINを受け付けた
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
764 // Session manager IDを使う。
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
765 sendCommand.setEID(psid);
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
766 send_sm_join_ack(psid, sid, sendCommand);
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
767 }
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
768
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
769
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
770 void send_sm_join_ack(int psid, int sid,REPCommand sendCommand) {
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
771 if (psid==smList.sessionManagerID()) {
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
772 // 直下のsessionManagerにIDを割り振る必要がある。
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
773 smList.assignSessionManagerIDtoWaitingSM(sid);
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
774 // ここで smList に一つだけ追加されるので
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
775 // 待っている最初のsm一つにだけ、sm_join_ackが新たに送られる。
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
776 }
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
777 smList.sendToSlaves(sendCommand);
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
778 }
85a5980d96d8 *** empty log message ***
kono
parents: 376
diff changeset
779
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
780 /*
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
781 * 指定されたeditorがlocalにあるかどうかを調べる。なければ、他に送る。戻って何回も探すことが
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
782 * あり得るので、よろしくない。
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
783 */
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
784 private void searchSelectedEditor(REPCommand command, REPNode editor) {
372
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
785 for(;editor.isDirect();editor = editor.getNextForwarder()) {
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
786 if (editor.getEID()==command.eid) {
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
787 // select したeditor を見つけた
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
788 command.cmd=REP.SMCMD_JOIN_ACK;
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
789 editor.send(command);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
790 return;
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
791 }
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
792 }
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
793 // ここにはありませんでした。
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
794 editor.send(command);
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
795 }
e16b6326fdac *** empty log message ***
kono
parents: 371
diff changeset
796
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
797
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
798 /**
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
799 * UPDATE/UPDATE_ACKにより送られてきたSessionの情報を追加する
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
800 * @param command
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
801 * @return
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
802 * @throws IOException
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
803 */
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
804 private String mergeUpdate(REPCommand command) throws IOException {
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
805 SessionList receivedSessionList;
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
806 try {
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
807 receivedSessionList = decoder.decode(command.string);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
808 } catch (SAXException e) {
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
809 throw new IOException();
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
810 }
363
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
811 // 受け取った情報と自分の情報を混ぜる。
1a8856580d38 *** empty log message ***
kono
parents: 362
diff changeset
812 sessionList.merge(receivedSessionList);
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
813 //XMLを生成。送信コマンドにセット。
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
814 return encoder.sessionListToXML(sessionList);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
815
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
816 }
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
817
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
818 /*
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
819 * id has SessionManager ID part
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
820 */
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
821 private int makeID(int newid) {
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
822 return newid+smList.sessionManagerID()*MAXID;
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
823 }
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
824
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
825 private int getSMID(int id) {
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
826 return id/MAXID;
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
827 }
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
828
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
829
361
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
830 /**
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
831 * Register Editor to our editorList. No connection is made.
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
832 * @param forwarder Editor to be add
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
833 * @param command
65c6d12a5835 *** empty log message ***
kono
parents: 360
diff changeset
834 */
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
835 public void registEditor(REPNode forwarder,REPCommand command) {
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
836 // make ack for PUT/JOIN. Do not send this to the editor,
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
837 // before select. After select, ack is sent to the editor.
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
838 REPNode editor;
367
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
839 if (getSMID(command.eid)==smList.sessionManagerID()) {
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
840 if (forwarder.isDirect()) {
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
841 editor = (Editor)forwarder;
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
842 } else
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
843 return;
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
844 } else {
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
845 editor = new Editor(this, command.cmd==REP.SMCMD_PUT_ACK, command.eid);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
846 }
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
847 editor.setName(command.string);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
848 editor.setSID(command.sid);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
849 if (!editorList.hasEid(command.eid)) {
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
850 editorList.add(editor);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
851 }
367
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
852 if (command.cmd==REP.SMCMD_PUT_ACK) {
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
853 Session session = new Session(command.sid, command.string, editor);
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
854 sessionList.put(command.sid, session);
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
855 }
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
856 // we don't join ack to the direct linked editor. We
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
857 // have to wait select command
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
858 }
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
859
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
860
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
861 private REPCommand makeREPCommandWithSessionList(REP cmd) {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
862 //SessionListからXMLを生成。
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
863 //joinしてきたSessionManagerに対してACKを送信。
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
864 REPCommand sendCommand = new REPCommand();
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
865 sendCommand.setCMD(cmd);
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
866 sendCommand.setString(encoder.sessionListToXML(sessionList));
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
867 return sendCommand;
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
868 }
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
869
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
870
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
871 public boolean isMaster() {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
872 return smList.isMaster();
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
873 }
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
874
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
875
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
876 public void setSessionManagerID(int sid) {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
877 smList.setSessionManagerID(sid);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
878 }
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
879
358
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
880
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
881 public Session getSession(int sid) {
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
882 return sessionList.get(sid);
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
883 }
034acadc0cdc *** empty log message ***
kono
parents: 356
diff changeset
884
365
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
885 public void execAfterConnect(SessionManagerEvent sessionManagerEvent) {
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
886 execAfterConnect = sessionManagerEvent;
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
887 }
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
888
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
889 public void afterConnect() {
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
890 if (execAfterConnect!=null) execAfterConnect.exec(this);
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
891 execAfterConnect = null;
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
892 }
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
893
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
894 public void setParent(REPNode fw) {
365
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
895 smList.setParent(fw);
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
896 }
367
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
897
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
898 public String toString() {
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
899 int myId = 0;
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
900 if (smList!=null) myId = smList.sessionManagerID();
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
901 return "rep.SessionManager-"+myId+"@"+myHost+":"+receive_port;
1bde894edd83 *** empty log message ***
kono
parents: 366
diff changeset
902 }
365
c432755c3555 distributed session debug continue... SELECT/SELECT_ACK loop
kono
parents: 364
diff changeset
903
382
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
904 public void addWaitingSessionManager(REPNode fw, REPCommand command) {
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
905 smList.addWaitingSessionManager(fw, command) ;
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
906 }
4b87f89b3afd REP Session Manager (Java version)
one@firefly.cr.ie.u-ryukyu.ac.jp
parents: 378
diff changeset
907
364
c965ef2b5fd6 *** empty log message ***
kono
parents: 363
diff changeset
908
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
909 }