annotate rep/SessionManager.java @ 355:98607350f7d1

*** empty log message ***
author kono
date Fri, 17 Oct 2008 22:11:34 +0900
parents 0d47ff22ee0e
children b18c24dcc5d2
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;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
21 import rep.handler.PacketSet;
146
20beee6ca31a *** empty log message ***
pin
parents: 144
diff changeset
22 import rep.handler.REPHandler;
158
5cc8cd48bded *** empty log message ***
pin
parents: 155
diff changeset
23 import rep.channel.REPSelector;
56
6ead43b2475e *** empty log message ***
pin
parents: 53
diff changeset
24 import rep.xml.SessionXMLDecoder;
45
10f1adf6d74d *** empty log message ***
pin
parents: 39
diff changeset
25 import rep.xml.SessionXMLEncoder;
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
26 import rep.channel.REPSelectionKey;
264
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
27
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
28 /*
264
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
29 +-------+--------+--------+-------+--------+---------+------+
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
30 | cmd | session| editor | seqid | lineno | textsiz | text |
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
31 | | id | id | | | | |
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
32 +-------+--------+--------+-------+--------+---------+------+
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
33 o---------- header section (network order) ----------o
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
34
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
35 int cmd; kind of command
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
36 int sid; session ID : uniqu to editing file
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
37 int eid; editor ID : owner editor ID = 1。Session に対して unique
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
38 -1 session manager command
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
39 -2 merge command
264
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
40 int seqno; Sequence number : sequence number はエディタごとに管理
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
41 int lineno; line number
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
42 int textsize; textsize : bytesize
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
43 byte[] text;
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
44 */
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
45
250
5f357ca66714 *** empty log message ***
pin
parents: 246
diff changeset
46 public class SessionManager implements SessionManagerEventListener{
337
5ba5b7a9761b use REPLogger
kono
parents: 336
diff changeset
47 static public REPLogger logger = REPLogger.singleton();
5ba5b7a9761b use REPLogger
kono
parents: 336
diff changeset
48
319
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
49 LinkedList<Session> sessionList;
280
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
50 private SessionManagerGUI gui;
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
51 private REPSelector<REPCommand> selector;
319
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
52 SessionManagerList smList;
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
53 List<Editor> editorList;
304
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
54 // editorList は、sessionList に入っているeditorとは別なeditorのlistらしい。
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
55 // private String maxHost;
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
56 private List<PacketSet> waitingCommandInMerge;
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
57 private BlockingQueue<SessionManagerEvent> waitingEventQueue = new LinkedBlockingQueue<SessionManagerEvent>();;
319
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
58 String myHost;
317
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
59 private LinkedList<PacketSet> writeQueue = new LinkedList<PacketSet>();
336
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
60 private int receive_port;
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
61 private int parent_port;
101
612cb62151ce *** empty log message ***
pin
parents: 100
diff changeset
62 static final int DEFAULT_PORT = 8766;
332
36faf76a087c *** empty log message ***
kono
parents: 330
diff changeset
63 private static final int packetLimit = 200;
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
64 SessionXMLDecoder decoder = new SessionXMLDecoder();
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
65 private Forwarder sm_join_channel;
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
66
316
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
67 public static void main(String[] args) throws InterruptedException, IOException {
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
68
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
69 int port = DEFAULT_PORT;
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
70 int port_s = DEFAULT_PORT;
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
71 //System.setProperty("file.encoding", "UTF-8");
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
72 if(args.length > 0){
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
73 port = Integer.parseInt(args[0]);
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
74 port_s = Integer.parseInt(args[1]);
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
75 }
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
76 SessionManager sm = new SessionManager();
336
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
77 sm.setReceivePort(port);
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
78 sm.setParentPort(port_s);
316
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
79 sm.init(port,new SessionManagerGUIimpl(sm));
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
80
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
81
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
82 }
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
83
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
84
336
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
85 public void setReceivePort(int port) {
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
86 receive_port = port;
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
87 }
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
88
d00cb51ba652 *** empty log message ***
kono
parents: 334
diff changeset
89
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
90 public void openSelector() throws IOException{
231
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
91 selector = REPSelector.<REPCommand>create();
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
92 }
280
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
93
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
94 public void init(int port, SessionManagerGUI gui) throws IOException, InterruptedException {
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
95 this.gui = gui;
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
96 openSelector();
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
97 init(port);
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
98 mainLoop();
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
99 }
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
100
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
101
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
102 private void init(int port) throws InterruptedException, IOException {
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
103
186
d22384c0026c *** empty log message ***
kent
parents: 185
diff changeset
104 REPServerSocketChannel<REPCommand> ssc = REPServerSocketChannel.<REPCommand>open(new REPCommandPacker());
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
105 ssc.configureBlocking(false); //reuse address 必須
101
612cb62151ce *** empty log message ***
pin
parents: 100
diff changeset
106 ssc.socket().setReuseAddress(true);
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
107 //getAllByNameで取れた全てのアドレスに対してbindする
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
108 ssc.socket().bind(new InetSocketAddress(port));
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
109 ssc.register(selector, SelectionKey.OP_ACCEPT,
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
110 new Forwarder(this));
6
bdb91f4cea26 It Can connect SessionManagers each other.
pin
parents: 5
diff changeset
111
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
112 sessionList = new LinkedList<Session>();
7
5067a6a93d01 *** empty log message ***
pin
parents: 6
diff changeset
113 smList = new SessionManagerList();
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
114 editorList = new LinkedList<Editor>();
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
115 waitingCommandInMerge = new LinkedList<PacketSet>();
228
e6c7a56ff7f1 *** empty log message ***
pin
parents: 227
diff changeset
116
215
7649238aaf66 *** empty log message ***
pin
parents: 213
diff changeset
117
155
bbd2801d8ce0 *** empty log message ***
pin
parents: 152
diff changeset
118 }
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
119
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
120 /*
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
121 * We wrote everything in one thread, but we can assign
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
122 * one thread for each communication channel and GUI event.
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
123 */
155
bbd2801d8ce0 *** empty log message ***
pin
parents: 152
diff changeset
124
231
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
125 public void mainLoop() throws IOException {
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
126 while(true){
328
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
127 checkWaitingCommandInMerge();
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
128 if (checkInputEvent() ||
328
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
129 checkWaitingWrite()) {
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
130 // try to do fair execution for waiting task
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
131 if(selector.selectNow() > 0) select();
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
132 continue;
300
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
133 }
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
134 // now we can wait for input packet or event
233
dae90ded1bcd *** empty log message ***
pin
parents: 231
diff changeset
135 selector.select();
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
136 select();
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
137 }
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
138 }
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
139
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
140 private boolean checkInputEvent() {
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
141 SessionManagerEvent e;
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
142 if((e = waitingEventQueue.poll())!=null){
334
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
143 e.exec(this);
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
144 return true;
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
145 }
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
146 return false;
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
147 }
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
148
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
149 private boolean checkWaitingWrite() throws IOException {
317
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
150 PacketSet p = writeQueue.poll();
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
151 if (p!=null) {
327
7b6dede07f4a *** empty log message ***
kono
parents: 324
diff changeset
152 p.channel.write(p.command);
317
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
153 return true;
313
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
154 }
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
155 return false;
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
156 }
0585fd2410b8 Single Insert Command worked.
kono
parents: 308
diff changeset
157
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
158 /**
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
159 * Check waiting command in merge
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
160 * @return true if there is a processed waiting command
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
161 * @throws IOException
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
162 */
346
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
163 private void checkWaitingCommandInMerge() {
328
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
164 List<PacketSet> w = waitingCommandInMerge;
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
165 waitingCommandInMerge = new LinkedList<PacketSet>();
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
166 for(PacketSet p: w) {
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
167 Editor e = p.getEditor();
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
168 if(e.isMerging()) { // still merging do nothing
328
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
169 waitingCommandInMerge.add(p);
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
170 } else {
346
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
171 try {
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
172 if (sessionManage(e, p.command)) { // we don't need this
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
173 assert false;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
174 return;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
175 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
176 e.manage(p.command);
347
86935b872385 *** empty log message ***
kono
parents: 346
diff changeset
177 } catch (Exception e1) {
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
178 // should be e.close()?
346
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
179 close(p.channel);
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
180 }
328
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
181 }
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
182 }
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
183 }
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
184
346
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
185 private void close(REPSocketChannel<REPCommand> channel) {
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
186 REPSelectionKey<REPCommand>key = channel.keyFor1(selector);
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
187 REPHandler handler = (REPHandler)key.attachment();
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
188 key.cancel();
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
189 handler.cancel(channel);
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
190 // we have to remove session/enditor
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
191 }
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
192
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
193
328
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
194 public boolean hasWaitingCommand(REPSocketChannel<REPCommand>c) {
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
195 for(PacketSet p:waitingCommandInMerge) {
6ceb222570cb merge is working now.
kono
parents: 327
diff changeset
196 if (p.channel==c) {
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
197 return true;
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
198 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
199 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
200 return false;
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
201 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
202
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
203 private void select() throws IOException {
231
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
204
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
205 Set<REPSelectionKey<REPCommand>> keys = selector.selectedKeys1();
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
206 for(REPSelectionKey<REPCommand> key : keys){
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
207 if(key.isAcceptable()){
199
456ba58cd042 *** empty log message ***
pin
parents: 198
diff changeset
208 REPSocketChannel<REPCommand> channel = key.accept(new REPCommandPacker());
337
5ba5b7a9761b use REPLogger
kono
parents: 336
diff changeset
209 logger.writeLog("SessionManager.select() : key.isAcceptable : channel = " + channel);
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
210 registerChannel (channel, new FirstConnector(this));
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
211 channel = null;
123
5b1a0574b406 *** empty log message ***
pin
parents: 122
diff changeset
212
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
213 }else if(key.isReadable()){
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
214 REPHandler handler = (REPHandler)(key.attachment());
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
215 try {
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
216 handler.handle(key);
346
edf0e0a5ffc8 *** empty log message ***
kono
parents: 343
diff changeset
217 } catch (Exception x) {
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
218 key.cancel();
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
219 handler.cancel(key.channel1());
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
220 }
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
221 }
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
222 }
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
223 }
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
224
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
225 void registerChannel(REPSocketChannel<REPCommand> channel,Forwarder handler) throws IOException {
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
226 if(channel == null) {
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
227 return;
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
228 }
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
229 handler.setChannel(channel);
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
230 channel.configureBlocking(false);
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
231 channel.register(selector, SelectionKey.OP_READ, handler);
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
232 }
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
233
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
234
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
235 void cancel_sm_join() {
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
236 removeChannel(sm_join_channel);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
237 sm_join_channel=null;
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
238 }
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
239
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
240
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
241 private void removeChannel(Forwarder sm_join_channel) {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
242 REPSelectionKey<REPCommand> key = sm_join_channel.channel.keyFor1(selector);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
243 key.cancel();
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
244 try {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
245 sm_join_channel.channel.close();
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
246 } catch (IOException e) {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
247 }
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
248 }
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
249
320
83790b8b8174 *** empty log message ***
kono
parents: 319
diff changeset
250
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
251 boolean hasSession(int sid) {
319
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
252 for(Session s:sessionList) {
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
253 if (s.getSID()==sid) return true;
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
254 }
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
255 return false;
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
256 }
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
257
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
258
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
259 void updateGUI() {
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
260 //リストのコピーをGUIに渡す
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
261 LinkedList<Session> sList = new LinkedList<Session>(sessionList);
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
262 LinkedList<Editor> eList = new LinkedList<Editor>(editorList);
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
263 //GUIに反映
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
264 Runnable doRun = new DoGUIUpdate(sList, eList, gui);
279
e58695b5118d *** empty log message ***
kono
parents: 274
diff changeset
265 gui.invokeLater(doRun);
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
266 }
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
267
319
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
268 Forwarder getEditor(String hostport) {
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
269 for(Editor editor : editorList){
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
270 if(editor.getHost() == hostport){
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
271 return editor;
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
272 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
273 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
274 return null;
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
275 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
276
316
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
277 public Session getSession(int sid) throws IOException {
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
278 for(Session session : sessionList){
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
279 if(session.getSID() == sid) return session;
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
280 }
316
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
281 throw new IOException();
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
282 }
83
9381b4734a0b *** empty log message ***
pin
parents: 82
diff changeset
283
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
284 // private boolean setMaxHost(REPSocketChannel<REPCommand> channel, String maxHost2) {
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
285 // if(maxHost.compareTo(maxHost2) > 0){
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
286 // return false;
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
287 // }else{
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
288 // maxHost = maxHost2;
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
289 // return true;
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
290 // }
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
291 // }
139
d6b94713cf45 *** empty log message ***
pin
parents: 133
diff changeset
292
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
293 void setMyHostName(String localHostName) {
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
294 myHost = localHostName + receive_port;
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
295 // if(maxHost == null) {
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
296 // maxHost = myHost;
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
297 // }
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
298 setHostToEditor(myHost);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
299 }
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
300
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
301 private void setHostToEditor(String myHost2) {
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
302 for(Editor editor : editorList){
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
303 editor.setHost(myHost2);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
304 }
76
97ca5f5447cd *** empty log message ***
pin
parents: 75
diff changeset
305 }
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
306
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
307
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
308 /**
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
309 * Host 名のSession Manager に SM_JOIN する。自分は、Session を持っていては
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
310 * ならない。複数のSession Managerにjoinすることは出来ない。(NATを実装するまでは)。
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
311 * @param host
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
312 */
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
313 public void connectSession(String host) {
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
314 if (sm_join_channel!=null) return;
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
315 if (!sessionList.isEmpty()) return;
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
316 if (!smList.isMaster()) return;
334
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
317 int port = parent_port;
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
318 InetSocketAddress addr = new InetSocketAddress(host, port);
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
319 try {
186
d22384c0026c *** empty log message ***
kent
parents: 185
diff changeset
320 REPSocketChannel<REPCommand> sessionchannel = REPSocketChannel.<REPCommand>create(new REPCommandPacker());
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
321
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
322 sessionchannel.connect(addr);
337
5ba5b7a9761b use REPLogger
kono
parents: 336
diff changeset
323 while(!sessionchannel.finishConnect());
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
324 Forwarder sm = new Forwarder(this);
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
325 registerChannel(sessionchannel, sm);
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
326 sm_join(sm);
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
327 }catch (IOException e) {
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
328 }
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
329 }
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
330
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
331 private void sm_join(Forwarder channel){
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
332 sm_join_channel = channel;
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
333 //SM_JOINコマンドを生成。
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
334 REPCommand command = new REPCommand();
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
335 command.setCMD(REP.SMCMD_SM_JOIN);
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
336 command.setEID(-1); // request Parent SessionManagerID
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
337 command.setSID(-1); // request SessionManagerID
79
d1877cfd131d *** empty log message ***
pin
parents: 78
diff changeset
338
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
339 //hostnameをセット。
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
340 setMyHostName(channel.getLocalHostName());
82
4bb583553a42 *** empty log message ***
pin
parents: 81
diff changeset
341
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
342 //XMLを生成。送信コマンドにセット。
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
343 //SessionXMLEncoder encoder = new SessionXMLEncoder(sessionList);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
344 //String string = encoder.sessionListToXML();
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
345 String string = myHost;
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
346 command.setString(string);
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
347
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
348 //SM_JOINコマンドを送信。
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
349 channel.send(command);
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
350 //SessionManagerのListに追加。
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
351
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
352 }
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
353
316
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
354 public void selectSession(SelectButtonEvent event) throws IOException {
250
5f357ca66714 *** empty log message ***
pin
parents: 246
diff changeset
355 int sid = event.getSID();
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
356 Session session = getSession(sid);
227
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
357
320
83790b8b8174 *** empty log message ***
kono
parents: 319
diff changeset
358 Editor editor = (Editor)event.getEditor();
227
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
359 if(editor == null){
337
5ba5b7a9761b use REPLogger
kono
parents: 336
diff changeset
360 logger.writeLog("SessionManager.selectSession():editor = " + editor);
227
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
361 return;
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
362 }
324
e235998427a6 try to fix merger
kono
parents: 323
diff changeset
363 if (editor.hasSession()) return;
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
364 //REPSocketChannel<REPCommand> channel = editor.getChannel();
319
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
365
324
e235998427a6 try to fix merger
kono
parents: 323
diff changeset
366 // System.out.println("SessionManager.session.hasOnwer="+session.hasOwner());
158
5cc8cd48bded *** empty log message ***
pin
parents: 155
diff changeset
367 if(session.hasOwner()){
320
83790b8b8174 *** empty log message ***
kono
parents: 319
diff changeset
368 editor.setEID(session.newEid());
322
5893fd8c0f50 *** empty log message ***
kono
parents: 320
diff changeset
369 editor.setSID(sid);
319
dfed28488274 *** empty log message ***
kono
parents: 318
diff changeset
370 session.addForwarder(editor);
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
371 REPCommand sendCommand = new REPCommand();
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
372 sendCommand.setCMD(REP.SMCMD_JOIN_ACK);
148
6a5fe529b192 *** empty log message ***
pin
parents: 146
diff changeset
373 sendCommand.setEID(editor.getEID());
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
374 sendCommand.setSID(sid);
286
30c993e89286 TestEditor
kono
parents: 281
diff changeset
375 sendCommand.string = "";
349
ef4afcae0c92 now Forwarder associates each client channel.
kono
parents: 347
diff changeset
376 editor.send(sendCommand);
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
377 }else {
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
378 editor.setHost(myHost);
322
5893fd8c0f50 *** empty log message ***
kono
parents: 320
diff changeset
379 editor.setSID(sid);
320
83790b8b8174 *** empty log message ***
kono
parents: 319
diff changeset
380 session.addEditor(editor);
316
77f443f6dc9f add session manager channel handler
kono
parents: 315
diff changeset
381 Forwarder owner = session.getOwner();
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
382
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
383 REPCommand command = new REPCommand();
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
384 command.setCMD(REP.SMCMD_SELECT);
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
385 command.setSID(sid);
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
386 command.setString(editor.getHost());
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
387 owner.send(command);
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
388 }
8
b774b87cc2c1 *** empty log message ***
pin
parents: 7
diff changeset
389 }
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
390
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
391 public void addWaitingCommand(PacketSet set) {
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
392 waitingCommandInMerge.add(set);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
393 }
148
6a5fe529b192 *** empty log message ***
pin
parents: 146
diff changeset
394
222
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
395 public void buttonPressed(SessionManagerEvent event) {
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
396 try {
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
397 waitingEventQueue.put(event);
222
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
398 } catch (InterruptedException e) {}
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
399 selector.wakeup();
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
400 }
281
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
401
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
402 public void syncExec(SessionManagerEvent event) {
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
403 try {
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
404 waitingEventQueue.put(event);
281
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
405 } catch (InterruptedException e) {
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
406 }
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
407 }
222
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
408
259
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
409 public void closeSession(SessionManagerEvent event) {
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
410 Session session = ((CloseButtonEvent) event).getSession();
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
411 session.closeSession();
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
412 sessionList.remove(session);
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
413 updateGUI();
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
414 }
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
415
274
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
416 public void remove(REPSocketChannel<REPCommand> channel) {
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
417 for(Session s:sessionList) {
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
418 if (s.deleteEditor(channel)) {
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
419 return ;
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
420 }
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
421 }
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
422 assert(false);
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
423 // can be other session manager? what should I do?
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
424 }
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
425
317
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
426
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
427 public void addWriteQueue(PacketSet packetSet) {
324
e235998427a6 try to fix merger
kono
parents: 323
diff changeset
428 writeQueue.addLast(packetSet);
323
1e605880d49e *** empty log message ***
kono
parents: 322
diff changeset
429 assert(writeQueue.size()<packetLimit) ;
317
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
430 }
c83a3faec487 *** empty log message ***
kono
parents: 316
diff changeset
431
318
dc57e24ea3df *** empty log message ***
kono
parents: 317
diff changeset
432
dc57e24ea3df *** empty log message ***
kono
parents: 317
diff changeset
433 public void remove(Editor editor) {
341
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
434 Session s0 = null;
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
435 editorList.remove(editor);
318
dc57e24ea3df *** empty log message ***
kono
parents: 317
diff changeset
436 for(Session s:sessionList) {
341
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
437 if (s.deleteForwarder(editor)) {
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
438 if (editor.getEID()==0) s0=s;
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
439 }
318
dc57e24ea3df *** empty log message ***
kono
parents: 317
diff changeset
440 }
341
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
441 if (s0!=null) removeSession(s0);
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
442 updateGUI();
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
443 }
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
444
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
445 private void removeSession(Session s0) {
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
446 sessionList.remove(s0);
a9a740e685fa remove session using QUIT_2_ACK
kono
parents: 337
diff changeset
447 // send UPDATE to all the session manager
318
dc57e24ea3df *** empty log message ***
kono
parents: 317
diff changeset
448 }
dc57e24ea3df *** empty log message ***
kono
parents: 317
diff changeset
449
334
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
450 public void setParentPort(int port) {
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
451 parent_port = port;
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
452 }
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
453 public int getParentPort() {
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
454 return parent_port;
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
455 }
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
456
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
457 public int getPort() {
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
458 return receive_port;
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
459 }
4fae49280699 Test pattern for Inter-Session Manager communication
kono
parents: 332
diff changeset
460
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
461
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
462 boolean sessionManage(Forwarder forwarder, REPCommand command) throws ClosedChannelException,
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
463 IOException, SAXException {
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
464 switch(command.cmd){
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
465
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
466 // Session Manager Command
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
467
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
468 case SMCMD_JOIN:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
469 {
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
470 updateGUI();
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
471 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
472
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
473 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
474
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
475 case SMCMD_JOIN_ACK:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
476 assert (false);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
477 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
478
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
479 case SMCMD_PUT:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
480 {
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
481 //Sessionを生成
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
482 // sessionIDってglobaly uniqueだから、本来は、
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
483 // 自分の親に作ってもらう必要がある。自分が親なら自分で作って良い。
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
484
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
485 int sid = sessionList.size();
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
486 Editor editor = (Editor) forwarder;
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
487 Session session = new Session(sid, command.string, (Editor)forwarder);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
488 session.hasOwner(true);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
489 sessionList.add(session);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
490
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
491 updateGUI();
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
492
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
493 //エディタにAckを送信
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
494 REPCommand sendCommand = new REPCommand(command);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
495 sendCommand.setCMD(REP.SMCMD_PUT_ACK);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
496 sendCommand.setEID(editor.getEID());
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
497 sendCommand.setSID(session.getSID());
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
498 editor.send(sendCommand);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
499
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
500 //他のSessionManagerへSessionの追加を報告
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
501 //親に送って、親から子へ
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
502 SessionXMLEncoder sessionEncoder = new SessionXMLEncoder(session);
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
503 REPCommand command1 = new REPCommand();
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
504 command1.setSID(session.getSID());
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
505 command1.setString(sessionEncoder.sessionListToXML());
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
506 command1.setCMD(REP.SMCMD_UPDATE);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
507 smList.sendToSlaves( command);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
508
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
509 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
510
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
511 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
512
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
513 // SELECT is no longer used in a editor. Select
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
514 // operation is handled in Session Manager Only
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
515 case SMCMD_SELECT:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
516 {
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
517 //他のSessionManagerをエディタとしてSessionに追加
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
518 Forwarder next = new Forwarder(this);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
519 next.setChannel(forwarder.channel);
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
520 Session session = getSession(command.sid);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
521 session.addForwarder(next);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
522
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
523 if(session.hasOwner()){
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
524 //このSessionManagerがオーナーを持っている場合、Sessionにエディタを追加し、エディタへAckを返す
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
525 REPCommand sendCommand = new REPCommand(command);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
526 sendCommand.setCMD(REP.SMCMD_SELECT_ACK);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
527 sendCommand.setEID(next.getEID());
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
528 next.send(sendCommand);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
529 }else{
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
530 //オーナーを持ってない場合は、オーナーを持っているSessionManagerへSELECTコマンドを中継する
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
531 Forwarder owner = session.getOwner();
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
532 owner.send(command);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
533 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
534 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
535
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
536 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
537
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
538 case SMCMD_SELECT_ACK:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
539 {
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
540 String hostport = command.string;
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
541 Forwarder editor1 = getEditor(hostport);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
542
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
543 if(editor1 != null) {
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
544 //host, port を見て、このコマンドが自分が送信したSelectコマンドのAckかどうかを判断する
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
545 REPCommand command1 = new REPCommand();
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
546 command1.setCMD(REP.SMCMD_JOIN_ACK);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
547 command1.setSID(command.sid);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
548 command1.setEID(command.eid);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
549 editor1.send(command);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
550
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
551 }else{
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
552 //自分が送信したコマンドでなければ、次のSessionManagerへ中継する
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
553 smList.sendToSlaves(command);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
554 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
555 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
556
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
557 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
558 case SMCMD_SM_JOIN:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
559
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
560 {
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
561 // SM_JOIN中にSMCMD_SM_JOINが来たら、これはループなので、
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
562 ///自分のSM_JOINを取り消す。
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
563 if (sm_join_channel!=null) cancel_sm_join();
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
564 // SMCMD_SM_JOIN は、master まで上昇する。
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
565 // masterでなければ、自分のparentに転送する。
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
566 if(isMaster()) {
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
567 // master であれば、SessionManager IDを決めて、
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
568 // 自分のsmList に登録
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
569 Forwarder sm;
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
570 int psid = command.eid;
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
571 if (forwarder.sid!=-1) {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
572 // すでに channelはSessionManager Idを持っていて、
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
573 // direct link ではないので、
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
574 // channel を持たないForwarderとして登録する
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
575 sm = new Forwarder(this);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
576 } else {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
577 sm = forwarder;
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
578 }
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
579 int sid = smList.addNewSessionManager(sm,command);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
580 REPCommand sendCommand = makeREPCommandWithSessionList(REP.SMCMD_SM_JOIN_ACK);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
581 // command.eid==smList.sesionManagerID() の場合は、
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
582 // 待っている自分の下のsessionManagerにsidをassignする必要がある。
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
583 sendCommand.setSID(sid); // new Session manager ID
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
584 // 複数のSM_JOIN_ACKを識別するには、最初にSM_JOINを受け付けた
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
585 // Session manager IDを使う。
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
586 sendCommand.setEID(psid);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
587 send_sm_join_ack(psid, sid, sendCommand);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
588 } else {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
589 if (forwarder.sid==-1) {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
590 // direct link の場合は、識別のために、EIDに直上の
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
591 // smid を入れておく。
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
592 command.setEID(smList.sessionManagerID());
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
593 }
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
594 smList.sendToMaster(command);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
595 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
596 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
597 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
598
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
599 case SMCMD_SM_JOIN_ACK:
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
600 send_sm_join_ack(command.eid, command.sid, command);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
601 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
602
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
603 case SMCMD_UPDATE:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
604 {
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
605 SessionList receivedSessionList3 = decoder.decode(command.string);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
606
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
607 //UPDATEコマンドにより送られてきたSessionの情報を追加する
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
608 LinkedList<Session> list = receivedSessionList3.getList();
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
609 for(Session session : list){
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
610 session.getEditorList().get(0).setChannel(forwarder.channel);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
611 sessionList.add(session);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
612 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
613
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
614 //他のSessionManagerへ中継する
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
615 smList.sendToSlaves(command);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
616
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
617 updateGUI();
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
618 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
619 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
620
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
621 case SMCMD_UPDATE_ACK:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
622 {
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
623 if(!hasSession(command.sid)) {
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
624 // accept new Session
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
625 // ここで初めてsession id が決まる。
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
626 // このコマンドは、master session manager が出すはず
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
627 Forwarder sm = new Forwarder(this);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
628 sm.setChannel(forwarder.channel);
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
629 Session session = new Session(command.sid,command.string,null);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
630 session.addForwarder(sm);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
631
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
632 sessionList.add(session);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
633
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
634 updateGUI();
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
635 }
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
636 smList.sendToSlaves(command);
353
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
637 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
638 break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
639
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
640 // case SMCMD_CH_MASTER:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
641 // {
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
642 // //maxHost を設定。
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
643 // if(setMaxHost(channel, receivedCommand.string)){
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
644 // REPCommand sendCommand = new REPCommand();
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
645 // sendCommand.setCMD(REP.SMCMD_CH_MASTER);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
646 // sendCommand.setString(maxHost);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
647 // smList.sendExcept(channel, sendCommand);
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
648 // }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
649 // }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
650 // break;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
651
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
652
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
653 default:
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
654 return false;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
655 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
656 return true;
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
657 }
0d47ff22ee0e *** empty log message ***
kono
parents: 352
diff changeset
658
355
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
659
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
660 void send_sm_join_ack(int psid, int sid,REPCommand sendCommand) {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
661 if (psid==smList.sessionManagerID()) {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
662 // 直下のsessionManagerにIDを割り振る必要がある。
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
663 smList.assignSessionManagerIDtoWaitingSM(sid);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
664 // ここで smList に一つだけ追加されるので
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
665 // 待っている最初のsm一つにだけ、sm_joinが新たに送られる。
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
666 }
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
667 smList.sendToSlaves(sendCommand);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
668 }
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
669
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
670
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
671 private REPCommand makeREPCommandWithSessionList(REP cmd) {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
672 //SessionListからXMLを生成。
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
673 //joinしてきたSessionManagerに対してACKを送信。
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
674 SessionXMLEncoder sessionlistEncoder = new SessionXMLEncoder(sessionList);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
675 REPCommand sendCommand = new REPCommand();
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
676 sendCommand.setCMD(cmd);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
677 sendCommand.setString(sessionlistEncoder.sessionListToXML());
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
678 return sendCommand;
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
679 }
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
680
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
681
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
682 public boolean isMaster() {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
683 return smList.isMaster();
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
684 }
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
685
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
686
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
687 public void setSessionManagerID(int sid) {
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
688 smList.setSessionManagerID(sid);
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
689 }
98607350f7d1 *** empty log message ***
kono
parents: 353
diff changeset
690
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
691 }