annotate rep/SessionManager.java @ 279:e58695b5118d

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