annotate test/editortest/REPEditor.java @ 417:267f9748e826

(no commit message)
author one
date Wed, 31 Dec 2008 14:52:45 +0900
parents
children 7ff127c8ad64
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
417
267f9748e826 (no commit message)
one
parents:
diff changeset
1 package test.editortest;
267f9748e826 (no commit message)
one
parents:
diff changeset
2
267f9748e826 (no commit message)
one
parents:
diff changeset
3 import java.io.IOException;
267f9748e826 (no commit message)
one
parents:
diff changeset
4 import java.net.InetSocketAddress;
267f9748e826 (no commit message)
one
parents:
diff changeset
5 import java.nio.channels.SelectionKey;
267f9748e826 (no commit message)
one
parents:
diff changeset
6 import java.util.LinkedList;
267f9748e826 (no commit message)
one
parents:
diff changeset
7 import rep.REP;
267f9748e826 (no commit message)
one
parents:
diff changeset
8 import rep.REPCommand;
267f9748e826 (no commit message)
one
parents:
diff changeset
9 import rep.REPCommandPacker;
267f9748e826 (no commit message)
one
parents:
diff changeset
10 import rep.channel.REPSelectionKey;
267f9748e826 (no commit message)
one
parents:
diff changeset
11 import rep.channel.REPSelector;
267f9748e826 (no commit message)
one
parents:
diff changeset
12 import rep.channel.REPSocketChannel;
267f9748e826 (no commit message)
one
parents:
diff changeset
13
267f9748e826 (no commit message)
one
parents:
diff changeset
14
267f9748e826 (no commit message)
one
parents:
diff changeset
15 public class REPEditor extends Thread implements REPTextListener{
267f9748e826 (no commit message)
one
parents:
diff changeset
16
267f9748e826 (no commit message)
one
parents:
diff changeset
17 private REPSocketChannel<REPCommand> channel;
267f9748e826 (no commit message)
one
parents:
diff changeset
18 REPSelector<REPCommand> selector;
267f9748e826 (no commit message)
one
parents:
diff changeset
19 private boolean running = true;
267f9748e826 (no commit message)
one
parents:
diff changeset
20 private boolean inputLock = false;
267f9748e826 (no commit message)
one
parents:
diff changeset
21 private long timeout = 1;
267f9748e826 (no commit message)
one
parents:
diff changeset
22 private int syncCounter = 0;
267f9748e826 (no commit message)
one
parents:
diff changeset
23 private LinkedList<REPCommand> userCommand = new LinkedList<REPCommand>();
267f9748e826 (no commit message)
one
parents:
diff changeset
24 private LinkedList<Runnable> runners = new LinkedList<Runnable>();
267f9748e826 (no commit message)
one
parents:
diff changeset
25 private String name = "test";
267f9748e826 (no commit message)
one
parents:
diff changeset
26 private int seq;
267f9748e826 (no commit message)
one
parents:
diff changeset
27 private int eid;
267f9748e826 (no commit message)
one
parents:
diff changeset
28 private int sid;
267f9748e826 (no commit message)
one
parents:
diff changeset
29 private REPText repText;
267f9748e826 (no commit message)
one
parents:
diff changeset
30 private boolean hasInputLock;
267f9748e826 (no commit message)
one
parents:
diff changeset
31 private boolean master;
267f9748e826 (no commit message)
one
parents:
diff changeset
32 private boolean syncEnable = true;
267f9748e826 (no commit message)
one
parents:
diff changeset
33 private LogTarget logTarget;
267f9748e826 (no commit message)
one
parents:
diff changeset
34
267f9748e826 (no commit message)
one
parents:
diff changeset
35 public REPEditor(REPText repText, boolean master){
267f9748e826 (no commit message)
one
parents:
diff changeset
36 this.repText = repText;
267f9748e826 (no commit message)
one
parents:
diff changeset
37 this.master = master;
267f9748e826 (no commit message)
one
parents:
diff changeset
38 repText.addTextListener(this);
267f9748e826 (no commit message)
one
parents:
diff changeset
39 if(master){
267f9748e826 (no commit message)
one
parents:
diff changeset
40 userCommand.add(new REPCommand(REP.SMCMD_PUT,0,0,0,0,name +"-file"));
267f9748e826 (no commit message)
one
parents:
diff changeset
41 }else{
267f9748e826 (no commit message)
one
parents:
diff changeset
42 userCommand.add(new REPCommand(REP.SMCMD_JOIN, 0, 0, 0, 0, name));
267f9748e826 (no commit message)
one
parents:
diff changeset
43 }
267f9748e826 (no commit message)
one
parents:
diff changeset
44 }
267f9748e826 (no commit message)
one
parents:
diff changeset
45
267f9748e826 (no commit message)
one
parents:
diff changeset
46 public void textDeleted(REPTextEvent event) {
267f9748e826 (no commit message)
one
parents:
diff changeset
47 Logger.print(event.getText());
267f9748e826 (no commit message)
one
parents:
diff changeset
48 addUserInput(new REPCommand(REP.REPCMD_DELETE_USER, 0, 0, 0, event.getLineno(), event.getText()));
267f9748e826 (no commit message)
one
parents:
diff changeset
49 }
267f9748e826 (no commit message)
one
parents:
diff changeset
50
267f9748e826 (no commit message)
one
parents:
diff changeset
51 public void textInserted(REPTextEvent event) {
267f9748e826 (no commit message)
one
parents:
diff changeset
52 Logger.print(event.getText());
267f9748e826 (no commit message)
one
parents:
diff changeset
53 addUserInput(new REPCommand(REP.REPCMD_INSERT_USER, 0, 0, 0, event.getLineno(), event.getText()));
267f9748e826 (no commit message)
one
parents:
diff changeset
54 }
267f9748e826 (no commit message)
one
parents:
diff changeset
55
267f9748e826 (no commit message)
one
parents:
diff changeset
56 private void addUserInput(final REPCommand command) {
267f9748e826 (no commit message)
one
parents:
diff changeset
57 Runnable runner = new Runnable(){
267f9748e826 (no commit message)
one
parents:
diff changeset
58 public void run(){
267f9748e826 (no commit message)
one
parents:
diff changeset
59 userCommand.add(command);
267f9748e826 (no commit message)
one
parents:
diff changeset
60 timeout = 1;
267f9748e826 (no commit message)
one
parents:
diff changeset
61 }
267f9748e826 (no commit message)
one
parents:
diff changeset
62 };
267f9748e826 (no commit message)
one
parents:
diff changeset
63 synchronized(runners){
267f9748e826 (no commit message)
one
parents:
diff changeset
64 runners.add(runner);
267f9748e826 (no commit message)
one
parents:
diff changeset
65 }
267f9748e826 (no commit message)
one
parents:
diff changeset
66 if(selector != null){
267f9748e826 (no commit message)
one
parents:
diff changeset
67 selector.wakeup();
267f9748e826 (no commit message)
one
parents:
diff changeset
68 }
267f9748e826 (no commit message)
one
parents:
diff changeset
69 }
267f9748e826 (no commit message)
one
parents:
diff changeset
70
267f9748e826 (no commit message)
one
parents:
diff changeset
71 public void run(){
267f9748e826 (no commit message)
one
parents:
diff changeset
72 /*
267f9748e826 (no commit message)
one
parents:
diff changeset
73 * Create Socket and connect to the session manager
267f9748e826 (no commit message)
one
parents:
diff changeset
74 */
267f9748e826 (no commit message)
one
parents:
diff changeset
75 try {
267f9748e826 (no commit message)
one
parents:
diff changeset
76 channel = REPSocketChannel.<REPCommand>create(new REPCommandPacker());
267f9748e826 (no commit message)
one
parents:
diff changeset
77 } catch (IOException e) {
267f9748e826 (no commit message)
one
parents:
diff changeset
78 e.printStackTrace();
267f9748e826 (no commit message)
one
parents:
diff changeset
79 return;
267f9748e826 (no commit message)
one
parents:
diff changeset
80 }
267f9748e826 (no commit message)
one
parents:
diff changeset
81 try {
267f9748e826 (no commit message)
one
parents:
diff changeset
82 InetSocketAddress semaIP = new InetSocketAddress("localhost", 8766);
267f9748e826 (no commit message)
one
parents:
diff changeset
83 while (!channel.connect(semaIP)){
267f9748e826 (no commit message)
one
parents:
diff changeset
84 Logger.print("SeMa not listen to socket yet, wait");
267f9748e826 (no commit message)
one
parents:
diff changeset
85 }
267f9748e826 (no commit message)
one
parents:
diff changeset
86 } catch (IOException e) {
267f9748e826 (no commit message)
one
parents:
diff changeset
87 e.printStackTrace();
267f9748e826 (no commit message)
one
parents:
diff changeset
88 return;
267f9748e826 (no commit message)
one
parents:
diff changeset
89 }
267f9748e826 (no commit message)
one
parents:
diff changeset
90 /*
267f9748e826 (no commit message)
one
parents:
diff changeset
91 * Start editor main loop
267f9748e826 (no commit message)
one
parents:
diff changeset
92 * public REPCommand(REP cmd,int sid,int eid, int seq, int lineno, String string)
267f9748e826 (no commit message)
one
parents:
diff changeset
93 */
267f9748e826 (no commit message)
one
parents:
diff changeset
94 try {
267f9748e826 (no commit message)
one
parents:
diff changeset
95 mainloop();
267f9748e826 (no commit message)
one
parents:
diff changeset
96 } catch (IOException e) {
267f9748e826 (no commit message)
one
parents:
diff changeset
97 }
267f9748e826 (no commit message)
one
parents:
diff changeset
98 }
267f9748e826 (no commit message)
one
parents:
diff changeset
99
267f9748e826 (no commit message)
one
parents:
diff changeset
100 /*
267f9748e826 (no commit message)
one
parents:
diff changeset
101 * Editor main loop with input lock
267f9748e826 (no commit message)
one
parents:
diff changeset
102 */
267f9748e826 (no commit message)
one
parents:
diff changeset
103 private void mainloop() throws IOException {
267f9748e826 (no commit message)
one
parents:
diff changeset
104
267f9748e826 (no commit message)
one
parents:
diff changeset
105 channel.configureBlocking(false);
267f9748e826 (no commit message)
one
parents:
diff changeset
106 selector = REPSelector.create();
267f9748e826 (no commit message)
one
parents:
diff changeset
107 channel.register(selector, SelectionKey.OP_READ);
267f9748e826 (no commit message)
one
parents:
diff changeset
108 while(running) {
267f9748e826 (no commit message)
one
parents:
diff changeset
109
267f9748e826 (no commit message)
one
parents:
diff changeset
110 synchronized(runners){
267f9748e826 (no commit message)
one
parents:
diff changeset
111 for(Runnable runner : runners){
267f9748e826 (no commit message)
one
parents:
diff changeset
112 runner.run();
267f9748e826 (no commit message)
one
parents:
diff changeset
113 }
267f9748e826 (no commit message)
one
parents:
diff changeset
114 runners.clear();
267f9748e826 (no commit message)
one
parents:
diff changeset
115 }
267f9748e826 (no commit message)
one
parents:
diff changeset
116
267f9748e826 (no commit message)
one
parents:
diff changeset
117 if (inputLock) {
267f9748e826 (no commit message)
one
parents:
diff changeset
118 // No user input during merge mode (optional)
267f9748e826 (no commit message)
one
parents:
diff changeset
119 if (selector.select(0)>0) {
267f9748e826 (no commit message)
one
parents:
diff changeset
120 handle(channel.read());
267f9748e826 (no commit message)
one
parents:
diff changeset
121 }
267f9748e826 (no commit message)
one
parents:
diff changeset
122 continue;
267f9748e826 (no commit message)
one
parents:
diff changeset
123 } else if (selector.select(timeout)<=0) {
267f9748e826 (no commit message)
one
parents:
diff changeset
124 if (syncCounter>0) {
267f9748e826 (no commit message)
one
parents:
diff changeset
125 syncText(); // send the master editor buffer to clients.
267f9748e826 (no commit message)
one
parents:
diff changeset
126 }
267f9748e826 (no commit message)
one
parents:
diff changeset
127 userInput();
267f9748e826 (no commit message)
one
parents:
diff changeset
128 }
267f9748e826 (no commit message)
one
parents:
diff changeset
129 // selector(timeout) returns 0, but it may contain readable channel..
267f9748e826 (no commit message)
one
parents:
diff changeset
130 for(REPSelectionKey<REPCommand> key : selector.selectedKeys1()) {
267f9748e826 (no commit message)
one
parents:
diff changeset
131 REPSocketChannel<REPCommand> ch = key.channel1();
267f9748e826 (no commit message)
one
parents:
diff changeset
132 handle(ch.read());
267f9748e826 (no commit message)
one
parents:
diff changeset
133 }
267f9748e826 (no commit message)
one
parents:
diff changeset
134 }
267f9748e826 (no commit message)
one
parents:
diff changeset
135 }
267f9748e826 (no commit message)
one
parents:
diff changeset
136
267f9748e826 (no commit message)
one
parents:
diff changeset
137 private void handle(REPCommand command) {
267f9748e826 (no commit message)
one
parents:
diff changeset
138 Logger.print(logTarget, command);
267f9748e826 (no commit message)
one
parents:
diff changeset
139 if(command == null) return;
267f9748e826 (no commit message)
one
parents:
diff changeset
140 switch(command.cmd){
267f9748e826 (no commit message)
one
parents:
diff changeset
141 case REPCMD_DELETE:
267f9748e826 (no commit message)
one
parents:
diff changeset
142 if(command.eid != eid){
267f9748e826 (no commit message)
one
parents:
diff changeset
143 String del = repText.delete(command.lineno);
267f9748e826 (no commit message)
one
parents:
diff changeset
144 command.setString(del);
267f9748e826 (no commit message)
one
parents:
diff changeset
145 }
267f9748e826 (no commit message)
one
parents:
diff changeset
146 forward(command);
267f9748e826 (no commit message)
one
parents:
diff changeset
147 break;
267f9748e826 (no commit message)
one
parents:
diff changeset
148 case REPCMD_INSERT:
267f9748e826 (no commit message)
one
parents:
diff changeset
149 if(command.eid != eid){
267f9748e826 (no commit message)
one
parents:
diff changeset
150 repText.insert(command.lineno, command.string);
267f9748e826 (no commit message)
one
parents:
diff changeset
151 }
267f9748e826 (no commit message)
one
parents:
diff changeset
152 forward(command);
267f9748e826 (no commit message)
one
parents:
diff changeset
153 break;
267f9748e826 (no commit message)
one
parents:
diff changeset
154 case REPCMD_NOP:
267f9748e826 (no commit message)
one
parents:
diff changeset
155 case REPCMD_INSERT_ACK:
267f9748e826 (no commit message)
one
parents:
diff changeset
156 case REPCMD_DELETE_ACK:
267f9748e826 (no commit message)
one
parents:
diff changeset
157 forward(command);
267f9748e826 (no commit message)
one
parents:
diff changeset
158 break;
267f9748e826 (no commit message)
one
parents:
diff changeset
159 case SMCMD_PUT_ACK:
267f9748e826 (no commit message)
one
parents:
diff changeset
160 sid = command.sid;
267f9748e826 (no commit message)
one
parents:
diff changeset
161 eid = command.eid;
267f9748e826 (no commit message)
one
parents:
diff changeset
162 name += "(eid="+eid+",sid="+sid+")";
267f9748e826 (no commit message)
one
parents:
diff changeset
163 inputLock = false;
267f9748e826 (no commit message)
one
parents:
diff changeset
164 break;
267f9748e826 (no commit message)
one
parents:
diff changeset
165 case SMCMD_JOIN_ACK :
267f9748e826 (no commit message)
one
parents:
diff changeset
166 sid = command.sid;
267f9748e826 (no commit message)
one
parents:
diff changeset
167 eid = command.eid;
267f9748e826 (no commit message)
one
parents:
diff changeset
168 name += "(eid="+eid+",sid="+sid+")";
267f9748e826 (no commit message)
one
parents:
diff changeset
169 inputLock = false;
267f9748e826 (no commit message)
one
parents:
diff changeset
170 break;
267f9748e826 (no commit message)
one
parents:
diff changeset
171 case SMCMD_START_MERGE :
267f9748e826 (no commit message)
one
parents:
diff changeset
172 // lock user input during merge (optional)
267f9748e826 (no commit message)
one
parents:
diff changeset
173 inputLock = hasInputLock;
267f9748e826 (no commit message)
one
parents:
diff changeset
174 command.cmd = REP.SMCMD_START_MERGE_ACK;
267f9748e826 (no commit message)
one
parents:
diff changeset
175 send(command);
267f9748e826 (no commit message)
one
parents:
diff changeset
176 break;
267f9748e826 (no commit message)
one
parents:
diff changeset
177 case SMCMD_END_MERGE :
267f9748e826 (no commit message)
one
parents:
diff changeset
178 inputLock = false;
267f9748e826 (no commit message)
one
parents:
diff changeset
179 break;
267f9748e826 (no commit message)
one
parents:
diff changeset
180 case SMCMD_SYNC:
267f9748e826 (no commit message)
one
parents:
diff changeset
181 // start contents sync with newly joined editor
267f9748e826 (no commit message)
one
parents:
diff changeset
182 command.cmd = REP.SMCMD_SYNC_ACK;
267f9748e826 (no commit message)
one
parents:
diff changeset
183 forward(command);
267f9748e826 (no commit message)
one
parents:
diff changeset
184 //if (cmd.eid==eid) {
267f9748e826 (no commit message)
one
parents:
diff changeset
185 if (master && syncEnable ) {
267f9748e826 (no commit message)
one
parents:
diff changeset
186 syncCounter = 1;
267f9748e826 (no commit message)
one
parents:
diff changeset
187 timeout = 1;
267f9748e826 (no commit message)
one
parents:
diff changeset
188 }
267f9748e826 (no commit message)
one
parents:
diff changeset
189 break;
267f9748e826 (no commit message)
one
parents:
diff changeset
190 }
267f9748e826 (no commit message)
one
parents:
diff changeset
191 }
267f9748e826 (no commit message)
one
parents:
diff changeset
192
267f9748e826 (no commit message)
one
parents:
diff changeset
193 private void userInput() {
267f9748e826 (no commit message)
one
parents:
diff changeset
194 Logger.print();
267f9748e826 (no commit message)
one
parents:
diff changeset
195 REPCommand command = userCommand.poll();
267f9748e826 (no commit message)
one
parents:
diff changeset
196 if(command != null){
267f9748e826 (no commit message)
one
parents:
diff changeset
197 switch(command.cmd){
267f9748e826 (no commit message)
one
parents:
diff changeset
198 case REPCMD_DELETE_USER:
267f9748e826 (no commit message)
one
parents:
diff changeset
199 send(command);
267f9748e826 (no commit message)
one
parents:
diff changeset
200 break;
267f9748e826 (no commit message)
one
parents:
diff changeset
201 case REPCMD_INSERT_USER:
267f9748e826 (no commit message)
one
parents:
diff changeset
202 send(command);
267f9748e826 (no commit message)
one
parents:
diff changeset
203 break;
267f9748e826 (no commit message)
one
parents:
diff changeset
204 case SMCMD_PUT:
267f9748e826 (no commit message)
one
parents:
diff changeset
205 case SMCMD_JOIN:
267f9748e826 (no commit message)
one
parents:
diff changeset
206 send(command);
267f9748e826 (no commit message)
one
parents:
diff changeset
207 break;
267f9748e826 (no commit message)
one
parents:
diff changeset
208 }
267f9748e826 (no commit message)
one
parents:
diff changeset
209 }else{
267f9748e826 (no commit message)
one
parents:
diff changeset
210 if(syncCounter == 0){
267f9748e826 (no commit message)
one
parents:
diff changeset
211 timeout = 0;
267f9748e826 (no commit message)
one
parents:
diff changeset
212 }
267f9748e826 (no commit message)
one
parents:
diff changeset
213 }
267f9748e826 (no commit message)
one
parents:
diff changeset
214 }
267f9748e826 (no commit message)
one
parents:
diff changeset
215
267f9748e826 (no commit message)
one
parents:
diff changeset
216 private void forward(REPCommand command) {
267f9748e826 (no commit message)
one
parents:
diff changeset
217 REPCommand cmd = new REPCommand(command);
267f9748e826 (no commit message)
one
parents:
diff changeset
218 channel.write(cmd);
267f9748e826 (no commit message)
one
parents:
diff changeset
219 }
267f9748e826 (no commit message)
one
parents:
diff changeset
220
267f9748e826 (no commit message)
one
parents:
diff changeset
221 private void send(REPCommand command) {
267f9748e826 (no commit message)
one
parents:
diff changeset
222 REPCommand cmd = new REPCommand(command);
267f9748e826 (no commit message)
one
parents:
diff changeset
223 cmd.setSEQID(seq++);
267f9748e826 (no commit message)
one
parents:
diff changeset
224 cmd.setEID(eid);
267f9748e826 (no commit message)
one
parents:
diff changeset
225 cmd.setSID(sid);
267f9748e826 (no commit message)
one
parents:
diff changeset
226 channel.write(cmd);
267f9748e826 (no commit message)
one
parents:
diff changeset
227 }
267f9748e826 (no commit message)
one
parents:
diff changeset
228
267f9748e826 (no commit message)
one
parents:
diff changeset
229 private void syncText() {
267f9748e826 (no commit message)
one
parents:
diff changeset
230 if(syncCounter>repText.size()){
267f9748e826 (no commit message)
one
parents:
diff changeset
231 syncCounter = 0;
267f9748e826 (no commit message)
one
parents:
diff changeset
232 }else {
267f9748e826 (no commit message)
one
parents:
diff changeset
233 if(inputLock) return;
267f9748e826 (no commit message)
one
parents:
diff changeset
234 int i = syncCounter - 1;
267f9748e826 (no commit message)
one
parents:
diff changeset
235 REPCommand del = new REPCommand(REP.REPCMD_DELETE_USER, sid, eid, 0, i, repText.get(i));
267f9748e826 (no commit message)
one
parents:
diff changeset
236 REPCommand ins = new REPCommand(REP.REPCMD_INSERT_USER, sid, eid, 0, i, repText.get(i));
267f9748e826 (no commit message)
one
parents:
diff changeset
237 send(del);
267f9748e826 (no commit message)
one
parents:
diff changeset
238 send(ins);
267f9748e826 (no commit message)
one
parents:
diff changeset
239 syncCounter++;
267f9748e826 (no commit message)
one
parents:
diff changeset
240 }
267f9748e826 (no commit message)
one
parents:
diff changeset
241 }
267f9748e826 (no commit message)
one
parents:
diff changeset
242
267f9748e826 (no commit message)
one
parents:
diff changeset
243 public void setLogTarget(LogTarget target){
267f9748e826 (no commit message)
one
parents:
diff changeset
244 logTarget = target;
267f9748e826 (no commit message)
one
parents:
diff changeset
245 }
267f9748e826 (no commit message)
one
parents:
diff changeset
246
267f9748e826 (no commit message)
one
parents:
diff changeset
247 }