annotate rep/SessionManager.java @ 308:c5be84d53c7f channel-simulator-update **INVALID**

*** empty log message ***
author kono
date Sat, 04 Oct 2008 22:12:34 +0900
parents 75192c844a8d
children 0585fd2410b8
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;
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
8 import java.util.Iterator;
83
9381b4734a0b *** empty log message ***
pin
parents: 82
diff changeset
9 import java.util.LinkedList;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
10 import java.util.List;
231
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
11 import java.util.Set;
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
12 import java.util.concurrent.BlockingQueue;
192
6fb97c7a0b42 *** empty log message ***
pin
parents: 191
diff changeset
13 import java.util.concurrent.LinkedBlockingQueue;
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
14
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
15
123
5b1a0574b406 *** empty log message ***
pin
parents: 122
diff changeset
16 import rep.channel.REPServerSocketChannel;
133
8dce4348966c *** empty log message ***
kono
parents: 124
diff changeset
17 import rep.channel.REPSocketChannel;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
18 import rep.handler.PacketSet;
146
20beee6ca31a *** empty log message ***
pin
parents: 144
diff changeset
19 import rep.handler.REPHandler;
148
6a5fe529b192 *** empty log message ***
pin
parents: 146
diff changeset
20 import rep.handler.REPHandlerImpl;
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
21 import rep.handler.REPHandlerInMerge;
158
5cc8cd48bded *** empty log message ***
pin
parents: 155
diff changeset
22 import rep.channel.REPSelector;
56
6ead43b2475e *** empty log message ***
pin
parents: 53
diff changeset
23 import rep.xml.SessionXMLDecoder;
45
10f1adf6d74d *** empty log message ***
pin
parents: 39
diff changeset
24 import rep.xml.SessionXMLEncoder;
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
25 import rep.channel.REPSelectionKey;
264
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
26
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
27 /*
264
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
28 +-------+--------+--------+-------+--------+---------+------+
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
29 | cmd | session| editor | seqid | lineno | textsiz | text |
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
30 | | id | id | | | | |
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
31 +-------+--------+--------+-------+--------+---------+------+
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
32 o---------- header section (network order) ----------o
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
33
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
34 int cmd; kind of command
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
35 int sid; session ID : uniqu to editing file
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
36 int eid; editor ID : owner editor ID = 1。Session に対して unique
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
37 -1 session manager command
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
38 -2 merge command
264
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
39 int seqno; Sequence number : sequence number はエディタごとに管理
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
40 int lineno; line number
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
41 int textsize; textsize : bytesize
8c02ec16b874 *** empty log message ***
pin
parents: 259
diff changeset
42 byte[] text;
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
43 */
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
44
250
5f357ca66714 *** empty log message ***
pin
parents: 246
diff changeset
45 public class SessionManager implements SessionManagerEventListener{
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
46
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
47 private LinkedList<Session> sessionList;
280
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
48 private SessionManagerGUI gui;
198
ff3fcdcccc85 *** empty log message ***
pin
parents: 192
diff changeset
49 private REPSelector<REPCommand> selector;
7
5067a6a93d01 *** empty log message ***
pin
parents: 6
diff changeset
50 private SessionManagerList smList;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
51 private List<Editor> editorList;
304
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
52 // editorList は、sessionList に入っているeditorとは別なeditorのlistらしい。
78
8a4f92f31c58 *** empty log message ***
pin
parents: 77
diff changeset
53 private String maxHost;
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
54 private List<PacketSet> waitingCommandInMerge;
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
55 REPHandler normalHandler = new REPHandlerImpl(this);
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
56 REPHandler handlerInMerge =new REPHandlerInMerge(this);
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
57 private BlockingQueue<SessionManagerEvent> waitingEventQueue = new LinkedBlockingQueue<SessionManagerEvent>();;
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
58 private String myHost;
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
59 private static int receive_port;
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
60 private static int parent_port;
101
612cb62151ce *** empty log message ***
pin
parents: 100
diff changeset
61 static final int DEFAULT_PORT = 8766;
612cb62151ce *** empty log message ***
pin
parents: 100
diff changeset
62
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
63
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
64 public void openSelector() throws IOException{
231
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
65 selector = REPSelector.<REPCommand>create();
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
66 }
280
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
67
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
68 public void init(int port, SessionManagerGUI gui) throws IOException, InterruptedException {
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
69 this.gui = gui;
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
70 openSelector();
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
71 init(port);
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
72 mainLoop();
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
73 }
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
74
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
75
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
76 private void init(int port) throws InterruptedException, IOException {
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
77
186
d22384c0026c *** empty log message ***
kent
parents: 185
diff changeset
78 REPServerSocketChannel<REPCommand> ssc = REPServerSocketChannel.<REPCommand>open(new REPCommandPacker());
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
79 ssc.configureBlocking(false); //reuse address 必須
101
612cb62151ce *** empty log message ***
pin
parents: 100
diff changeset
80 ssc.socket().setReuseAddress(true);
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
81 //getAllByNameで取れた全てのアドレスに対してbindする
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
82 ssc.socket().bind(new InetSocketAddress(port));
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
83 ssc.register(selector, SelectionKey.OP_ACCEPT, normalHandler);
6
bdb91f4cea26 It Can connect SessionManagers each other.
pin
parents: 5
diff changeset
84
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
85 sessionList = new LinkedList<Session>();
7
5067a6a93d01 *** empty log message ***
pin
parents: 6
diff changeset
86 smList = new SessionManagerList();
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
87 editorList = new LinkedList<Editor>();
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
88 waitingCommandInMerge = new LinkedList<PacketSet>();
228
e6c7a56ff7f1 *** empty log message ***
pin
parents: 227
diff changeset
89
215
7649238aaf66 *** empty log message ***
pin
parents: 213
diff changeset
90
155
bbd2801d8ce0 *** empty log message ***
pin
parents: 152
diff changeset
91 }
bbd2801d8ce0 *** empty log message ***
pin
parents: 152
diff changeset
92
231
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
93 public void mainLoop() throws IOException {
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
94 while(true){
281
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
95 SessionManagerEvent e;
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
96 while((e = waitingEventQueue.poll())!=null){
281
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
97 e.exec();
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
98 }
304
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
99 for(Session s:sessionList) {
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
100 for(Editor editor: s.getEditorList())
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
101 if (editor.doWaitingWrite()) break;
300
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
102 }
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
103 // if there are waiting command during merge operation, do process it
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
104 if(checkWaitingCommandInMerge()){
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
105 if(selector.selectNow() > 0){
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
106 select();
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
107 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
108 continue;
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
109 }
233
dae90ded1bcd *** empty log message ***
pin
parents: 231
diff changeset
110 selector.select();
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
111 select();
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
112 }
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
113 }
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
114
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
115 /**
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
116 * Check waiting command in merge
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
117 * @return true if there is a processed waiting command
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
118 * @throws IOException
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
119 */
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
120 private boolean checkWaitingCommandInMerge() throws IOException {
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
121 for(Iterator<PacketSet> it = waitingCommandInMerge.iterator(); it.hasNext();){
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
122 PacketSet p = it.next();
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
123 if(p.getEditor().isMerging()) { // still merging do nothing
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
124 continue;
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
125 }else{
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
126 // process one command and return true
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
127 manage(p.channel, p.command);
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
128 it.remove();
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
129 return true;
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
130 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
131 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
132 return false;
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
133 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
134
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
135 private void select() throws IOException {
231
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
136
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
137 Set<REPSelectionKey<REPCommand>> keys = selector.selectedKeys1();
b837feb00132 *** empty log message ***
pin
parents: 229
diff changeset
138 for(REPSelectionKey<REPCommand> key : keys){
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
139 if(key.isAcceptable()){
199
456ba58cd042 *** empty log message ***
pin
parents: 198
diff changeset
140 REPSocketChannel<REPCommand> channel = key.accept(new REPCommandPacker());
300
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
141 System.out.println("SessionManager.select() : key.isAcceptable : channel = " + channel);
229
f816e0cbe6fd *** empty log message ***
pin
parents: 228
diff changeset
142 registerChannel (channel, SelectionKey.OP_READ);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
143 channel = null;
123
5b1a0574b406 *** empty log message ***
pin
parents: 122
diff changeset
144
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
145 }else if(key.isReadable()){
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
146 REPHandler handler = (REPHandler)(key.attachment());
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
147 try {
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
148 handler.handle(key);
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
149 } catch (ClosedChannelException x) {
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
150 key.cancel();
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
151 handler.cancel(key.channel1());
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
152 } catch (IOException x) {
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
153 key.cancel();
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
154 handler.cancel( key.channel1());
267
c513cf1ce9cc call handle.cancel() on socket channel close.
kono
parents: 266
diff changeset
155 }
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
156 }
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
157 }
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
158 }
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
159
229
f816e0cbe6fd *** empty log message ***
pin
parents: 228
diff changeset
160 private void registerChannel(REPSocketChannel<REPCommand> channel, int ops) throws IOException {
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
161 if(channel == null) {
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
162 return;
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
163 }
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
164 channel.configureBlocking(false);
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
165 REPHandler handler = normalHandler;
148
6a5fe529b192 *** empty log message ***
pin
parents: 146
diff changeset
166 channel.register(selector, ops, handler);
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
167 }
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
168
287
1ff8bfc0a99a *** empty log message ***
kono
parents: 286
diff changeset
169 public void manage(REPSocketChannel<REPCommand> channel, REPCommand receivedCommand) throws IOException {
75
a636b651dbce *** empty log message ***
pin
parents: 74
diff changeset
170 if(receivedCommand == null) return;
158
5cc8cd48bded *** empty log message ***
pin
parents: 155
diff changeset
171 //Session session;
141
6f15a8880ed8 *** empty log message ***
pin
parents: 140
diff changeset
172 REPCommand sendCommand = new REPCommand(receivedCommand);
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
173 REPSocketChannel<REPCommand> send = channel;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
174
75
a636b651dbce *** empty log message ***
pin
parents: 74
diff changeset
175 switch(receivedCommand.cmd){
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
176
271
kono
parents: 267
diff changeset
177 case SMCMD_JOIN:
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
178 {
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
179 //どのSessionにも属さないエディタをリストに追加
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
180 //エディタとchannelは1対1
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
181 //エディタが新しくputする場合は新しくソケットを作る
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
182 Editor editor = new Editor(editorList.size(), channel);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
183 editor.setHost(myHost);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
184 editorList.add(editor);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
185
259
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
186 updateGUI();
199
456ba58cd042 *** empty log message ***
pin
parents: 198
diff changeset
187
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
188 }
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
189
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
190 break;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
191
271
kono
parents: 267
diff changeset
192 case SMCMD_JOIN_ACK:
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
193 assert (false);
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
194 break;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
195
271
kono
parents: 267
diff changeset
196 case SMCMD_PUT:
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
197 {
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
198 //エディタのリストに追加
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
199 Editor editor = new Editor(editorList.size(), channel);
227
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
200 //editorList.add(editor);
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
201
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
202 //Sessionを生成
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
203 int sid = sessionList.size();
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
204 editor = new Editor(0, channel);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
205 editor.setHost(myHost);
227
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
206 Session session = new Session(sid, receivedCommand.string, editor);
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
207 session.hasOwner(true);
227
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
208 sessionList.add(session);
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
209
259
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
210 updateGUI();
158
5cc8cd48bded *** empty log message ***
pin
parents: 155
diff changeset
211
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
212 //エディタにAckを送信
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
213 sendCommand.setCMD(REP.SMCMD_PUT_ACK);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
214 sendCommand.setEID(editor.getEID());
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
215 sendCommand.setSID(session.getSID());
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
216 editor.send(sendCommand);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
217
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
218 //他のSessionManagerへSessionの追加を報告
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
219 //親に送って、親から子へ
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
220 SessionXMLEncoder sessionEncoder = new SessionXMLEncoder(session);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
221 REPCommand command = new REPCommand();
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
222 command.setSID(session.getSID());
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
223 command.setString(sessionEncoder.sessionListToXML());
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
224 command.setCMD(REP.SMCMD_UPDATE);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
225 smList.sendExcept(channel, command);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
226
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
227 }
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
228
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
229 break;
133
8dce4348966c *** empty log message ***
kono
parents: 124
diff changeset
230
271
kono
parents: 267
diff changeset
231 case SMCMD_SELECT:
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
232 {
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
233 //他のSessionManagerをエディタとしてSessionに追加
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
234 Editor editor = new Editor(channel);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
235 Session session = getSession(receivedCommand.sid);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
236 session.addEditor(editor);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
237
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
238 if(session.hasOwner()){
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
239 //このSessionManagerがオーナーを持っている場合、Sessionにエディタを追加し、エディタへAckを返す
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
240 sendCommand.setCMD(REP.SMCMD_SELECT_ACK);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
241 sendCommand.setEID(editor.getEID());
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
242 editor.send(sendCommand);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
243 }else{
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
244 //オーナーを持ってない場合は、オーナーを持っているSessionManagerへSELECTコマンドを中継する
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
245 Editor owner = session.getOwner();
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
246 owner.send(receivedCommand);
148
6a5fe529b192 *** empty log message ***
pin
parents: 146
diff changeset
247 }
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
248 }
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
249
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
250 break;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
251
271
kono
parents: 267
diff changeset
252 case SMCMD_SELECT_ACK:
160
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
253 {
85
d5cd4d103eea *** empty log message ***
pin
parents: 84
diff changeset
254 String hostport = receivedCommand.string;
160
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
255 Editor editor = getEditor(hostport);
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
256
160
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
257 if(editor != null) {
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
258 //host, port を見て、このコマンドが自分が送信したSelectコマンドのAckかどうかを判断する
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
259 REPCommand command = new REPCommand();
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
260 command.setCMD(REP.SMCMD_JOIN_ACK);
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
261 command.setSID(receivedCommand.sid);
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
262 command.setEID(receivedCommand.eid);
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
263 editor.send(command);
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
264
85
d5cd4d103eea *** empty log message ***
pin
parents: 84
diff changeset
265 }else{
160
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
266 //自分が送信したコマンドでなければ、次のSessionManagerへ中継する
85
d5cd4d103eea *** empty log message ***
pin
parents: 84
diff changeset
267 smList.sendExcept(channel, receivedCommand);
d5cd4d103eea *** empty log message ***
pin
parents: 84
diff changeset
268 }
160
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
269 }
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
270
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
271 break;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
272
271
kono
parents: 267
diff changeset
273 case SMCMD_SM_JOIN:
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
274
160
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
275 {
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
276 //SessionManagerのリストへ追加
83
9381b4734a0b *** empty log message ***
pin
parents: 82
diff changeset
277 smList.add(channel);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
278
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
279 //XMLからSessionListオブジェクトを生成する。
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
280 SessionXMLDecoder decoder = new SessionXMLDecoder();
79
d1877cfd131d *** empty log message ***
pin
parents: 78
diff changeset
281 SessionList receivedSessionList = decoder.decode(receivedCommand.string);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
282
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
283 //myHost を設定。
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
284 //立ち上げ時にやるとlocalhostしか取れない
76
97ca5f5447cd *** empty log message ***
pin
parents: 75
diff changeset
285 if(myHost == null) setMyHostName(getLocalHostName(channel));
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
286
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
287 //maxHost を設定。
95
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
288 if(setMaxHost(channel, receivedSessionList.getMaxHost())){
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
289 sendCommand = new REPCommand();
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
290 sendCommand.setCMD(REP.SMCMD_CH_MASTER);
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
291 sendCommand.setString(maxHost);
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
292 smList.sendExcept(channel, sendCommand);
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
293 }
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
294
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
295 //SessionListからXMLを生成。
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
296 //joinしてきたSessionManagerに対してACKを送信。
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
297 SessionXMLEncoder sessionlistEncoder = new SessionXMLEncoder(sessionList);
78
8a4f92f31c58 *** empty log message ***
pin
parents: 77
diff changeset
298 sendCommand = new REPCommand();
8a4f92f31c58 *** empty log message ***
pin
parents: 77
diff changeset
299 sendCommand.setCMD(REP.SMCMD_SM_JOIN_ACK);
8a4f92f31c58 *** empty log message ***
pin
parents: 77
diff changeset
300 sendCommand.setString(sessionlistEncoder.sessionListToXML());
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
301 send.write(sendCommand);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
302
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
303 //その他の SessionManager に対して SMCMD_UPDATEを 送信。
78
8a4f92f31c58 *** empty log message ***
pin
parents: 77
diff changeset
304 sendCommand = new REPCommand();
83
9381b4734a0b *** empty log message ***
pin
parents: 82
diff changeset
305 sendCommand.setCMD(REP.SMCMD_UPDATE);
78
8a4f92f31c58 *** empty log message ***
pin
parents: 77
diff changeset
306 sendCommand.setString(receivedCommand.string);
8a4f92f31c58 *** empty log message ***
pin
parents: 77
diff changeset
307 smList.sendExcept(channel, sendCommand);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
308
160
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
309 }
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
310 break;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
311
271
kono
parents: 267
diff changeset
312 case SMCMD_SM_JOIN_ACK:
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
313
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
314 //XMLからSessionListオブジェクトを生成。
82
4bb583553a42 *** empty log message ***
pin
parents: 81
diff changeset
315 SessionXMLDecoder decoder2 = new SessionXMLDecoder();
4bb583553a42 *** empty log message ***
pin
parents: 81
diff changeset
316 SessionList receivedSessionList2 = decoder2.decode(receivedCommand.string);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
317
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
318 //maxHostを決定。
95
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
319 if(setMaxHost(channel, receivedSessionList2.getMaxHost())){
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
320 sendCommand = new REPCommand();
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
321 sendCommand.setCMD(REP.SMCMD_CH_MASTER);
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
322 sendCommand.setString(maxHost);
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
323 smList.sendExcept(channel, sendCommand);
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
324 }
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
325
6
bdb91f4cea26 It Can connect SessionManagers each other.
pin
parents: 5
diff changeset
326 break;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
327
271
kono
parents: 267
diff changeset
328 case SMCMD_UPDATE:
200
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
329 {
99
2f79cdc45a2e *** empty log message ***
pin
parents: 98
diff changeset
330 SessionXMLDecoder decoder3 = new SessionXMLDecoder();
2f79cdc45a2e *** empty log message ***
pin
parents: 98
diff changeset
331 SessionList receivedSessionList3 = decoder3.decode(receivedCommand.string);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
332
200
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
333 //UPDATEコマンドにより送られてきたSessionの情報を追加する
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
334 LinkedList<Session> list = receivedSessionList3.getList();
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
335 for(Session session : list){
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
336 session.getEditorList().get(0).setChannel(channel);
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
337 sessionList.add(session);
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
338 }
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
339
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
340 //他のSessionManagerへ中継する
99
2f79cdc45a2e *** empty log message ***
pin
parents: 98
diff changeset
341 smList.sendExcept(channel, receivedCommand);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
342
200
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
343 //リストのコピーをGUIに渡す
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
344 LinkedList<Session> sList = new LinkedList<Session>(sessionList);
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
345 LinkedList<Editor> eList = new LinkedList<Editor>(editorList);
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
346 //GUIに反映
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
347 Runnable doRun = new DoGUIUpdate(sList, eList, gui);
279
e58695b5118d *** empty log message ***
kono
parents: 274
diff changeset
348 gui.invokeLater(doRun);
200
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
349 }
9
2d4c2c19d2d0 *** empty log message ***
pin
parents: 8
diff changeset
350 break;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
351
271
kono
parents: 267
diff changeset
352 case SMCMD_UPDATE_ACK:
200
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
353 {
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
354 if(receivedCommand.sid > sessionList.size()){
148
6a5fe529b192 *** empty log message ***
pin
parents: 146
diff changeset
355 Editor editor = new Editor(channel);
75
a636b651dbce *** empty log message ***
pin
parents: 74
diff changeset
356 editor.setName(receivedCommand.string);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
357
158
5cc8cd48bded *** empty log message ***
pin
parents: 155
diff changeset
358 Session session = new Session(editor);
73
4d887f38284b *** empty log message ***
pin
parents: 72
diff changeset
359 session.addEditor(editor);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
360
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
361 sessionList.add(session);
200
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
362
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
363 //リストのコピーをGUIに渡す
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
364 LinkedList<Session> sList = new LinkedList<Session>(sessionList);
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
365 LinkedList<Editor> eList = new LinkedList<Editor>(editorList);
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
366 //GUIに反映
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
367 Runnable doRun = new DoGUIUpdate(sList, eList, gui);
279
e58695b5118d *** empty log message ***
kono
parents: 274
diff changeset
368 gui.invokeLater(doRun);
73
4d887f38284b *** empty log message ***
pin
parents: 72
diff changeset
369 }
75
a636b651dbce *** empty log message ***
pin
parents: 74
diff changeset
370 smList.sendToSlave(receivedCommand);
200
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
371 }
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
372 break;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
373
271
kono
parents: 267
diff changeset
374 case SMCMD_CH_MASTER:
200
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
375 {
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
376 //maxHost を設定。
95
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
377 if(setMaxHost(channel, receivedCommand.string)){
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
378 sendCommand = new REPCommand();
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
379 sendCommand.setCMD(REP.SMCMD_CH_MASTER);
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
380 sendCommand.setString(maxHost);
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
381 smList.sendExcept(channel, sendCommand);
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
382 }
200
2f0a0448de6b *** empty log message ***
pin
parents: 199
diff changeset
383 }
95
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
384 break;
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
385
271
kono
parents: 267
diff changeset
386 case REPCMD_DELETE:
kono
parents: 267
diff changeset
387 case REPCMD_INSERT:
300
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
388 case REPCMD_NOP:
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
389 {
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
390 //sid から Session を取得
158
5cc8cd48bded *** empty log message ***
pin
parents: 155
diff changeset
391 Session session = getSession(receivedCommand.sid);
287
1ff8bfc0a99a *** empty log message ***
kono
parents: 286
diff changeset
392 if (session==null) throw new IOException();
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
393 //マージの処理と次のエディタへコマンドを送信する処理
304
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
394 Editor editor = session.getEditor(channel);
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
395 boolean old = editor.isMerging();
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
396 session.translate(channel, receivedCommand);
304
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
397 boolean newState = editor.isMerging();
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
398 if (old!=newState) {
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
399 // prevEditor なのは変だと思うが...
304
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
400 Editor prevEditor = session.getPrevEditor(editor);
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
401 //マージ中のエディタはコマンドを受け取らない
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
402 // この代入は状態が変わったときだけ行えば良い。毎回、new するのは変
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
403 if(editor.isMerging()){
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
404 //Handlerを切り替える
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
405 setMergeState(prevEditor.getChannel(), session.getSID());
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
406 }else {
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
407 setNormalState(prevEditor.getChannel(), session.getSID());
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
408 }
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
409 }
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
410 }
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
411 break;
300
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
412 case SMCMD_QUIT:
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
413 {
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
414 Session session = getSession(receivedCommand.sid);
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
415 if (session==null) throw new IOException();
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
416 session.sendToNextEditor(channel,receivedCommand);
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
417 break;
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
418 }
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
419 case SMCMD_QUIT_2:
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
420 {
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
421 Session session = getSession(receivedCommand.sid);
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
422 if (session==null) throw new IOException();
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
423 Editor editor = session.getEditor(channel);
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
424 editor.setQuit2(receivedCommand);
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
425 break;
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
426 }
213
4d9b32666ed2 *** empty log message ***
pin
parents: 212
diff changeset
427 default:
4d9b32666ed2 *** empty log message ***
pin
parents: 212
diff changeset
428 assert(false);
4d9b32666ed2 *** empty log message ***
pin
parents: 212
diff changeset
429 break;
4d9b32666ed2 *** empty log message ***
pin
parents: 212
diff changeset
430
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
431 }
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
432 }
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
433
259
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
434 private void updateGUI() {
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
435 //リストのコピーをGUIに渡す
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
436 LinkedList<Session> sList = new LinkedList<Session>(sessionList);
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
437 LinkedList<Editor> eList = new LinkedList<Editor>(editorList);
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
438 //GUIに反映
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
439 Runnable doRun = new DoGUIUpdate(sList, eList, gui);
279
e58695b5118d *** empty log message ***
kono
parents: 274
diff changeset
440 gui.invokeLater(doRun);
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
441 }
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
442
169
2974db051dd8 *** empty log message ***
pin
parents: 167
diff changeset
443 private void setNormalState(REPSocketChannel<REPCommand> channel, int sid) {
2974db051dd8 *** empty log message ***
pin
parents: 167
diff changeset
444 SelectionKey key = channel.keyFor(selector);
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
445 key.attach(normalHandler);
169
2974db051dd8 *** empty log message ***
pin
parents: 167
diff changeset
446 }
2974db051dd8 *** empty log message ***
pin
parents: 167
diff changeset
447
167
3dc194f5e28f *** empty log message ***
pin
parents: 164
diff changeset
448 private void setMergeState(REPSocketChannel<REPCommand> channel, int sid) {
3dc194f5e28f *** empty log message ***
pin
parents: 164
diff changeset
449 SelectionKey key = channel.keyFor(selector);
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
450 key.attach(handlerInMerge);
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
451 }
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
452
160
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
453 private Editor getEditor(String hostport) {
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
454 for(Editor editor : editorList){
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
455 if(editor.getHost() == hostport){
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
456 return editor;
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
457 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
458 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
459 return null;
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
460 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
461
224
6b0dd92b8e45 add optimizer to Editor
kent
parents: 222
diff changeset
462 public Editor getEditor(REPSocketChannel<REPCommand> channel){
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
463 for(Editor editor : editorList){
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
464 if(editor.getChannel() == channel){
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
465 return editor;
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
466 }
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
467 }
160
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
468 return null;
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
469 }
6a5974dd0368 *** empty log message ***
pin
parents: 158
diff changeset
470
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
471 private Session getSession(int sid) {
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
472 for(Session session : sessionList){
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
473 if(session.getSID() == sid) return session;
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
474 }
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
475 return null;
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
476 }
83
9381b4734a0b *** empty log message ***
pin
parents: 82
diff changeset
477
224
6b0dd92b8e45 add optimizer to Editor
kent
parents: 222
diff changeset
478 private boolean setMaxHost(REPSocketChannel<REPCommand> channel, String maxHost2) {
179
763aad2da6b3 *** empty log message ***
pin
parents: 178
diff changeset
479 if(maxHost.compareTo(maxHost2) > 0){
763aad2da6b3 *** empty log message ***
pin
parents: 178
diff changeset
480 return false;
763aad2da6b3 *** empty log message ***
pin
parents: 178
diff changeset
481 }else{
763aad2da6b3 *** empty log message ***
pin
parents: 178
diff changeset
482 maxHost = maxHost2;
763aad2da6b3 *** empty log message ***
pin
parents: 178
diff changeset
483 return true;
763aad2da6b3 *** empty log message ***
pin
parents: 178
diff changeset
484 }
139
d6b94713cf45 *** empty log message ***
pin
parents: 133
diff changeset
485 }
d6b94713cf45 *** empty log message ***
pin
parents: 133
diff changeset
486
76
97ca5f5447cd *** empty log message ***
pin
parents: 75
diff changeset
487 private void setMyHostName(String localHostName) {
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
488 myHost = localHostName + receive_port;
81
13819571691d *** empty log message ***
pin
parents: 80
diff changeset
489 if(maxHost == null) {
13819571691d *** empty log message ***
pin
parents: 80
diff changeset
490 maxHost = myHost;
13819571691d *** empty log message ***
pin
parents: 80
diff changeset
491 }
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
492 setHostToEditor(myHost);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
493 }
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
494
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
495 private void setHostToEditor(String myHost2) {
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
496 for(Editor editor : editorList){
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
497 editor.setHost(myHost2);
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
498 }
76
97ca5f5447cd *** empty log message ***
pin
parents: 75
diff changeset
499 }
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
500
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
501 public static void main(String[] args) throws InterruptedException, IOException {
191
dbf59f82273e *** empty log message ***
pin
parents: 186
diff changeset
502
101
612cb62151ce *** empty log message ***
pin
parents: 100
diff changeset
503 int port = DEFAULT_PORT;
612cb62151ce *** empty log message ***
pin
parents: 100
diff changeset
504 int port_s = DEFAULT_PORT;
300
8f6b7a1890b2 *** empty log message ***
kono
parents: 296
diff changeset
505 //System.setProperty("file.encoding", "UTF-8");
82
4bb583553a42 *** empty log message ***
pin
parents: 81
diff changeset
506 if(args.length > 0){
39
c873ee0318f8 *** empty log message ***
pin
parents: 38
diff changeset
507 port = Integer.parseInt(args[0]);
95
2462a5d11396 add hostname+port
chiaki
parents: 94
diff changeset
508 port_s = Integer.parseInt(args[1]);
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
509 }
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
510 receive_port = port;
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
511 parent_port = port_s;
281
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
512 SessionManager sm = new SessionManager();
280
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
513 sm.init(port,new SessionManagerGUIimpl(sm));
a549bd4dadb8 *** empty log message ***
kono
parents: 279
diff changeset
514
191
dbf59f82273e *** empty log message ***
pin
parents: 186
diff changeset
515
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
516 }
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
517
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
518 public void connectSession(String host) {
101
612cb62151ce *** empty log message ***
pin
parents: 100
diff changeset
519 int port = DEFAULT_PORT;
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
520 port = parent_port;
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
521 InetSocketAddress addr = new InetSocketAddress(host, port);
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
522 try {
186
d22384c0026c *** empty log message ***
kent
parents: 185
diff changeset
523 REPSocketChannel<REPCommand> sessionchannel = REPSocketChannel.<REPCommand>create(new REPCommandPacker());
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
524 sessionchannel.configureBlocking(true);
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
525 sessionchannel.connect(addr);
6
bdb91f4cea26 It Can connect SessionManagers each other.
pin
parents: 5
diff changeset
526 while(!sessionchannel.finishConnect()){
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
527 System.out.print("test afro");
6
bdb91f4cea26 It Can connect SessionManagers each other.
pin
parents: 5
diff changeset
528 }
bdb91f4cea26 It Can connect SessionManagers each other.
pin
parents: 5
diff changeset
529 System.out.println("");
229
f816e0cbe6fd *** empty log message ***
pin
parents: 228
diff changeset
530 registerChannel(sessionchannel, SelectionKey.OP_READ);
45
10f1adf6d74d *** empty log message ***
pin
parents: 39
diff changeset
531
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
532 sm_join(sessionchannel);
45
10f1adf6d74d *** empty log message ***
pin
parents: 39
diff changeset
533
1
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
534 }catch (IOException e) {
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
535 e.printStackTrace();
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
536 }
3f5bf0255f5e *** empty log message ***
pin
parents: 0
diff changeset
537 }
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
538
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
539 private void sm_join(REPSocketChannel<REPCommand> channel){
79
d1877cfd131d *** empty log message ***
pin
parents: 78
diff changeset
540
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
541 //SM_JOINコマンドを生成。
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
542 REPCommand command = new REPCommand();
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
543 command.setCMD(REP.SMCMD_SM_JOIN);
79
d1877cfd131d *** empty log message ***
pin
parents: 78
diff changeset
544
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
545 //hostnameをセット。
82
4bb583553a42 *** empty log message ***
pin
parents: 81
diff changeset
546 setMyHostName(getLocalHostName(channel));
4bb583553a42 *** empty log message ***
pin
parents: 81
diff changeset
547
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
548 //XMLを生成。送信コマンドにセット。
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
549 SessionXMLEncoder encoder = new SessionXMLEncoder(sessionList);
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
550 String string = encoder.sessionListToXML();
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
551 command.setString(string);
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
552
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
553 //SM_JOINコマンドを送信。
186
d22384c0026c *** empty log message ***
kent
parents: 185
diff changeset
554 channel.write(command);
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
555 //SessionManagerのListに追加。
77
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
556 smList.add(channel);
eb78312ea831 *** empty log message ***
pin
parents: 76
diff changeset
557 }
2
02fa9a68d9a2 *** empty log message ***
pin
parents: 1
diff changeset
558
271
kono
parents: 267
diff changeset
559 private String getLocalHostName(REPSocketChannel<?> channel) {
74
391d44c94799 *** empty log message ***
pin
parents: 73
diff changeset
560 String host = null;
391d44c94799 *** empty log message ***
pin
parents: 73
diff changeset
561 host = channel.socket().getLocalAddress().getHostName();
391d44c94799 *** empty log message ***
pin
parents: 73
diff changeset
562 return host;
391d44c94799 *** empty log message ***
pin
parents: 73
diff changeset
563 }
391d44c94799 *** empty log message ***
pin
parents: 73
diff changeset
564
250
5f357ca66714 *** empty log message ***
pin
parents: 246
diff changeset
565 public void selectSession(SelectButtonEvent event) {
5f357ca66714 *** empty log message ***
pin
parents: 246
diff changeset
566 REPSocketChannel<REPCommand> channel = event.getEditorChannel();
5f357ca66714 *** empty log message ***
pin
parents: 246
diff changeset
567 int sid = event.getSID();
5f357ca66714 *** empty log message ***
pin
parents: 246
diff changeset
568 int eid = event.getEID();
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
569 Session session = getSession(sid);
227
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
570
250
5f357ca66714 *** empty log message ***
pin
parents: 246
diff changeset
571 Editor editor = editorList.get(eid);
227
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
572 if(editor == null){
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
573 System.out.println("SessionManager.selectSession():editor = " + editor);
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
574 return;
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
575 }
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
576
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
577 session.addEditor(editor);
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
578
304
75192c844a8d *** empty log message ***
kono
parents: 300
diff changeset
579 System.out.println("SessionManager.session.hasOnwer="+session.hasOwner());
158
5cc8cd48bded *** empty log message ***
pin
parents: 155
diff changeset
580 if(session.hasOwner()){
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
581 REPCommand sendCommand = new REPCommand();
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
582 sendCommand.setCMD(REP.SMCMD_JOIN_ACK);
148
6a5fe529b192 *** empty log message ***
pin
parents: 146
diff changeset
583 sendCommand.setEID(editor.getEID());
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
584 sendCommand.setSID(sid);
286
30c993e89286 TestEditor
kono
parents: 281
diff changeset
585 sendCommand.string = "";
186
d22384c0026c *** empty log message ***
kent
parents: 185
diff changeset
586 channel.write(sendCommand);
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
587 }else {
250
5f357ca66714 *** empty log message ***
pin
parents: 246
diff changeset
588 sid = event.getSID();
227
cbd67817e9cd *** empty log message ***
pin
parents: 224
diff changeset
589 editor = new Editor(channel);
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
590 editor.setHost(myHost);
164
3841cc75b808 *** empty log message ***
pin
parents: 163
diff changeset
591 session = getSession(sid);
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
592 session.addEditor(editor);
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
593
158
5cc8cd48bded *** empty log message ***
pin
parents: 155
diff changeset
594 Editor owner = session.getOwner();
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
595
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
596 REPCommand command = new REPCommand();
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
597 command.setCMD(REP.SMCMD_SELECT);
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
598 command.setSID(sid);
178
a097b1d619a1 *** empty log message ***
pin
parents: 173
diff changeset
599 command.setString(editor.getHost());
107
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
600 owner.send(command);
d32096538dc3 *** empty log message ***
pin
parents: 106
diff changeset
601 }
8
b774b87cc2c1 *** empty log message ***
pin
parents: 7
diff changeset
602 }
122
790c8dd42a7b *** empty log message ***
kono
parents: 117
diff changeset
603
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
604 public void addWaitingCommand(PacketSet set) {
212
e8f716498caf *** empty log message ***
pin
parents: 201
diff changeset
605 waitingCommandInMerge.add(set);
144
0bf7f8d0f5f7 *** empty log message ***
pin
parents: 141
diff changeset
606 }
148
6a5fe529b192 *** empty log message ***
pin
parents: 146
diff changeset
607
222
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
608 public void buttonPressed(SessionManagerEvent event) {
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
609 try {
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
610 waitingEventQueue.put(event);
222
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
611 } catch (InterruptedException e) {}
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
612 selector.wakeup();
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
613 }
281
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
614
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
615 public void syncExec(SessionManagerEvent event) {
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
616 try {
308
c5be84d53c7f *** empty log message ***
kono
parents: 304
diff changeset
617 waitingEventQueue.put(event);
281
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
618 } catch (InterruptedException e) {
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
619 }
c3969dd625b2 GUIless test routine.
kono
parents: 280
diff changeset
620 }
222
18d6a7140fa3 *** empty log message ***
pin
parents: 215
diff changeset
621
259
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
622 public void closeSession(SessionManagerEvent event) {
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
623 Session session = ((CloseButtonEvent) event).getSession();
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
624 session.closeSession();
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
625 sessionList.remove(session);
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
626 updateGUI();
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
627 }
9e36fd27e2b6 *** empty log message ***
pin
parents: 258
diff changeset
628
274
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
629 public void remove(REPSocketChannel<REPCommand> channel) {
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
630 for(Session s:sessionList) {
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
631 if (s.deleteEditor(channel)) {
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
632 return ;
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
633 }
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
634 }
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
635 assert(false);
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
636 // can be other session manager? what should I do?
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
637 }
ad487e63e3c8 *** empty log message ***
kono
parents: 271
diff changeset
638
0
e41994ce73c7 *** empty log message ***
pin
parents:
diff changeset
639 }