annotate rep/translator/TranslatorImpl.java @ 330:ddfc786811b9

*** empty log message ***
author kono
date Sun, 12 Oct 2008 04:23:57 +0900
parents 7b6dede07f4a
children 36faf76a087c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
1 package rep.translator;
e235998427a6 try to fix merger
kono
parents:
diff changeset
2
e235998427a6 try to fix merger
kono
parents:
diff changeset
3 import java.util.Collection;
e235998427a6 try to fix merger
kono
parents:
diff changeset
4 import java.util.Comparator;
e235998427a6 try to fix merger
kono
parents:
diff changeset
5 import java.util.LinkedList;
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
6 import java.util.List;
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
7 import java.util.TreeSet;
e235998427a6 try to fix merger
kono
parents:
diff changeset
8
e235998427a6 try to fix merger
kono
parents:
diff changeset
9 import rep.Editor;
e235998427a6 try to fix merger
kono
parents:
diff changeset
10 import rep.Forwarder;
e235998427a6 try to fix merger
kono
parents:
diff changeset
11 import rep.REPCommand;
e235998427a6 try to fix merger
kono
parents:
diff changeset
12 import rep.REP;
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
13 import rep.optimizers.REPCommandOptimizer;
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
14
e235998427a6 try to fix merger
kono
parents:
diff changeset
15 public class TranslatorImpl implements Translator{
e235998427a6 try to fix merger
kono
parents:
diff changeset
16 public int eid;
e235998427a6 try to fix merger
kono
parents:
diff changeset
17 /*
e235998427a6 try to fix merger
kono
parents:
diff changeset
18 * queue が5つもいるって、あまりに馬鹿げてる。
e235998427a6 try to fix merger
kono
parents:
diff changeset
19 */
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
20 public REPCommandOptimizer optimizer;
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
21 private LinkedList<REPCommand> unMergedCmds;
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
22 public LinkedList<REPCommand> sentMergedList;
e235998427a6 try to fix merger
kono
parents:
diff changeset
23 private LinkedList<REPCommand> mergeAgainList;
e235998427a6 try to fix merger
kono
parents:
diff changeset
24 boolean merge_mode = false;
e235998427a6 try to fix merger
kono
parents:
diff changeset
25
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
26 public TranslatorImpl(int _eid,REPCommandOptimizer opt){
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
27 eid = _eid;
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
28 optimizer = opt;
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
29 unMergedCmds = new LinkedList<REPCommand>();
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
30 mergeAgainList = new LinkedList<REPCommand>();
e235998427a6 try to fix merger
kono
parents:
diff changeset
31 sentMergedList = new LinkedList<REPCommand>();
e235998427a6 try to fix merger
kono
parents:
diff changeset
32 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
33
e235998427a6 try to fix merger
kono
parents:
diff changeset
34 /**
e235998427a6 try to fix merger
kono
parents:
diff changeset
35 * New command from an editor
e235998427a6 try to fix merger
kono
parents:
diff changeset
36 * The command is sent to the next editor
e235998427a6 try to fix merger
kono
parents:
diff changeset
37 * @param cmd
e235998427a6 try to fix merger
kono
parents:
diff changeset
38 * @return translated command.
e235998427a6 try to fix merger
kono
parents:
diff changeset
39 */
e235998427a6 try to fix merger
kono
parents:
diff changeset
40 public REPCommand transSendCmd(REPCommand cmd){
327
7b6dede07f4a *** empty log message ***
kono
parents: 326
diff changeset
41 assert(cmd.eid==eid);
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
42 unMergedCmds.add(cmd);
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
43
e235998427a6 try to fix merger
kono
parents:
diff changeset
44 //マージ中にユーザから割り込みがあった場合
e235998427a6 try to fix merger
kono
parents:
diff changeset
45 if(isMerging()){
e235998427a6 try to fix merger
kono
parents:
diff changeset
46 mergeAgainList.add(cmd);
e235998427a6 try to fix merger
kono
parents:
diff changeset
47 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
48
e235998427a6 try to fix merger
kono
parents:
diff changeset
49 return cmd;
e235998427a6 try to fix merger
kono
parents:
diff changeset
50 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
51 /**
325
be0831086e63 *** empty log message ***
kono
parents: 324
diff changeset
52 * My command is returned from the session ring, and START_MERGE_ACK
be0831086e63 *** empty log message ***
kono
parents: 324
diff changeset
53 * is returned. At this
be0831086e63 *** empty log message ***
kono
parents: 324
diff changeset
54 * stage my writeQueue is empty, our editor is waiting for me.
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
55 * Start merge process.
e235998427a6 try to fix merger
kono
parents:
diff changeset
56 * @param cmd
e235998427a6 try to fix merger
kono
parents:
diff changeset
57 */
e235998427a6 try to fix merger
kono
parents:
diff changeset
58 public boolean catchOwnCommand(Editor editor){
e235998427a6 try to fix merger
kono
parents:
diff changeset
59 LinkedList<REPCommand> output = new LinkedList<REPCommand>();
e235998427a6 try to fix merger
kono
parents:
diff changeset
60 LinkedList<REPCommand> cmds = new LinkedList<REPCommand>();
e235998427a6 try to fix merger
kono
parents:
diff changeset
61 //スタック上にあるコマンドを全部undoコマンドにする
e235998427a6 try to fix merger
kono
parents:
diff changeset
62 while ( !unMergedCmds.isEmpty() ){
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
63 REPCommand cmd0 = unMergedCmds.removeLast();
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
64 output.add( createUndo(cmd0) );
e235998427a6 try to fix merger
kono
parents:
diff changeset
65 cmds.add(cmd0);
e235998427a6 try to fix merger
kono
parents:
diff changeset
66 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
67
e235998427a6 try to fix merger
kono
parents:
diff changeset
68 /* 必要な分だけソートして返却用のリストに追加 */
e235998427a6 try to fix merger
kono
parents:
diff changeset
69 output.addAll( sortCmds(cmds) );
e235998427a6 try to fix merger
kono
parents:
diff changeset
70
e235998427a6 try to fix merger
kono
parents:
diff changeset
71 /* 残ったコマンドも再び実行させるが、まだマージされてないのでunMergedにも入れる */
e235998427a6 try to fix merger
kono
parents:
diff changeset
72 output.addAll(cmds);
e235998427a6 try to fix merger
kono
parents:
diff changeset
73 for(REPCommand c: cmds) {
e235998427a6 try to fix merger
kono
parents:
diff changeset
74 output.add(c);
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
75 unMergedCmds.add(c);
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
76 }
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
77 return optimizedSend(editor,output);
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
78 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
79
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
80 /**
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
81 * Sent optimized merged command list
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
82 * @param editor
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
83 * @param output
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
84 * @return if any sent commands output
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
85 */
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
86 public boolean optimizedSend(Editor editor, LinkedList<REPCommand> output) {
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
87 List<REPCommand> output1 = optimizer.optimize(output);
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
88 if (output1.size()==0) {
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
89 merge_mode = false;
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
90 return false;
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
91 }
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
92 for(REPCommand c:output1) {
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
93 REPCommand m = new REPCommand(c);
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
94 m.setEID(REP.MERGE_EID.id);
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
95 m.setSEQID(editor.seq());
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
96 sentMergedList.add(m);
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
97 editor.send(m);
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
98 }
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
99 return true;
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
100 }
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
101
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
102 private REPCommand createUndo(REPCommand cmd){
e235998427a6 try to fix merger
kono
parents:
diff changeset
103 REPCommand retCmd = new REPCommand(cmd);
e235998427a6 try to fix merger
kono
parents:
diff changeset
104 if (cmd.cmd==REP.REPCMD_INSERT) retCmd.cmd=REP.REPCMD_DELETE;
e235998427a6 try to fix merger
kono
parents:
diff changeset
105 else if (cmd.cmd==REP.REPCMD_DELETE) retCmd.cmd=REP.REPCMD_INSERT;
e235998427a6 try to fix merger
kono
parents:
diff changeset
106 return retCmd;
e235998427a6 try to fix merger
kono
parents:
diff changeset
107 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
108
e235998427a6 try to fix merger
kono
parents:
diff changeset
109 class REPCommandComparator implements Comparator<REPCommand>{
e235998427a6 try to fix merger
kono
parents:
diff changeset
110
e235998427a6 try to fix merger
kono
parents:
diff changeset
111 public int compare(REPCommand o1, REPCommand o2) {
e235998427a6 try to fix merger
kono
parents:
diff changeset
112
e235998427a6 try to fix merger
kono
parents:
diff changeset
113 if ( o2.lineno > o1.lineno ) return 1;
e235998427a6 try to fix merger
kono
parents:
diff changeset
114 else if ( o2.lineno < o1.lineno
e235998427a6 try to fix merger
kono
parents:
diff changeset
115 || o2.eid > o1.eid )
e235998427a6 try to fix merger
kono
parents:
diff changeset
116 return -1;
e235998427a6 try to fix merger
kono
parents:
diff changeset
117
e235998427a6 try to fix merger
kono
parents:
diff changeset
118 return 1;
e235998427a6 try to fix merger
kono
parents:
diff changeset
119 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
120
e235998427a6 try to fix merger
kono
parents:
diff changeset
121 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
122
e235998427a6 try to fix merger
kono
parents:
diff changeset
123 private Collection<REPCommand> sortCmds(LinkedList<REPCommand> cmds) {
e235998427a6 try to fix merger
kono
parents:
diff changeset
124 TreeSet<REPCommand> sortedCmds1 = new TreeSet<REPCommand>(new REPCommandComparator());
e235998427a6 try to fix merger
kono
parents:
diff changeset
125 int top;
e235998427a6 try to fix merger
kono
parents:
diff changeset
126 int prevEid=-1;
e235998427a6 try to fix merger
kono
parents:
diff changeset
127 while ( -1 != (top=getPrecedence(cmds, prevEid+1)) ){
e235998427a6 try to fix merger
kono
parents:
diff changeset
128 REPCommand tmp = cmds.remove(top);
e235998427a6 try to fix merger
kono
parents:
diff changeset
129 sortedCmds1.add(tmp);
e235998427a6 try to fix merger
kono
parents:
diff changeset
130 prevEid = tmp.eid;
e235998427a6 try to fix merger
kono
parents:
diff changeset
131 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
132
e235998427a6 try to fix merger
kono
parents:
diff changeset
133 return sortedCmds1;
e235998427a6 try to fix merger
kono
parents:
diff changeset
134 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
135
e235998427a6 try to fix merger
kono
parents:
diff changeset
136 /* search cmd. ordering by min EID that is lower lowEid and min SEQ. */
e235998427a6 try to fix merger
kono
parents:
diff changeset
137 private int getPrecedence(LinkedList<REPCommand> cmds, int lowEid) {
e235998427a6 try to fix merger
kono
parents:
diff changeset
138 int cEid, cSeq;
e235998427a6 try to fix merger
kono
parents:
diff changeset
139 cEid=cSeq=Integer.MAX_VALUE;
e235998427a6 try to fix merger
kono
parents:
diff changeset
140 int ret=-1;
e235998427a6 try to fix merger
kono
parents:
diff changeset
141 for (int i=0; i<cmds.size(); i++){
e235998427a6 try to fix merger
kono
parents:
diff changeset
142 REPCommand c = cmds.get(i);
e235998427a6 try to fix merger
kono
parents:
diff changeset
143 if ( c.eid<lowEid ) continue;
e235998427a6 try to fix merger
kono
parents:
diff changeset
144 else if ( c.eid>cEid ) continue;
e235998427a6 try to fix merger
kono
parents:
diff changeset
145 else if ( c.eid==cEid ) {
e235998427a6 try to fix merger
kono
parents:
diff changeset
146 if ( c.seq>cSeq ) continue;
e235998427a6 try to fix merger
kono
parents:
diff changeset
147 cSeq=c.seq;
e235998427a6 try to fix merger
kono
parents:
diff changeset
148 ret = i;
e235998427a6 try to fix merger
kono
parents:
diff changeset
149 } else { /* tmp.eid<cEid */
e235998427a6 try to fix merger
kono
parents:
diff changeset
150 cEid = c.eid;
e235998427a6 try to fix merger
kono
parents:
diff changeset
151 cSeq = c.seq;
e235998427a6 try to fix merger
kono
parents:
diff changeset
152 ret = i;
e235998427a6 try to fix merger
kono
parents:
diff changeset
153 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
154 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
155 return ret;
e235998427a6 try to fix merger
kono
parents:
diff changeset
156 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
157
e235998427a6 try to fix merger
kono
parents:
diff changeset
158 /**
e235998427a6 try to fix merger
kono
parents:
diff changeset
159 * Translate Command cmd that was received from SeMa.
e235998427a6 try to fix merger
kono
parents:
diff changeset
160 * @param cmd the command to be translated.
e235998427a6 try to fix merger
kono
parents:
diff changeset
161 * @return translated commannd.
e235998427a6 try to fix merger
kono
parents:
diff changeset
162 */
e235998427a6 try to fix merger
kono
parents:
diff changeset
163 public void transReceiveCmd(Forwarder nextEditor,REPCommand cmd){
e235998427a6 try to fix merger
kono
parents:
diff changeset
164 assert (cmd.eid != eid);
e235998427a6 try to fix merger
kono
parents:
diff changeset
165 // nop command の挿入は Editor 側で行って、こちら側ではやらない
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
166 unMergedCmds.add(cmd);
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
167 nextEditor.send(cmd);
e235998427a6 try to fix merger
kono
parents:
diff changeset
168 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
169
e235998427a6 try to fix merger
kono
parents:
diff changeset
170 public void setEid(int _eid){
e235998427a6 try to fix merger
kono
parents:
diff changeset
171 eid = _eid;
e235998427a6 try to fix merger
kono
parents:
diff changeset
172 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
173
e235998427a6 try to fix merger
kono
parents:
diff changeset
174 public boolean checkMergeConflict(REPCommand command) {
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
175 REPCommand prev = sentMergedList.remove();
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
176 assert (prev.seq==command.seq);
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
177
e235998427a6 try to fix merger
kono
parents:
diff changeset
178 if(mergeAgainList.size() > 0){
e235998427a6 try to fix merger
kono
parents:
diff changeset
179 mergeAgainList.add(command);
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
180 return true;
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
181 }
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
182 if(sentMergedList.size()==0) {
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
183 merge_mode=false;
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
184 }
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
185 return false;
e235998427a6 try to fix merger
kono
parents:
diff changeset
186 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
187
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
188 public void getMergeAgain(Editor editor) {
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
189 LinkedList<REPCommand> returnCommand = new LinkedList<REPCommand>();
e235998427a6 try to fix merger
kono
parents:
diff changeset
190 for(int i = 0; i < mergeAgainList.size(); i++){
e235998427a6 try to fix merger
kono
parents:
diff changeset
191 //eid = REP.MEGE_EID
e235998427a6 try to fix merger
kono
parents:
diff changeset
192 returnCommand.add(createUndo(mergeAgainList.get(mergeAgainList.size() - i -1)));
e235998427a6 try to fix merger
kono
parents:
diff changeset
193 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
194 for(REPCommand command : mergeAgainList){
e235998427a6 try to fix merger
kono
parents:
diff changeset
195 if(command.eid == REP.MERGE_EID.id){
e235998427a6 try to fix merger
kono
parents:
diff changeset
196 returnCommand.add(command);
e235998427a6 try to fix merger
kono
parents:
diff changeset
197 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
198 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
199 for(REPCommand command : mergeAgainList){
e235998427a6 try to fix merger
kono
parents:
diff changeset
200 if(command.eid == eid){
e235998427a6 try to fix merger
kono
parents:
diff changeset
201 command.eid = REP.MERGE_EID.id;
e235998427a6 try to fix merger
kono
parents:
diff changeset
202 returnCommand.add(command);
e235998427a6 try to fix merger
kono
parents:
diff changeset
203 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
204 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
205 mergeAgainList.clear();
326
b1a6acf0b8a9 *** empty log message ***
kono
parents: 325
diff changeset
206 optimizedSend(editor, returnCommand);
324
e235998427a6 try to fix merger
kono
parents:
diff changeset
207 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
208
e235998427a6 try to fix merger
kono
parents:
diff changeset
209 public boolean isFinished() {
e235998427a6 try to fix merger
kono
parents:
diff changeset
210 if(unMergedCmds.size() > 0) return false;
e235998427a6 try to fix merger
kono
parents:
diff changeset
211 if(sentMergedList.size() > 0) return false;
e235998427a6 try to fix merger
kono
parents:
diff changeset
212 return true;
e235998427a6 try to fix merger
kono
parents:
diff changeset
213 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
214
e235998427a6 try to fix merger
kono
parents:
diff changeset
215 public boolean isMerging() {
e235998427a6 try to fix merger
kono
parents:
diff changeset
216 return merge_mode;
e235998427a6 try to fix merger
kono
parents:
diff changeset
217 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
218
e235998427a6 try to fix merger
kono
parents:
diff changeset
219 public void startMerge(REPCommand cmd) {
e235998427a6 try to fix merger
kono
parents:
diff changeset
220 merge_mode = true;
e235998427a6 try to fix merger
kono
parents:
diff changeset
221 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
222
e235998427a6 try to fix merger
kono
parents:
diff changeset
223 public void mergeAck() {
e235998427a6 try to fix merger
kono
parents:
diff changeset
224 }
e235998427a6 try to fix merger
kono
parents:
diff changeset
225
e235998427a6 try to fix merger
kono
parents:
diff changeset
226
e235998427a6 try to fix merger
kono
parents:
diff changeset
227
e235998427a6 try to fix merger
kono
parents:
diff changeset
228
e235998427a6 try to fix merger
kono
parents:
diff changeset
229 }