joachim99@8
|
1 /***************************************************************************
|
joachim99@8
|
2 mergeresultwindow.cpp - description
|
joachim99@8
|
3 -------------------
|
joachim99@8
|
4 begin : Sun Apr 14 2002
|
joachim99@77
|
5 copyright : (C) 2002-2007 by Joachim Eibl
|
joachim99@69
|
6 email : joachim.eibl at gmx.de
|
joachim99@8
|
7 ***************************************************************************/
|
joachim99@8
|
8
|
joachim99@8
|
9 /***************************************************************************
|
joachim99@8
|
10 * *
|
joachim99@8
|
11 * This program is free software; you can redistribute it and/or modify *
|
joachim99@8
|
12 * it under the terms of the GNU General Public License as published by *
|
joachim99@8
|
13 * the Free Software Foundation; either version 2 of the License, or *
|
joachim99@8
|
14 * (at your option) any later version. *
|
joachim99@8
|
15 * *
|
joachim99@8
|
16 ***************************************************************************/
|
joachim99@8
|
17
|
joachim99@69
|
18 #include "mergeresultwindow.h"
|
joachim99@69
|
19 #include "optiondialog.h"
|
joachim99@69
|
20
|
joachim99@75
|
21 #include <QPainter>
|
joachim99@75
|
22 #include <QApplication>
|
joachim99@75
|
23 #include <QClipboard>
|
joachim99@75
|
24 #include <QDir>
|
joachim99@75
|
25 #include <QFile>
|
joachim99@75
|
26 #include <QCursor>
|
joachim99@75
|
27 #include <QStatusBar>
|
joachim99@75
|
28 #include <QRegExp>
|
joachim99@70
|
29 #include <QTextStream>
|
joachim99@70
|
30 #include <QKeyEvent>
|
joachim99@70
|
31 #include <QMouseEvent>
|
joachim99@69
|
32
|
joachim99@75
|
33 #include <QLineEdit>
|
joachim99@75
|
34 #include <QTextCodec>
|
joachim99@75
|
35 #include <QComboBox>
|
joachim99@75
|
36 #include <QHBoxLayout>
|
joachim99@75
|
37 #include <QLabel>
|
joachim99@75
|
38 #include <QUrl>
|
joachim99@80
|
39 //Added by qt3to4:
|
joachim99@80
|
40 #include <QTimerEvent>
|
joachim99@80
|
41 #include <QResizeEvent>
|
joachim99@80
|
42 #include <QWheelEvent>
|
joachim99@80
|
43 #include <QPixmap>
|
joachim99@80
|
44 #include <QFocusEvent>
|
joachim99@80
|
45 #include <QEvent>
|
joachim99@80
|
46 #include <QInputEvent>
|
joachim99@80
|
47 #include <QDropEvent>
|
joachim99@80
|
48 #include <QPaintEvent>
|
joachim99@80
|
49 #include <QTextStream>
|
Chris@113
|
50 #include <QMimeData>
|
joachim99@75
|
51
|
joachim99@8
|
52 #include <klocale.h>
|
joachim99@8
|
53 #include <kmessagebox.h>
|
joachim99@58
|
54 #include <iostream>
|
joachim99@8
|
55
|
joachim99@8
|
56 int g_bAutoSolve = true;
|
joachim99@8
|
57
|
joachim99@53
|
58 #undef leftInfoWidth
|
joachim99@8
|
59 #define leftInfoWidth 3
|
joachim99@8
|
60
|
joachim99@8
|
61 MergeResultWindow::MergeResultWindow(
|
joachim99@8
|
62 QWidget* pParent,
|
joachim99@66
|
63 OptionDialog* pOptionDialog,
|
joachim99@66
|
64 QStatusBar* pStatusBar
|
joachim99@8
|
65 )
|
joachim99@75
|
66 : QWidget( pParent )
|
joachim99@8
|
67 {
|
joachim99@75
|
68 setObjectName( "MergeResultWindow" );
|
joachim99@70
|
69 setFocusPolicy( Qt::ClickFocus );
|
joachim99@8
|
70
|
joachim99@8
|
71 m_firstLine = 0;
|
joachim99@8
|
72 m_firstColumn = 0;
|
joachim99@8
|
73 m_nofColumns = 0;
|
joachim99@8
|
74 m_nofLines = 0;
|
joachim99@58
|
75 m_totalSize = 0;
|
joachim99@8
|
76 m_bMyUpdate = false;
|
joachim99@8
|
77 m_bInsertMode = true;
|
joachim99@8
|
78 m_scrollDeltaX = 0;
|
joachim99@8
|
79 m_scrollDeltaY = 0;
|
joachim99@8
|
80 m_bModified = false;
|
joachim99@69
|
81 m_eOverviewMode=Overview::eOMNormal;
|
joachim99@8
|
82
|
joachim99@8
|
83 m_pldA = 0;
|
joachim99@8
|
84 m_pldB = 0;
|
joachim99@8
|
85 m_pldC = 0;
|
joachim99@69
|
86 m_sizeA = 0;
|
joachim99@69
|
87 m_sizeB = 0;
|
joachim99@69
|
88 m_sizeC = 0;
|
joachim99@8
|
89
|
joachim99@8
|
90 m_pDiff3LineList = 0;
|
joachim99@8
|
91 m_pTotalDiffStatus = 0;
|
joachim99@66
|
92 m_pStatusBar = pStatusBar;
|
joachim99@58
|
93
|
joachim99@8
|
94 m_pOptionDialog = pOptionDialog;
|
joachim99@58
|
95 m_bPaintingAllowed = false;
|
joachim99@69
|
96 m_delayedDrawTimer = 0;
|
joachim99@8
|
97
|
joachim99@8
|
98 m_cursorXPos=0;
|
joachim99@8
|
99 m_cursorOldXPos=0;
|
joachim99@8
|
100 m_cursorYPos=0;
|
joachim99@8
|
101 m_bCursorOn = true;
|
joachim99@69
|
102 m_bCursorUpdate = false;
|
joachim99@8
|
103 connect( &m_cursorTimer, SIGNAL(timeout()), this, SLOT( slotCursorUpdate() ) );
|
joachim99@75
|
104 m_cursorTimer.setSingleShot(true);
|
joachim99@75
|
105 m_cursorTimer.start( 500 /*ms*/ );
|
joachim99@8
|
106 m_selection.reset();
|
joachim99@8
|
107
|
joachim99@8
|
108 setMinimumSize( QSize(20,20) );
|
joachim99@27
|
109 setFont( m_pOptionDialog->m_font );
|
joachim99@8
|
110 }
|
joachim99@8
|
111
|
joachim99@8
|
112 void MergeResultWindow::init(
|
joachim99@69
|
113 const LineData* pLineDataA, int sizeA,
|
joachim99@69
|
114 const LineData* pLineDataB, int sizeB,
|
joachim99@69
|
115 const LineData* pLineDataC, int sizeC,
|
joachim99@8
|
116 const Diff3LineList* pDiff3LineList,
|
joachim99@75
|
117 TotalDiffStatus* pTotalDiffStatus
|
joachim99@8
|
118 )
|
joachim99@8
|
119 {
|
joachim99@8
|
120 m_firstLine = 0;
|
joachim99@8
|
121 m_firstColumn = 0;
|
joachim99@8
|
122 m_nofColumns = 0;
|
joachim99@8
|
123 m_nofLines = 0;
|
joachim99@8
|
124 m_bMyUpdate = false;
|
joachim99@8
|
125 m_bInsertMode = true;
|
joachim99@8
|
126 m_scrollDeltaX = 0;
|
joachim99@8
|
127 m_scrollDeltaY = 0;
|
joachim99@75
|
128 setModified( false );
|
joachim99@8
|
129
|
joachim99@8
|
130 m_pldA = pLineDataA;
|
joachim99@8
|
131 m_pldB = pLineDataB;
|
joachim99@8
|
132 m_pldC = pLineDataC;
|
joachim99@69
|
133 m_sizeA = sizeA;
|
joachim99@69
|
134 m_sizeB = sizeB;
|
joachim99@69
|
135 m_sizeC = sizeC;
|
joachim99@8
|
136
|
joachim99@8
|
137 m_pDiff3LineList = pDiff3LineList;
|
joachim99@8
|
138 m_pTotalDiffStatus = pTotalDiffStatus;
|
joachim99@8
|
139
|
joachim99@8
|
140 m_selection.reset();
|
joachim99@8
|
141 m_cursorXPos=0;
|
joachim99@8
|
142 m_cursorOldXPos=0;
|
joachim99@8
|
143 m_cursorYPos=0;
|
joachim99@8
|
144
|
joachim99@8
|
145 merge( g_bAutoSolve, -1 );
|
joachim99@8
|
146 g_bAutoSolve = true;
|
joachim99@8
|
147 update();
|
joachim99@66
|
148 updateSourceMask();
|
joachim99@68
|
149
|
joachim99@68
|
150 int wsc;
|
joachim99@69
|
151 int nofUnsolved = getNrOfUnsolvedConflicts(&wsc);
|
joachim99@73
|
152 if (m_pStatusBar)
|
joachim99@80
|
153 m_pStatusBar->showMessage( i18n("Number of remaining unsolved conflicts: %1 (of which %2 are whitespace)"
|
joachim99@80
|
154 ,nofUnsolved,wsc) );
|
joachim99@8
|
155 }
|
joachim99@8
|
156
|
joachim99@69
|
157 void MergeResultWindow::reset()
|
joachim99@69
|
158 {
|
joachim99@69
|
159 m_pDiff3LineList = 0;
|
joachim99@69
|
160 m_pTotalDiffStatus = 0;
|
joachim99@69
|
161 m_pldA = 0;
|
joachim99@69
|
162 m_pldB = 0;
|
joachim99@69
|
163 m_pldC = 0;
|
joachim99@69
|
164 }
|
joachim99@8
|
165
|
joachim99@8
|
166 // Calculate the merge information for the given Diff3Line.
|
joachim99@8
|
167 // Results will be stored in mergeDetails, bConflict, bLineRemoved and src.
|
joachim99@8
|
168 void mergeOneLine(
|
joachim99@8
|
169 const Diff3Line& d, e_MergeDetails& mergeDetails, bool& bConflict,
|
joachim99@8
|
170 bool& bLineRemoved, int& src, bool bTwoInputs
|
joachim99@8
|
171 )
|
joachim99@8
|
172 {
|
joachim99@8
|
173 mergeDetails = eDefault;
|
joachim99@8
|
174 bConflict = false;
|
joachim99@8
|
175 bLineRemoved = false;
|
joachim99@8
|
176 src = 0;
|
joachim99@8
|
177
|
joachim99@8
|
178 if ( bTwoInputs ) // Only two input files
|
joachim99@8
|
179 {
|
joachim99@8
|
180 if ( d.lineA!=-1 && d.lineB!=-1 )
|
joachim99@8
|
181 {
|
joachim99@8
|
182 if ( d.pFineAB == 0 )
|
joachim99@8
|
183 {
|
joachim99@8
|
184 mergeDetails = eNoChange; src = A;
|
joachim99@8
|
185 }
|
joachim99@8
|
186 else
|
joachim99@8
|
187 {
|
joachim99@8
|
188 mergeDetails = eBChanged; bConflict = true;
|
joachim99@8
|
189 }
|
joachim99@8
|
190 }
|
joachim99@8
|
191 else
|
joachim99@8
|
192 {
|
joachim99@8
|
193 if ( d.lineA!=-1 && d.lineB==-1 )
|
joachim99@8
|
194 {
|
joachim99@8
|
195 mergeDetails = eBDeleted; bConflict = true;
|
joachim99@8
|
196 }
|
joachim99@8
|
197 else if ( d.lineA==-1 && d.lineB!=-1 )
|
joachim99@8
|
198 {
|
joachim99@8
|
199 mergeDetails = eBDeleted; bConflict = true;
|
joachim99@8
|
200 }
|
joachim99@8
|
201 }
|
joachim99@8
|
202 return;
|
joachim99@8
|
203 }
|
joachim99@8
|
204
|
joachim99@8
|
205 // A is base.
|
joachim99@8
|
206 if ( d.lineA!=-1 && d.lineB!=-1 && d.lineC!=-1 )
|
joachim99@8
|
207 {
|
joachim99@8
|
208 if ( d.pFineAB == 0 && d.pFineBC == 0 && d.pFineCA == 0)
|
joachim99@8
|
209 {
|
joachim99@8
|
210 mergeDetails = eNoChange; src = A;
|
joachim99@8
|
211 }
|
joachim99@8
|
212 else if( d.pFineAB == 0 && d.pFineBC != 0 && d.pFineCA != 0 )
|
joachim99@8
|
213 {
|
joachim99@8
|
214 mergeDetails = eCChanged; src = C;
|
joachim99@8
|
215 }
|
joachim99@8
|
216 else if( d.pFineAB != 0 && d.pFineBC != 0 && d.pFineCA == 0 )
|
joachim99@8
|
217 {
|
joachim99@8
|
218 mergeDetails = eBChanged; src = B;
|
joachim99@8
|
219 }
|
joachim99@8
|
220 else if( d.pFineAB != 0 && d.pFineBC == 0 && d.pFineCA != 0 )
|
joachim99@8
|
221 {
|
joachim99@8
|
222 mergeDetails = eBCChangedAndEqual; src = C;
|
joachim99@8
|
223 }
|
joachim99@8
|
224 else if( d.pFineAB != 0 && d.pFineBC != 0 && d.pFineCA != 0 )
|
joachim99@8
|
225 {
|
joachim99@8
|
226 mergeDetails = eBCChanged; bConflict = true;
|
joachim99@8
|
227 }
|
joachim99@8
|
228 else
|
joachim99@8
|
229 assert(false);
|
joachim99@8
|
230 }
|
joachim99@8
|
231 else if ( d.lineA!=-1 && d.lineB!=-1 && d.lineC==-1 )
|
joachim99@8
|
232 {
|
joachim99@8
|
233 if( d.pFineAB != 0 )
|
joachim99@8
|
234 {
|
joachim99@8
|
235 mergeDetails = eBChanged_CDeleted; bConflict = true;
|
joachim99@8
|
236 }
|
joachim99@8
|
237 else
|
joachim99@8
|
238 {
|
joachim99@8
|
239 mergeDetails = eCDeleted; bLineRemoved = true; src = C;
|
joachim99@8
|
240 }
|
joachim99@8
|
241 }
|
joachim99@8
|
242 else if ( d.lineA!=-1 && d.lineB==-1 && d.lineC!=-1 )
|
joachim99@8
|
243 {
|
joachim99@8
|
244 if( d.pFineCA != 0 )
|
joachim99@8
|
245 {
|
joachim99@8
|
246 mergeDetails = eCChanged_BDeleted; bConflict = true;
|
joachim99@8
|
247 }
|
joachim99@8
|
248 else
|
joachim99@8
|
249 {
|
joachim99@8
|
250 mergeDetails = eBDeleted; bLineRemoved = true; src = B;
|
joachim99@8
|
251 }
|
joachim99@8
|
252 }
|
joachim99@8
|
253 else if ( d.lineA==-1 && d.lineB!=-1 && d.lineC!=-1 )
|
joachim99@8
|
254 {
|
joachim99@8
|
255 if( d.pFineBC != 0 )
|
joachim99@8
|
256 {
|
joachim99@8
|
257 mergeDetails = eBCAdded; bConflict = true;
|
joachim99@8
|
258 }
|
joachim99@8
|
259 else // B==C
|
joachim99@8
|
260 {
|
joachim99@8
|
261 mergeDetails = eBCAddedAndEqual; src = C;
|
joachim99@8
|
262 }
|
joachim99@8
|
263 }
|
joachim99@8
|
264 else if ( d.lineA==-1 && d.lineB==-1 && d.lineC!= -1 )
|
joachim99@8
|
265 {
|
joachim99@8
|
266 mergeDetails = eCAdded; src = C;
|
joachim99@8
|
267 }
|
joachim99@8
|
268 else if ( d.lineA==-1 && d.lineB!=-1 && d.lineC== -1 )
|
joachim99@8
|
269 {
|
joachim99@8
|
270 mergeDetails = eBAdded; src = B;
|
joachim99@8
|
271 }
|
joachim99@8
|
272 else if ( d.lineA!=-1 && d.lineB==-1 && d.lineC==-1 )
|
joachim99@8
|
273 {
|
joachim99@8
|
274 mergeDetails = eBCDeleted; bLineRemoved = true; src = C;
|
joachim99@8
|
275 }
|
joachim99@8
|
276 else
|
joachim99@8
|
277 assert(false);
|
joachim99@8
|
278 }
|
joachim99@8
|
279
|
joachim99@8
|
280 bool MergeResultWindow::sameKindCheck( const MergeLine& ml1, const MergeLine& ml2 )
|
joachim99@8
|
281 {
|
joachim99@8
|
282 if ( ml1.bConflict && ml2.bConflict )
|
joachim99@8
|
283 {
|
joachim99@51
|
284 // Both lines have conflicts: If one is only a white space conflict and
|
joachim99@51
|
285 // the other one is a real conflict, then this line returns false.
|
joachim99@8
|
286 return ml1.id3l->bAEqC == ml2.id3l->bAEqC && ml1.id3l->bAEqB == ml2.id3l->bAEqB;
|
joachim99@8
|
287 }
|
joachim99@8
|
288 else
|
joachim99@8
|
289 return (
|
joachim99@103
|
290 !ml1.bConflict && !ml2.bConflict && ml1.bDelta && ml2.bDelta && ml1.srcSelect == ml2.srcSelect
|
joachim99@103
|
291 && (ml1.mergeDetails==ml2.mergeDetails || ml1.mergeDetails!=eBCAddedAndEqual && ml2.mergeDetails!=eBCAddedAndEqual )
|
joachim99@103
|
292 ||
|
joachim99@8
|
293 !ml1.bDelta && !ml2.bDelta
|
joachim99@8
|
294 );
|
joachim99@8
|
295 }
|
joachim99@8
|
296
|
joachim99@51
|
297 void MergeResultWindow::merge(bool bAutoSolve, int defaultSelector, bool bConflictsOnly, bool bWhiteSpaceOnly )
|
joachim99@51
|
298 {
|
joachim99@51
|
299 if ( !bConflictsOnly )
|
joachim99@8
|
300 {
|
joachim99@51
|
301 if(m_bModified)
|
joachim99@8
|
302 {
|
joachim99@51
|
303 int result = KMessageBox::warningYesNo(this,
|
joachim99@51
|
304 i18n("The output has been modified.\n"
|
joachim99@51
|
305 "If you continue your changes will be lost."),
|
joachim99@80
|
306 i18n("Warning"),
|
joachim99@80
|
307 KStandardGuiItem::cont(),
|
joachim99@80
|
308 KStandardGuiItem::cancel());
|
joachim99@51
|
309 if ( result==KMessageBox::No )
|
joachim99@51
|
310 return;
|
joachim99@8
|
311 }
|
joachim99@8
|
312
|
joachim99@51
|
313 m_mergeLineList.clear();
|
joachim99@58
|
314 m_totalSize = 0;
|
joachim99@51
|
315 int lineIdx = 0;
|
joachim99@51
|
316 Diff3LineList::const_iterator it;
|
joachim99@51
|
317 for( it=m_pDiff3LineList->begin(); it!=m_pDiff3LineList->end(); ++it, ++lineIdx )
|
joachim99@8
|
318 {
|
joachim99@51
|
319 const Diff3Line& d = *it;
|
joachim99@51
|
320
|
joachim99@51
|
321 MergeLine ml;
|
joachim99@51
|
322 bool bLineRemoved;
|
joachim99@51
|
323 mergeOneLine( d, ml.mergeDetails, ml.bConflict, bLineRemoved, ml.srcSelect, m_pldC==0 );
|
joachim99@51
|
324
|
joachim99@51
|
325 // Automatic solving for only whitespace changes.
|
joachim99@51
|
326 if ( ml.bConflict &&
|
joachim99@51
|
327 ( m_pldC==0 && (d.bAEqB || d.bWhiteLineA && d.bWhiteLineB) ||
|
joachim99@51
|
328 m_pldC!=0 && (d.bAEqB && d.bAEqC || d.bWhiteLineA && d.bWhiteLineB && d.bWhiteLineC ) ) )
|
joachim99@51
|
329 {
|
joachim99@51
|
330 ml.bWhiteSpaceConflict = true;
|
joachim99@51
|
331 }
|
joachim99@51
|
332
|
joachim99@51
|
333 ml.d3lLineIdx = lineIdx;
|
joachim99@51
|
334 ml.bDelta = ml.srcSelect != A;
|
joachim99@51
|
335 ml.id3l = it;
|
joachim99@51
|
336 ml.srcRangeLength = 1;
|
joachim99@51
|
337
|
joachim99@51
|
338 MergeLine* back = m_mergeLineList.empty() ? 0 : &m_mergeLineList.back();
|
joachim99@51
|
339
|
joachim99@51
|
340 bool bSame = back!=0 && sameKindCheck( ml, *back );
|
joachim99@51
|
341 if( bSame )
|
joachim99@51
|
342 {
|
joachim99@51
|
343 ++back->srcRangeLength;
|
joachim99@51
|
344 if ( back->bWhiteSpaceConflict && !ml.bWhiteSpaceConflict )
|
joachim99@51
|
345 back->bWhiteSpaceConflict = false;
|
joachim99@51
|
346 }
|
joachim99@51
|
347 else
|
joachim99@51
|
348 {
|
joachim99@51
|
349 if (back!=0 && back->bWhiteSpaceConflict )
|
joachim99@51
|
350 {
|
joachim99@51
|
351 if ( m_pldC==0 && m_pOptionDialog->m_whiteSpace2FileMergeDefault != 0 ) // Only two inputs
|
joachim99@51
|
352 {
|
joachim99@51
|
353 back->srcSelect = m_pOptionDialog->m_whiteSpace2FileMergeDefault;
|
joachim99@51
|
354 back->bConflict = false;
|
joachim99@51
|
355 }
|
joachim99@51
|
356 else if ( m_pldC!=0 && m_pOptionDialog->m_whiteSpace3FileMergeDefault != 0 )
|
joachim99@51
|
357 {
|
joachim99@51
|
358 back->srcSelect = m_pOptionDialog->m_whiteSpace3FileMergeDefault;
|
joachim99@51
|
359 back->bConflict = false;
|
joachim99@51
|
360 }
|
joachim99@51
|
361 }
|
joachim99@58
|
362 ml.mergeEditLineList.setTotalSizePtr(&m_totalSize);
|
joachim99@51
|
363 m_mergeLineList.push_back( ml );
|
joachim99@51
|
364 }
|
joachim99@51
|
365
|
joachim99@51
|
366 if ( ! ml.bConflict )
|
joachim99@51
|
367 {
|
joachim99@51
|
368 MergeLine& tmpBack = m_mergeLineList.back();
|
joachim99@69
|
369 MergeEditLine mel(ml.id3l);
|
joachim99@69
|
370 mel.setSource( ml.srcSelect, bLineRemoved );
|
joachim99@51
|
371 tmpBack.mergeEditLineList.push_back(mel);
|
joachim99@51
|
372 }
|
joachim99@51
|
373 else if ( back==0 || ! back->bConflict || !bSame )
|
joachim99@51
|
374 {
|
joachim99@51
|
375 MergeLine& tmpBack = m_mergeLineList.back();
|
joachim99@69
|
376 MergeEditLine mel(ml.id3l);
|
joachim99@51
|
377 mel.setConflict();
|
joachim99@51
|
378 tmpBack.mergeEditLineList.push_back(mel);
|
joachim99@51
|
379 }
|
joachim99@8
|
380 }
|
joachim99@8
|
381 }
|
joachim99@8
|
382
|
joachim99@8
|
383 if ( !bAutoSolve )
|
joachim99@8
|
384 {
|
joachim99@8
|
385 // Change all auto selections
|
joachim99@8
|
386 MergeLineList::iterator mlIt;
|
joachim99@8
|
387 for( mlIt=m_mergeLineList.begin(); mlIt!=m_mergeLineList.end(); ++mlIt )
|
joachim99@8
|
388 {
|
joachim99@8
|
389 MergeLine& ml = *mlIt;
|
joachim99@51
|
390 bool bConflict = ml.mergeEditLineList.empty() || ml.mergeEditLineList.begin()->isConflict();
|
joachim99@51
|
391 if ( ml.bDelta && ( !bConflictsOnly || bConflict ) && (!bWhiteSpaceOnly || ml.bWhiteSpaceConflict ))
|
joachim99@8
|
392 {
|
joachim99@8
|
393 ml.mergeEditLineList.clear();
|
joachim99@8
|
394 if ( defaultSelector==-1 && ml.bDelta )
|
joachim99@8
|
395 {
|
joachim99@69
|
396 MergeEditLine mel(ml.id3l);;
|
joachim99@8
|
397 mel.setConflict();
|
joachim99@8
|
398 ml.bConflict = true;
|
joachim99@8
|
399 ml.mergeEditLineList.push_back(mel);
|
joachim99@8
|
400 }
|
joachim99@8
|
401 else
|
joachim99@8
|
402 {
|
joachim99@8
|
403 Diff3LineList::const_iterator d3llit=ml.id3l;
|
joachim99@8
|
404 int j;
|
joachim99@8
|
405
|
joachim99@8
|
406 for( j=0; j<ml.srcRangeLength; ++j )
|
joachim99@8
|
407 {
|
joachim99@69
|
408 MergeEditLine mel(d3llit);
|
joachim99@69
|
409 mel.setSource( defaultSelector, false );
|
joachim99@51
|
410
|
joachim99@8
|
411 int srcLine = defaultSelector==1 ? d3llit->lineA :
|
joachim99@8
|
412 defaultSelector==2 ? d3llit->lineB :
|
joachim99@8
|
413 defaultSelector==3 ? d3llit->lineC : -1;
|
joachim99@51
|
414
|
joachim99@8
|
415 if ( srcLine != -1 )
|
joachim99@8
|
416 {
|
joachim99@8
|
417 ml.mergeEditLineList.push_back(mel);
|
joachim99@8
|
418 }
|
joachim99@8
|
419
|
joachim99@8
|
420 ++d3llit;
|
joachim99@8
|
421 }
|
joachim99@8
|
422
|
joachim99@8
|
423 if ( ml.mergeEditLineList.empty() ) // Make a line nevertheless
|
joachim99@8
|
424 {
|
joachim99@69
|
425 MergeEditLine mel(ml.id3l);
|
joachim99@8
|
426 mel.setRemoved( defaultSelector );
|
joachim99@8
|
427 ml.mergeEditLineList.push_back(mel);
|
joachim99@8
|
428 }
|
joachim99@8
|
429 }
|
joachim99@8
|
430 }
|
joachim99@8
|
431 }
|
joachim99@8
|
432 }
|
joachim99@8
|
433
|
joachim99@8
|
434 MergeLineList::iterator mlIt;
|
joachim99@8
|
435 for( mlIt=m_mergeLineList.begin(); mlIt!=m_mergeLineList.end(); ++mlIt )
|
joachim99@8
|
436 {
|
joachim99@8
|
437 MergeLine& ml = *mlIt;
|
joachim99@8
|
438 // Remove all lines that are empty, because no src lines are there.
|
joachim99@8
|
439
|
joachim99@8
|
440 int oldSrcLine = -1;
|
joachim99@8
|
441 int oldSrc = -1;
|
joachim99@8
|
442 MergeEditLineList::iterator melIt;
|
joachim99@8
|
443 for( melIt = ml.mergeEditLineList.begin(); melIt != ml.mergeEditLineList.end(); )
|
joachim99@8
|
444 {
|
joachim99@8
|
445 MergeEditLine& mel = *melIt;
|
joachim99@8
|
446 int melsrc = mel.src();
|
joachim99@8
|
447
|
joachim99@69
|
448 int srcLine = mel.isRemoved() ? -1 :
|
joachim99@69
|
449 melsrc==1 ? mel.id3l()->lineA :
|
joachim99@8
|
450 melsrc==2 ? mel.id3l()->lineB :
|
joachim99@8
|
451 melsrc==3 ? mel.id3l()->lineC : -1;
|
joachim99@8
|
452
|
joachim99@69
|
453 // At least one line remains because oldSrc != melsrc for first line in list
|
joachim99@69
|
454 // Other empty lines will be removed
|
joachim99@8
|
455 if ( srcLine == -1 && oldSrcLine==-1 && oldSrc == melsrc )
|
joachim99@8
|
456 melIt = ml.mergeEditLineList.erase( melIt );
|
joachim99@8
|
457 else
|
joachim99@8
|
458 ++melIt;
|
joachim99@8
|
459
|
joachim99@8
|
460 oldSrcLine = srcLine;
|
joachim99@8
|
461 oldSrc = melsrc;
|
joachim99@8
|
462 }
|
joachim99@8
|
463 }
|
joachim99@8
|
464
|
joachim99@69
|
465 if ( bAutoSolve && !bConflictsOnly )
|
joachim99@69
|
466 {
|
joachim99@69
|
467 if ( m_pOptionDialog->m_bRunHistoryAutoMergeOnMergeStart )
|
joachim99@69
|
468 slotMergeHistory();
|
joachim99@69
|
469 if ( m_pOptionDialog->m_bRunRegExpAutoMergeOnMergeStart )
|
joachim99@69
|
470 slotRegExpAutoMerge();
|
joachim99@69
|
471 if ( m_pldC != 0 && ! doRelevantChangesExist() )
|
joachim99@69
|
472 emit noRelevantChangesDetected();
|
joachim99@69
|
473 }
|
joachim99@69
|
474
|
joachim99@66
|
475 int nrOfSolvedConflicts = 0;
|
joachim99@66
|
476 int nrOfUnsolvedConflicts = 0;
|
joachim99@66
|
477 int nrOfWhiteSpaceConflicts = 0;
|
joachim99@66
|
478
|
joachim99@66
|
479 MergeLineList::iterator i;
|
joachim99@66
|
480 for ( i = m_mergeLineList.begin(); i!=m_mergeLineList.end(); ++i )
|
joachim99@66
|
481 {
|
joachim99@66
|
482 if ( i->bConflict )
|
joachim99@66
|
483 ++nrOfUnsolvedConflicts;
|
joachim99@66
|
484 else if ( i->bDelta )
|
joachim99@66
|
485 ++nrOfSolvedConflicts;
|
joachim99@68
|
486
|
joachim99@66
|
487 if ( i->bWhiteSpaceConflict )
|
joachim99@66
|
488 ++nrOfWhiteSpaceConflicts;
|
joachim99@66
|
489 }
|
joachim99@68
|
490
|
joachim99@66
|
491 m_pTotalDiffStatus->nofUnsolvedConflicts = nrOfUnsolvedConflicts;
|
joachim99@66
|
492 m_pTotalDiffStatus->nofSolvedConflicts = nrOfSolvedConflicts;
|
joachim99@66
|
493 m_pTotalDiffStatus->nofWhitespaceConflicts = nrOfWhiteSpaceConflicts;
|
joachim99@66
|
494
|
joachim99@66
|
495
|
joachim99@8
|
496 m_cursorXPos=0;
|
joachim99@8
|
497 m_cursorOldXPos=0;
|
joachim99@8
|
498 m_cursorYPos=0;
|
joachim99@66
|
499 //m_firstLine = 0; // Must not set line/column without scrolling there
|
joachim99@66
|
500 //m_firstColumn = 0;
|
joachim99@51
|
501
|
joachim99@75
|
502 setModified(false);
|
joachim99@66
|
503
|
joachim99@66
|
504 m_currentMergeLineIt = m_mergeLineList.begin();
|
joachim99@66
|
505 slotGoTop();
|
joachim99@66
|
506
|
joachim99@8
|
507 updateAvailabilities();
|
joachim99@8
|
508 update();
|
joachim99@8
|
509 }
|
joachim99@8
|
510
|
joachim99@8
|
511 void MergeResultWindow::setFirstLine(int firstLine)
|
joachim99@8
|
512 {
|
joachim99@8
|
513 m_firstLine = max2(0,firstLine);
|
joachim99@8
|
514 update();
|
joachim99@8
|
515 }
|
joachim99@8
|
516
|
joachim99@8
|
517 void MergeResultWindow::setFirstColumn(int firstCol)
|
joachim99@8
|
518 {
|
joachim99@8
|
519 m_firstColumn = max2(0,firstCol);
|
joachim99@8
|
520 update();
|
joachim99@8
|
521 }
|
joachim99@8
|
522
|
joachim99@8
|
523 int MergeResultWindow::getNofColumns()
|
joachim99@8
|
524 {
|
joachim99@8
|
525 return m_nofColumns;
|
joachim99@8
|
526 }
|
joachim99@8
|
527
|
joachim99@8
|
528 int MergeResultWindow::getNofLines()
|
joachim99@8
|
529 {
|
joachim99@58
|
530 return m_totalSize;
|
joachim99@8
|
531 }
|
joachim99@8
|
532
|
joachim99@8
|
533 int MergeResultWindow::getNofVisibleColumns()
|
joachim99@8
|
534 {
|
joachim99@8
|
535 QFontMetrics fm = fontMetrics();
|
joachim99@8
|
536 return width()/fm.width('W')-4;
|
joachim99@8
|
537 }
|
joachim99@8
|
538
|
joachim99@8
|
539 int MergeResultWindow::getNofVisibleLines()
|
joachim99@8
|
540 {
|
joachim99@8
|
541 QFontMetrics fm = fontMetrics();
|
joachim99@8
|
542 return (height()-3)/fm.height()-2;
|
joachim99@8
|
543 }
|
joachim99@8
|
544
|
joachim99@8
|
545 void MergeResultWindow::resizeEvent( QResizeEvent* e )
|
joachim99@8
|
546 {
|
joachim99@8
|
547 QWidget::resizeEvent(e);
|
joachim99@8
|
548 emit resizeSignal();
|
joachim99@8
|
549 }
|
joachim99@8
|
550
|
joachim99@69
|
551 Overview::e_OverviewMode MergeResultWindow::getOverviewMode()
|
joachim99@69
|
552 {
|
joachim99@69
|
553 return m_eOverviewMode;
|
joachim99@69
|
554 }
|
joachim99@69
|
555
|
joachim99@69
|
556 void MergeResultWindow::setOverviewMode( Overview::e_OverviewMode eOverviewMode )
|
joachim99@69
|
557 {
|
joachim99@69
|
558 m_eOverviewMode = eOverviewMode;
|
joachim99@69
|
559 }
|
joachim99@69
|
560
|
joachim99@69
|
561 // Check whether we should ignore current delta when moving to next/previous delta
|
joachim99@69
|
562 bool MergeResultWindow::checkOverviewIgnore(MergeLineList::iterator &i)
|
joachim99@69
|
563 {
|
joachim99@69
|
564 if (m_eOverviewMode == Overview::eOMNormal) return false;
|
joachim99@69
|
565 if (m_eOverviewMode == Overview::eOMAvsB)
|
joachim99@69
|
566 return i->mergeDetails == eCAdded || i->mergeDetails == eCDeleted || i->mergeDetails == eCChanged;
|
joachim99@69
|
567 if (m_eOverviewMode == Overview::eOMAvsC)
|
joachim99@69
|
568 return i->mergeDetails == eBAdded || i->mergeDetails == eBDeleted || i->mergeDetails == eBChanged;
|
joachim99@69
|
569 if (m_eOverviewMode == Overview::eOMBvsC)
|
joachim99@69
|
570 return i->mergeDetails == eBCAddedAndEqual || i->mergeDetails == eBCDeleted || i->mergeDetails == eBCChangedAndEqual;
|
joachim99@69
|
571 return false;
|
joachim99@69
|
572 }
|
joachim99@69
|
573
|
joachim99@8
|
574 // Go to prev/next delta/conflict or first/last delta.
|
joachim99@8
|
575 void MergeResultWindow::go( e_Direction eDir, e_EndPoint eEndPoint )
|
joachim99@8
|
576 {
|
joachim99@8
|
577 assert( eDir==eUp || eDir==eDown );
|
joachim99@8
|
578 MergeLineList::iterator i = m_currentMergeLineIt;
|
joachim99@51
|
579 bool bSkipWhiteConflicts = ! m_pOptionDialog->m_bShowWhiteSpace;
|
joachim99@8
|
580 if( eEndPoint==eEnd )
|
joachim99@8
|
581 {
|
joachim99@8
|
582 if (eDir==eUp) i = m_mergeLineList.begin(); // first mergeline
|
joachim99@8
|
583 else i = --m_mergeLineList.end(); // last mergeline
|
joachim99@8
|
584
|
joachim99@77
|
585 while ( isItAtEnd(eDir==eUp, i) && ! i->bDelta )
|
joachim99@8
|
586 {
|
joachim99@8
|
587 if ( eDir==eUp ) ++i; // search downwards
|
joachim99@8
|
588 else --i; // search upwards
|
joachim99@8
|
589 }
|
joachim99@8
|
590 }
|
joachim99@77
|
591 else if ( eEndPoint == eDelta && isItAtEnd(eDir!=eUp, i) )
|
joachim99@8
|
592 {
|
joachim99@8
|
593 do
|
joachim99@8
|
594 {
|
joachim99@8
|
595 if ( eDir==eUp ) --i;
|
joachim99@8
|
596 else ++i;
|
joachim99@8
|
597 }
|
joachim99@77
|
598 while ( isItAtEnd(eDir!=eUp, i) && ( i->bDelta == false || checkOverviewIgnore(i) || bSkipWhiteConflicts && i->bWhiteSpaceConflict ) );
|
joachim99@8
|
599 }
|
joachim99@77
|
600 else if ( eEndPoint == eConflict && isItAtEnd(eDir!=eUp, i) )
|
joachim99@8
|
601 {
|
joachim99@8
|
602 do
|
joachim99@8
|
603 {
|
joachim99@8
|
604 if ( eDir==eUp ) --i;
|
joachim99@8
|
605 else ++i;
|
joachim99@8
|
606 }
|
joachim99@77
|
607 while ( isItAtEnd(eDir!=eUp, i) && (i->bConflict == false || bSkipWhiteConflicts && i->bWhiteSpaceConflict ) );
|
joachim99@8
|
608 }
|
joachim99@77
|
609 else if ( isItAtEnd(eDir!=eUp, i) && eEndPoint == eUnsolvedConflict )
|
joachim99@8
|
610 {
|
joachim99@8
|
611 do
|
joachim99@8
|
612 {
|
joachim99@8
|
613 if ( eDir==eUp ) --i;
|
joachim99@8
|
614 else ++i;
|
joachim99@8
|
615 }
|
joachim99@77
|
616 while ( isItAtEnd(eDir!=eUp, i) && ! i->mergeEditLineList.begin()->isConflict() );
|
joachim99@8
|
617 }
|
joachim99@8
|
618
|
joachim99@53
|
619 if ( isVisible() )
|
joachim99@53
|
620 setFocus();
|
joachim99@68
|
621
|
joachim99@66
|
622 setFastSelector( i );
|
joachim99@8
|
623 }
|
joachim99@8
|
624
|
joachim99@8
|
625 bool MergeResultWindow::isDeltaAboveCurrent()
|
joachim99@8
|
626 {
|
joachim99@51
|
627 bool bSkipWhiteConflicts = ! m_pOptionDialog->m_bShowWhiteSpace;
|
joachim99@66
|
628 if (m_mergeLineList.empty()) return false;
|
joachim99@8
|
629 MergeLineList::iterator i = m_currentMergeLineIt;
|
joachim99@66
|
630 if (i == m_mergeLineList.begin()) return false;
|
joachim99@66
|
631 do
|
joachim99@8
|
632 {
|
joachim99@66
|
633 --i;
|
joachim99@77
|
634 if ( i->bDelta && !checkOverviewIgnore(i) && !( bSkipWhiteConflicts && i->bWhiteSpaceConflict ) ) return true;
|
joachim99@68
|
635 }
|
joachim99@66
|
636 while (i!=m_mergeLineList.begin());
|
joachim99@68
|
637
|
joachim99@8
|
638 return false;
|
joachim99@8
|
639 }
|
joachim99@8
|
640
|
joachim99@8
|
641 bool MergeResultWindow::isDeltaBelowCurrent()
|
joachim99@8
|
642 {
|
joachim99@51
|
643 bool bSkipWhiteConflicts = ! m_pOptionDialog->m_bShowWhiteSpace;
|
joachim99@66
|
644 if (m_mergeLineList.empty()) return false;
|
joachim99@68
|
645
|
joachim99@8
|
646 MergeLineList::iterator i = m_currentMergeLineIt;
|
joachim99@66
|
647 if (i!=m_mergeLineList.end())
|
joachim99@8
|
648 {
|
joachim99@66
|
649 ++i;
|
joachim99@66
|
650 for( ; i!=m_mergeLineList.end(); ++i )
|
joachim99@66
|
651 {
|
joachim99@77
|
652 if ( i->bDelta && !checkOverviewIgnore(i) && !( bSkipWhiteConflicts && i->bWhiteSpaceConflict ) ) return true;
|
joachim99@66
|
653 }
|
joachim99@8
|
654 }
|
joachim99@8
|
655 return false;
|
joachim99@8
|
656 }
|
joachim99@8
|
657
|
joachim99@8
|
658 bool MergeResultWindow::isConflictAboveCurrent()
|
joachim99@8
|
659 {
|
joachim99@66
|
660 if (m_mergeLineList.empty()) return false;
|
joachim99@8
|
661 MergeLineList::iterator i = m_currentMergeLineIt;
|
joachim99@66
|
662 if (i == m_mergeLineList.begin()) return false;
|
joachim99@68
|
663
|
joachim99@77
|
664 bool bSkipWhiteConflicts = ! m_pOptionDialog->m_bShowWhiteSpace;
|
joachim99@77
|
665
|
joachim99@66
|
666 do
|
joachim99@8
|
667 {
|
joachim99@66
|
668 --i;
|
joachim99@77
|
669 if ( i->bConflict && !(bSkipWhiteConflicts && i->bWhiteSpaceConflict) ) return true;
|
joachim99@66
|
670 }
|
joachim99@66
|
671 while (i!=m_mergeLineList.begin());
|
joachim99@66
|
672
|
joachim99@8
|
673 return false;
|
joachim99@8
|
674 }
|
joachim99@8
|
675
|
joachim99@8
|
676 bool MergeResultWindow::isConflictBelowCurrent()
|
joachim99@8
|
677 {
|
joachim99@8
|
678 MergeLineList::iterator i = m_currentMergeLineIt;
|
joachim99@66
|
679 if (m_mergeLineList.empty()) return false;
|
joachim99@77
|
680
|
joachim99@77
|
681 bool bSkipWhiteConflicts = ! m_pOptionDialog->m_bShowWhiteSpace;
|
joachim99@77
|
682
|
joachim99@66
|
683 if (i!=m_mergeLineList.end())
|
joachim99@8
|
684 {
|
joachim99@66
|
685 ++i;
|
joachim99@66
|
686 for( ; i!=m_mergeLineList.end(); ++i )
|
joachim99@66
|
687 {
|
joachim99@77
|
688 if ( i->bConflict && !(bSkipWhiteConflicts && i->bWhiteSpaceConflict) ) return true;
|
joachim99@66
|
689 }
|
joachim99@8
|
690 }
|
joachim99@69
|
691 return false;
|
joachim99@8
|
692 }
|
joachim99@8
|
693
|
joachim99@77
|
694 bool MergeResultWindow::isUnsolvedConflictAtCurrent()
|
joachim99@77
|
695 {
|
joachim99@77
|
696 if (m_mergeLineList.empty()) return false;
|
joachim99@77
|
697 MergeLineList::iterator i = m_currentMergeLineIt;
|
joachim99@77
|
698 return i->mergeEditLineList.begin()->isConflict();
|
joachim99@77
|
699 }
|
joachim99@77
|
700
|
joachim99@8
|
701 bool MergeResultWindow::isUnsolvedConflictAboveCurrent()
|
joachim99@8
|
702 {
|
joachim99@66
|
703 if (m_mergeLineList.empty()) return false;
|
joachim99@8
|
704 MergeLineList::iterator i = m_currentMergeLineIt;
|
joachim99@66
|
705 if (i == m_mergeLineList.begin()) return false;
|
joachim99@66
|
706
|
joachim99@66
|
707 do
|
joachim99@8
|
708 {
|
joachim99@66
|
709 --i;
|
joachim99@8
|
710 if ( i->mergeEditLineList.begin()->isConflict() ) return true;
|
joachim99@66
|
711 }
|
joachim99@66
|
712 while (i!=m_mergeLineList.begin());
|
joachim99@66
|
713
|
joachim99@8
|
714 return false;
|
joachim99@8
|
715 }
|
joachim99@8
|
716
|
joachim99@8
|
717 bool MergeResultWindow::isUnsolvedConflictBelowCurrent()
|
joachim99@8
|
718 {
|
joachim99@8
|
719 MergeLineList::iterator i = m_currentMergeLineIt;
|
joachim99@66
|
720 if (m_mergeLineList.empty()) return false;
|
joachim99@66
|
721
|
joachim99@66
|
722 if (i!=m_mergeLineList.end())
|
joachim99@8
|
723 {
|
joachim99@66
|
724 ++i;
|
joachim99@66
|
725 for( ; i!=m_mergeLineList.end(); ++i )
|
joachim99@66
|
726 {
|
joachim99@66
|
727 if ( i->mergeEditLineList.begin()->isConflict() ) return true;
|
joachim99@66
|
728 }
|
joachim99@8
|
729 }
|
joachim99@8
|
730 return false;
|
joachim99@8
|
731 }
|
joachim99@8
|
732
|
joachim99@8
|
733 void MergeResultWindow::slotGoTop()
|
joachim99@8
|
734 {
|
joachim99@8
|
735 go( eUp, eEnd );
|
joachim99@8
|
736 }
|
joachim99@8
|
737
|
joachim99@8
|
738 void MergeResultWindow::slotGoCurrent()
|
joachim99@8
|
739 {
|
joachim99@8
|
740 setFastSelector( m_currentMergeLineIt );
|
joachim99@8
|
741 }
|
joachim99@8
|
742
|
joachim99@8
|
743 void MergeResultWindow::slotGoBottom()
|
joachim99@8
|
744 {
|
joachim99@8
|
745 go( eDown, eEnd );
|
joachim99@8
|
746 }
|
joachim99@8
|
747
|
joachim99@8
|
748 void MergeResultWindow::slotGoPrevDelta()
|
joachim99@8
|
749 {
|
joachim99@8
|
750 go( eUp, eDelta );
|
joachim99@8
|
751 }
|
joachim99@8
|
752
|
joachim99@8
|
753 void MergeResultWindow::slotGoNextDelta()
|
joachim99@8
|
754 {
|
joachim99@8
|
755 go( eDown, eDelta );
|
joachim99@8
|
756 }
|
joachim99@8
|
757
|
joachim99@8
|
758 void MergeResultWindow::slotGoPrevConflict()
|
joachim99@8
|
759 {
|
joachim99@8
|
760 go( eUp, eConflict );
|
joachim99@8
|
761 }
|
joachim99@8
|
762
|
joachim99@8
|
763 void MergeResultWindow::slotGoNextConflict()
|
joachim99@8
|
764 {
|
joachim99@8
|
765 go( eDown, eConflict );
|
joachim99@8
|
766 }
|
joachim99@8
|
767
|
joachim99@8
|
768 void MergeResultWindow::slotGoPrevUnsolvedConflict()
|
joachim99@8
|
769 {
|
joachim99@8
|
770 go( eUp, eUnsolvedConflict );
|
joachim99@8
|
771 }
|
joachim99@8
|
772
|
joachim99@8
|
773 void MergeResultWindow::slotGoNextUnsolvedConflict()
|
joachim99@8
|
774 {
|
joachim99@8
|
775 go( eDown, eUnsolvedConflict );
|
joachim99@8
|
776 }
|
joachim99@8
|
777
|
joachim99@8
|
778 /** The line is given as a index in the Diff3LineList.
|
joachim99@8
|
779 The function calculates the corresponding iterator. */
|
joachim99@8
|
780 void MergeResultWindow::slotSetFastSelectorLine( int line )
|
joachim99@8
|
781 {
|
joachim99@8
|
782 MergeLineList::iterator i;
|
joachim99@8
|
783 for ( i = m_mergeLineList.begin(); i!=m_mergeLineList.end(); ++i )
|
joachim99@8
|
784 {
|
joachim99@8
|
785 if ( line>=i->d3lLineIdx && line < i->d3lLineIdx + i->srcRangeLength )
|
joachim99@8
|
786 {
|
joachim99@68
|
787 //if ( i->bDelta )
|
joachim99@8
|
788 {
|
joachim99@8
|
789 setFastSelector( i );
|
joachim99@8
|
790 }
|
joachim99@8
|
791 break;
|
joachim99@8
|
792 }
|
joachim99@8
|
793 }
|
joachim99@8
|
794 }
|
joachim99@8
|
795
|
joachim99@68
|
796 int MergeResultWindow::getNrOfUnsolvedConflicts( int* pNrOfWhiteSpaceConflicts )
|
joachim99@8
|
797 {
|
joachim99@8
|
798 int nrOfUnsolvedConflicts = 0;
|
joachim99@68
|
799 if (pNrOfWhiteSpaceConflicts!=0)
|
joachim99@68
|
800 *pNrOfWhiteSpaceConflicts = 0;
|
joachim99@8
|
801
|
joachim99@8
|
802 MergeLineList::iterator mlIt = m_mergeLineList.begin();
|
joachim99@8
|
803 for(mlIt = m_mergeLineList.begin();mlIt!=m_mergeLineList.end(); ++mlIt)
|
joachim99@8
|
804 {
|
joachim99@8
|
805 MergeLine& ml = *mlIt;
|
joachim99@8
|
806 MergeEditLineList::iterator melIt = ml.mergeEditLineList.begin();
|
joachim99@8
|
807 if ( melIt->isConflict() )
|
joachim99@68
|
808 {
|
joachim99@8
|
809 ++nrOfUnsolvedConflicts;
|
joachim99@68
|
810 if ( ml.bWhiteSpaceConflict && pNrOfWhiteSpaceConflicts!=0 )
|
joachim99@68
|
811 ++ *pNrOfWhiteSpaceConflicts;
|
joachim99@68
|
812 }
|
joachim99@8
|
813 }
|
joachim99@8
|
814
|
joachim99@8
|
815 return nrOfUnsolvedConflicts;
|
joachim99@8
|
816 }
|
joachim99@8
|
817
|
joachim99@8
|
818 void MergeResultWindow::showNrOfConflicts()
|
joachim99@8
|
819 {
|
joachim99@80
|
820 if (!m_pOptionDialog->m_bShowInfoDialogs)
|
joachim99@80
|
821 return;
|
joachim99@69
|
822 int nrOfConflicts = 0;
|
joachim99@8
|
823 MergeLineList::iterator i;
|
joachim99@8
|
824 for ( i = m_mergeLineList.begin(); i!=m_mergeLineList.end(); ++i )
|
joachim99@8
|
825 {
|
joachim99@69
|
826 if ( i->bConflict || i->bDelta )
|
joachim99@69
|
827 ++nrOfConflicts;
|
joachim99@8
|
828 }
|
joachim99@8
|
829 QString totalInfo;
|
joachim99@8
|
830 if ( m_pTotalDiffStatus->bBinaryAEqB && m_pTotalDiffStatus->bBinaryAEqC )
|
joachim99@8
|
831 totalInfo += i18n("All input files are binary equal.");
|
joachim99@8
|
832 else if ( m_pTotalDiffStatus->bTextAEqB && m_pTotalDiffStatus->bTextAEqC )
|
joachim99@8
|
833 totalInfo += i18n("All input files contain the same text.");
|
joachim99@8
|
834 else {
|
joachim99@80
|
835 if ( m_pTotalDiffStatus->bBinaryAEqB ) totalInfo += i18n("Files %1 and %2 are binary equal.\n",QString("A"),QString("B"));
|
joachim99@80
|
836 else if ( m_pTotalDiffStatus->bTextAEqB ) totalInfo += i18n("Files %1 and %2 have equal text.\n",QString("A"),QString("B"));
|
joachim99@80
|
837 if ( m_pTotalDiffStatus->bBinaryAEqC ) totalInfo += i18n("Files %1 and %2 are binary equal.\n",QString("A"),QString("C"));
|
joachim99@80
|
838 else if ( m_pTotalDiffStatus->bTextAEqC ) totalInfo += i18n("Files %1 and %2 have equal text.\n",QString("A"),QString("C"));
|
joachim99@80
|
839 if ( m_pTotalDiffStatus->bBinaryBEqC ) totalInfo += i18n("Files %1 and %2 are binary equal.\n",QString("B"),QString("C"));
|
joachim99@80
|
840 else if ( m_pTotalDiffStatus->bTextBEqC ) totalInfo += i18n("Files %1 and %2 have equal text.\n",QString("B"),QString("C"));
|
joachim99@8
|
841 }
|
joachim99@69
|
842
|
joachim99@69
|
843 int nrOfUnsolvedConflicts = getNrOfUnsolvedConflicts();
|
joachim99@69
|
844
|
joachim99@8
|
845 KMessageBox::information( this,
|
joachim99@69
|
846 i18n("Total number of conflicts: ") + QString::number(nrOfConflicts) +
|
joachim99@69
|
847 i18n("\nNr of automatically solved conflicts: ") + QString::number(nrOfConflicts-nrOfUnsolvedConflicts) +
|
joachim99@8
|
848 i18n("\nNr of unsolved conflicts: ") + QString::number(nrOfUnsolvedConflicts) +
|
joachim99@8
|
849 "\n"+totalInfo,
|
joachim99@8
|
850 i18n("Conflicts")
|
joachim99@8
|
851 );
|
joachim99@8
|
852 }
|
joachim99@8
|
853
|
joachim99@8
|
854 void MergeResultWindow::setFastSelector(MergeLineList::iterator i)
|
joachim99@8
|
855 {
|
joachim99@8
|
856 if ( i==m_mergeLineList.end() )
|
joachim99@8
|
857 return;
|
joachim99@8
|
858 m_currentMergeLineIt = i;
|
joachim99@8
|
859 emit setFastSelectorRange( i->d3lLineIdx, i->srcRangeLength );
|
joachim99@8
|
860
|
joachim99@8
|
861 int line1 = 0;
|
joachim99@8
|
862
|
joachim99@8
|
863 MergeLineList::iterator mlIt = m_mergeLineList.begin();
|
joachim99@8
|
864 for(mlIt = m_mergeLineList.begin();mlIt!=m_mergeLineList.end(); ++mlIt)
|
joachim99@8
|
865 {
|
joachim99@8
|
866 if(mlIt==m_currentMergeLineIt)
|
joachim99@8
|
867 break;
|
joachim99@8
|
868 line1 += mlIt->mergeEditLineList.size();
|
joachim99@8
|
869 }
|
joachim99@8
|
870
|
joachim99@8
|
871 int nofLines = m_currentMergeLineIt->mergeEditLineList.size();
|
joachim99@8
|
872 int newFirstLine = getBestFirstLine( line1, nofLines, m_firstLine, getNofVisibleLines() );
|
joachim99@8
|
873 if ( newFirstLine != m_firstLine )
|
joachim99@8
|
874 {
|
joachim99@8
|
875 scroll( 0, newFirstLine - m_firstLine );
|
joachim99@8
|
876 }
|
joachim99@8
|
877
|
joachim99@8
|
878 if ( m_selection.isEmpty() )
|
joachim99@8
|
879 {
|
joachim99@8
|
880 m_cursorXPos = 0;
|
joachim99@8
|
881 m_cursorOldXPos = 0;
|
joachim99@8
|
882 m_cursorYPos = line1;
|
joachim99@8
|
883 }
|
joachim99@8
|
884
|
joachim99@8
|
885 update();
|
joachim99@66
|
886 updateSourceMask();
|
joachim99@8
|
887 emit updateAvailabilities();
|
joachim99@8
|
888 }
|
joachim99@8
|
889
|
joachim99@8
|
890 void MergeResultWindow::choose( int selector )
|
joachim99@8
|
891 {
|
joachim99@66
|
892 if ( m_currentMergeLineIt==m_mergeLineList.end() )
|
joachim99@66
|
893 return;
|
joachim99@68
|
894
|
joachim99@8
|
895 setModified();
|
joachim99@8
|
896
|
joachim99@8
|
897 // First find range for which this change works.
|
joachim99@8
|
898 MergeLine& ml = *m_currentMergeLineIt;
|
joachim99@8
|
899
|
joachim99@8
|
900 MergeEditLineList::iterator melIt;
|
joachim99@8
|
901
|
joachim99@8
|
902 // Now check if selector is active for this range already.
|
joachim99@8
|
903 bool bActive = false;
|
joachim99@8
|
904
|
joachim99@8
|
905 // Remove unneeded lines in the range.
|
joachim99@8
|
906 for( melIt = ml.mergeEditLineList.begin(); melIt != ml.mergeEditLineList.end(); )
|
joachim99@8
|
907 {
|
joachim99@8
|
908 MergeEditLine& mel = *melIt;
|
joachim99@8
|
909 if ( mel.src()==selector )
|
joachim99@8
|
910 bActive = true;
|
joachim99@8
|
911
|
joachim99@8
|
912 if ( mel.src()==selector || !mel.isEditableText() || mel.isModified() )
|
joachim99@8
|
913 melIt = ml.mergeEditLineList.erase( melIt );
|
joachim99@8
|
914 else
|
joachim99@8
|
915 ++melIt;
|
joachim99@8
|
916 }
|
joachim99@8
|
917
|
joachim99@8
|
918 if ( !bActive ) // Selected source wasn't active.
|
joachim99@8
|
919 { // Append the lines from selected source here at rangeEnd.
|
joachim99@8
|
920 Diff3LineList::const_iterator d3llit=ml.id3l;
|
joachim99@8
|
921 int j;
|
joachim99@8
|
922
|
joachim99@8
|
923 for( j=0; j<ml.srcRangeLength; ++j )
|
joachim99@8
|
924 {
|
joachim99@69
|
925 MergeEditLine mel(d3llit);
|
joachim99@69
|
926 mel.setSource( selector, false );
|
joachim99@8
|
927 ml.mergeEditLineList.push_back(mel);
|
joachim99@8
|
928
|
joachim99@8
|
929 ++d3llit;
|
joachim99@8
|
930 }
|
joachim99@8
|
931 }
|
joachim99@8
|
932
|
joachim99@8
|
933 if ( ! ml.mergeEditLineList.empty() )
|
joachim99@8
|
934 {
|
joachim99@8
|
935 // Remove all lines that are empty, because no src lines are there.
|
joachim99@8
|
936 for( melIt = ml.mergeEditLineList.begin(); melIt != ml.mergeEditLineList.end(); )
|
joachim99@8
|
937 {
|
joachim99@8
|
938 MergeEditLine& mel = *melIt;
|
joachim99@8
|
939
|
joachim99@8
|
940 int srcLine = mel.src()==1 ? mel.id3l()->lineA :
|
joachim99@8
|
941 mel.src()==2 ? mel.id3l()->lineB :
|
joachim99@8
|
942 mel.src()==3 ? mel.id3l()->lineC : -1;
|
joachim99@8
|
943
|
joachim99@8
|
944 if ( srcLine == -1 )
|
joachim99@8
|
945 melIt = ml.mergeEditLineList.erase( melIt );
|
joachim99@8
|
946 else
|
joachim99@8
|
947 ++melIt;
|
joachim99@8
|
948 }
|
joachim99@8
|
949 }
|
joachim99@8
|
950
|
joachim99@8
|
951 if ( ml.mergeEditLineList.empty() )
|
joachim99@8
|
952 {
|
joachim99@8
|
953 // Insert a dummy line:
|
joachim99@69
|
954 MergeEditLine mel(ml.id3l);
|
joachim99@8
|
955
|
joachim99@8
|
956 if ( bActive ) mel.setConflict(); // All src entries deleted => conflict
|
joachim99@8
|
957 else mel.setRemoved(selector); // No lines in corresponding src found.
|
joachim99@8
|
958
|
joachim99@8
|
959 ml.mergeEditLineList.push_back(mel);
|
joachim99@8
|
960 }
|
joachim99@68
|
961
|
joachim99@58
|
962 if ( m_cursorYPos >= m_totalSize )
|
joachim99@58
|
963 {
|
joachim99@58
|
964 m_cursorYPos = m_totalSize-1;
|
joachim99@58
|
965 m_cursorXPos = 0;
|
joachim99@58
|
966 }
|
joachim99@8
|
967
|
joachim99@8
|
968 update();
|
joachim99@66
|
969 updateSourceMask();
|
joachim99@8
|
970 emit updateAvailabilities();
|
joachim99@68
|
971 int wsc;
|
joachim99@69
|
972 int nofUnsolved = getNrOfUnsolvedConflicts(&wsc);
|
joachim99@80
|
973 m_pStatusBar->showMessage( i18n("Number of remaining unsolved conflicts: %1 (of which %2 are whitespace)"
|
joachim99@80
|
974 ,nofUnsolved,wsc) );
|
joachim99@8
|
975 }
|
joachim99@8
|
976
|
joachim99@51
|
977 // bConflictsOnly: automatically choose for conflicts only (true) or for everywhere (false)
|
joachim99@51
|
978 void MergeResultWindow::chooseGlobal(int selector, bool bConflictsOnly, bool bWhiteSpaceOnly )
|
joachim99@8
|
979 {
|
joachim99@8
|
980 resetSelection();
|
joachim99@8
|
981
|
joachim99@51
|
982 merge( false, selector, bConflictsOnly, bWhiteSpaceOnly );
|
joachim99@75
|
983 setModified( true );
|
joachim99@8
|
984 update();
|
joachim99@68
|
985 int wsc;
|
joachim99@69
|
986 int nofUnsolved = getNrOfUnsolvedConflicts(&wsc);
|
joachim99@80
|
987 m_pStatusBar->showMessage( i18n("Number of remaining unsolved conflicts: %1 (of which %2 are whitespace)"
|
joachim99@80
|
988 ,nofUnsolved,wsc) );
|
joachim99@8
|
989 }
|
joachim99@8
|
990
|
joachim99@8
|
991 void MergeResultWindow::slotAutoSolve()
|
joachim99@8
|
992 {
|
joachim99@8
|
993 resetSelection();
|
joachim99@8
|
994 merge( true, -1 );
|
joachim99@75
|
995 setModified( true );
|
joachim99@8
|
996 update();
|
joachim99@68
|
997 int wsc;
|
joachim99@69
|
998 int nofUnsolved = getNrOfUnsolvedConflicts(&wsc);
|
joachim99@80
|
999 m_pStatusBar->showMessage( i18n("Number of remaining unsolved conflicts: %1 (of which %2 are whitespace)"
|
joachim99@80
|
1000 ,nofUnsolved,wsc) );
|
joachim99@8
|
1001 }
|
joachim99@8
|
1002
|
joachim99@8
|
1003 void MergeResultWindow::slotUnsolve()
|
joachim99@8
|
1004 {
|
joachim99@8
|
1005 resetSelection();
|
joachim99@8
|
1006 merge( false, -1 );
|
joachim99@75
|
1007 setModified( true );
|
joachim99@8
|
1008 update();
|
joachim99@68
|
1009 int wsc;
|
joachim99@69
|
1010 int nofUnsolved = getNrOfUnsolvedConflicts(&wsc);
|
joachim99@80
|
1011 m_pStatusBar->showMessage( i18n("Number of remaining unsolved conflicts: %1 (of which %2 are whitespace)"
|
joachim99@80
|
1012 ,nofUnsolved,wsc) );
|
joachim99@69
|
1013 }
|
joachim99@69
|
1014
|
joachim99@77
|
1015 static QString calcHistoryLead(const QString& s )
|
joachim99@77
|
1016 {
|
joachim99@77
|
1017 // Return the start of the line until the first white char after the first non white char.
|
joachim99@77
|
1018 int i;
|
joachim99@77
|
1019 for( i=0; i<s.length(); ++i )
|
joachim99@77
|
1020 {
|
joachim99@77
|
1021 if (s[i]!=' ' && s[i]!='\t')
|
joachim99@77
|
1022 {
|
joachim99@77
|
1023 for( ; i<s.length(); ++i )
|
joachim99@77
|
1024 {
|
joachim99@77
|
1025 if (s[i]==' ' || s[i]=='\t')
|
joachim99@77
|
1026 {
|
joachim99@77
|
1027 return s.left(i);
|
joachim99@77
|
1028 }
|
joachim99@77
|
1029 }
|
joachim99@77
|
1030 return s; // Very unlikely
|
joachim99@77
|
1031 }
|
joachim99@77
|
1032 }
|
joachim99@77
|
1033 return ""; // Must be an empty string, not a null string.
|
joachim99@77
|
1034 }
|
joachim99@77
|
1035
|
joachim99@77
|
1036 static void findHistoryRange( const QRegExp& historyStart, bool bThreeFiles, const Diff3LineList* pD3LList,
|
joachim99@69
|
1037 Diff3LineList::const_iterator& iBegin, Diff3LineList::const_iterator& iEnd, int& idxBegin, int& idxEnd )
|
joachim99@69
|
1038 {
|
joachim99@69
|
1039 QString historyLead;
|
joachim99@69
|
1040 // Search for start of history
|
joachim99@69
|
1041 for( iBegin = pD3LList->begin(), idxBegin=0; iBegin!=pD3LList->end(); ++iBegin, ++idxBegin )
|
joachim99@69
|
1042 {
|
joachim99@69
|
1043 if ( historyStart.exactMatch( iBegin->getString(A) ) &&
|
joachim99@69
|
1044 historyStart.exactMatch( iBegin->getString(B) ) &&
|
joachim99@69
|
1045 ( !bThreeFiles || historyStart.exactMatch( iBegin->getString(C) ) ) )
|
joachim99@69
|
1046 {
|
joachim99@77
|
1047 historyLead = calcHistoryLead( iBegin->getString(A) );
|
joachim99@69
|
1048 break;
|
joachim99@69
|
1049 }
|
joachim99@69
|
1050 }
|
joachim99@69
|
1051 // Search for end of history
|
joachim99@69
|
1052 for( iEnd = iBegin, idxEnd = idxBegin; iEnd!=pD3LList->end(); ++iEnd, ++idxEnd )
|
joachim99@69
|
1053 {
|
joachim99@69
|
1054 QString sA = iEnd->getString(A);
|
joachim99@69
|
1055 QString sB = iEnd->getString(B);
|
joachim99@69
|
1056 QString sC = iEnd->getString(C);
|
joachim99@77
|
1057 if ( ! ((sA.isNull() || historyLead == calcHistoryLead(sA) ) &&
|
joachim99@77
|
1058 (sB.isNull() || historyLead == calcHistoryLead(sB) ) &&
|
joachim99@77
|
1059 (!bThreeFiles || sC.isNull() || historyLead == calcHistoryLead(sC) )
|
joachim99@69
|
1060 ))
|
joachim99@69
|
1061 {
|
joachim99@69
|
1062 break; // End of the history
|
joachim99@69
|
1063 }
|
joachim99@69
|
1064 }
|
joachim99@69
|
1065 }
|
joachim99@69
|
1066
|
joachim99@69
|
1067 bool findParenthesesGroups( const QString& s, QStringList& sl )
|
joachim99@69
|
1068 {
|
joachim99@69
|
1069 sl.clear();
|
joachim99@69
|
1070 int i=0;
|
joachim99@69
|
1071 std::list<int> startPosStack;
|
joachim99@69
|
1072 int length = s.length();
|
joachim99@69
|
1073 for( i=0; i<length; ++i )
|
joachim99@69
|
1074 {
|
joachim99@69
|
1075 if ( s[i]=='\\' && i+1<length && ( s[i+1]=='\\' || s[i+1]=='(' || s[i+1]==')' ) )
|
joachim99@69
|
1076 {
|
joachim99@69
|
1077 ++i;
|
joachim99@69
|
1078 continue;
|
joachim99@69
|
1079 }
|
joachim99@69
|
1080 if ( s[i]=='(' )
|
joachim99@69
|
1081 {
|
joachim99@69
|
1082 startPosStack.push_back(i);
|
joachim99@69
|
1083 }
|
joachim99@69
|
1084 else if ( s[i]==')' )
|
joachim99@69
|
1085 {
|
joachim99@69
|
1086 if (startPosStack.empty())
|
joachim99@69
|
1087 return false; // Parentheses don't match
|
joachim99@69
|
1088 int startPos = startPosStack.back();
|
joachim99@69
|
1089 startPosStack.pop_back();
|
joachim99@69
|
1090 sl.push_back( s.mid( startPos+1, i-startPos-1 ) );
|
joachim99@69
|
1091 }
|
joachim99@69
|
1092 }
|
joachim99@69
|
1093 return startPosStack.empty(); // false if parentheses don't match
|
joachim99@69
|
1094 }
|
joachim99@69
|
1095
|
joachim99@69
|
1096 QString calcHistorySortKey( const QString& keyOrder, QRegExp& matchedRegExpr, const QStringList& parenthesesGroupList )
|
joachim99@69
|
1097 {
|
joachim99@75
|
1098 QStringList keyOrderList = keyOrder.split(',');
|
joachim99@69
|
1099 QString key;
|
joachim99@69
|
1100 for ( QStringList::iterator keyIt = keyOrderList.begin(); keyIt!=keyOrderList.end(); ++keyIt )
|
joachim99@69
|
1101 {
|
joachim99@69
|
1102 if ( (*keyIt).isEmpty() )
|
joachim99@69
|
1103 continue;
|
joachim99@69
|
1104 bool bOk=false;
|
joachim99@69
|
1105 int groupIdx = (*keyIt).toInt(&bOk);
|
joachim99@69
|
1106 if (!bOk || groupIdx<0 || groupIdx >(int)parenthesesGroupList.size() )
|
joachim99@69
|
1107 continue;
|
joachim99@69
|
1108 QString s = matchedRegExpr.cap( groupIdx );
|
joachim99@69
|
1109 if ( groupIdx == 0 )
|
joachim99@69
|
1110 {
|
joachim99@69
|
1111 key += s + " ";
|
joachim99@69
|
1112 continue;
|
joachim99@69
|
1113 }
|
joachim99@69
|
1114
|
joachim99@69
|
1115 QString groupRegExp = parenthesesGroupList[groupIdx-1];
|
joachim99@75
|
1116 if( groupRegExp.indexOf('|')<0 || groupRegExp.indexOf('(')>=0 )
|
joachim99@69
|
1117 {
|
joachim99@69
|
1118 bool bOk = false;
|
joachim99@69
|
1119 int i = s.toInt( &bOk );
|
joachim99@69
|
1120 if ( bOk && i>=0 && i<10000 )
|
joachim99@69
|
1121 s.sprintf("%04d", i); // This should help for correct sorting of numbers.
|
joachim99@69
|
1122 key += s + " ";
|
joachim99@69
|
1123 }
|
joachim99@69
|
1124 else
|
joachim99@69
|
1125 {
|
joachim99@69
|
1126 // Assume that the groupRegExp consists of something like "Jan|Feb|Mar|Apr"
|
joachim99@69
|
1127 // s is the string that managed to match.
|
joachim99@69
|
1128 // Now we want to know at which position it occurred. e.g. Jan=0, Feb=1, Mar=2, etc.
|
joachim99@75
|
1129 QStringList sl = groupRegExp.split( '|' );
|
joachim99@75
|
1130 int idx = sl.indexOf( s );
|
joachim99@69
|
1131 if (idx<0)
|
joachim99@69
|
1132 {
|
joachim99@69
|
1133 // Didn't match
|
joachim99@69
|
1134 }
|
joachim99@69
|
1135 else
|
joachim99@69
|
1136 {
|
joachim99@69
|
1137 QString sIdx;
|
joachim99@69
|
1138 sIdx.sprintf("%02d", idx+1 ); // Up to 99 words in the groupRegExp (more than 12 aren't expected)
|
joachim99@69
|
1139 key += sIdx + " ";
|
joachim99@69
|
1140 }
|
joachim99@69
|
1141 }
|
joachim99@69
|
1142 }
|
joachim99@69
|
1143 return key;
|
joachim99@69
|
1144 }
|
joachim99@69
|
1145
|
joachim99@69
|
1146 void MergeResultWindow::collectHistoryInformation(
|
joachim99@69
|
1147 int src, Diff3LineList::const_iterator iHistoryBegin, Diff3LineList::const_iterator iHistoryEnd,
|
joachim99@69
|
1148 HistoryMap& historyMap,
|
joachim99@69
|
1149 std::list< HistoryMap::iterator >& hitList // list of iterators
|
joachim99@69
|
1150 )
|
joachim99@69
|
1151 {
|
joachim99@69
|
1152 std::list< HistoryMap::iterator >::iterator itHitListFront = hitList.begin();
|
joachim99@69
|
1153 Diff3LineList::const_iterator id3l = iHistoryBegin;
|
joachim99@69
|
1154 QString historyLead;
|
joachim99@69
|
1155 {
|
joachim99@69
|
1156 const LineData* pld = id3l->getLineData(src);
|
joachim99@69
|
1157 QString s( pld->pLine, pld->size );
|
joachim99@77
|
1158 historyLead = calcHistoryLead(s);
|
joachim99@69
|
1159 }
|
joachim99@70
|
1160 QRegExp historyStart( m_pOptionDialog->m_historyStartRegExp );
|
joachim99@80
|
1161 if ( id3l == iHistoryEnd )
|
joachim99@80
|
1162 return;
|
joachim99@69
|
1163 ++id3l; // Skip line with "$Log ... $"
|
joachim99@70
|
1164 QRegExp newHistoryEntry( m_pOptionDialog->m_historyEntryStartRegExp );
|
joachim99@69
|
1165 QStringList parenthesesGroups;
|
joachim99@69
|
1166 findParenthesesGroups( m_pOptionDialog->m_historyEntryStartRegExp, parenthesesGroups );
|
joachim99@69
|
1167 QString key;
|
joachim99@69
|
1168 MergeEditLineList melList;
|
joachim99@69
|
1169 bool bPrevLineIsEmpty = true;
|
joachim99@69
|
1170 bool bUseRegExp = !m_pOptionDialog->m_historyEntryStartRegExp.isEmpty();
|
joachim99@69
|
1171 for(; id3l != iHistoryEnd; ++id3l )
|
joachim99@69
|
1172 {
|
joachim99@69
|
1173 const LineData* pld = id3l->getLineData(src);
|
joachim99@69
|
1174 if ( !pld ) continue;
|
joachim99@69
|
1175 QString s( pld->pLine, pld->size );
|
joachim99@77
|
1176 if (historyLead.isNull()) historyLead = calcHistoryLead(s);
|
joachim99@69
|
1177 QString sLine = s.mid(historyLead.length());
|
joachim99@75
|
1178 if ( ( !bUseRegExp && !sLine.trimmed().isEmpty() && bPrevLineIsEmpty )
|
joachim99@69
|
1179 || bUseRegExp && newHistoryEntry.exactMatch( sLine )
|
joachim99@69
|
1180 )
|
joachim99@69
|
1181 {
|
joachim99@69
|
1182 if ( !key.isEmpty() && !melList.empty() )
|
joachim99@69
|
1183 {
|
joachim99@69
|
1184 // Only insert new HistoryMapEntry if key not found; in either case p.first is a valid iterator to element key.
|
joachim99@69
|
1185 std::pair<HistoryMap::iterator, bool> p = historyMap.insert(HistoryMap::value_type(key,HistoryMapEntry()));
|
joachim99@69
|
1186 HistoryMapEntry& hme = p.first->second;
|
joachim99@69
|
1187 if ( src==A ) hme.mellA = melList;
|
joachim99@69
|
1188 if ( src==B ) hme.mellB = melList;
|
joachim99@69
|
1189 if ( src==C ) hme.mellC = melList;
|
joachim99@69
|
1190 if ( p.second ) // Not in list yet?
|
joachim99@69
|
1191 {
|
joachim99@69
|
1192 hitList.insert( itHitListFront, p.first );
|
joachim99@69
|
1193 }
|
joachim99@69
|
1194 }
|
joachim99@69
|
1195
|
joachim99@69
|
1196 if ( ! bUseRegExp )
|
joachim99@69
|
1197 key = sLine;
|
joachim99@69
|
1198 else
|
joachim99@69
|
1199 key = calcHistorySortKey(m_pOptionDialog->m_historyEntryStartSortKeyOrder,newHistoryEntry,parenthesesGroups);
|
joachim99@69
|
1200
|
joachim99@69
|
1201 melList.clear();
|
joachim99@69
|
1202 melList.push_back( MergeEditLine(id3l,src) );
|
joachim99@69
|
1203 }
|
joachim99@69
|
1204 else if ( ! historyStart.exactMatch( s ) )
|
joachim99@69
|
1205 {
|
joachim99@69
|
1206 melList.push_back( MergeEditLine(id3l,src) );
|
joachim99@69
|
1207 }
|
joachim99@69
|
1208
|
joachim99@75
|
1209 bPrevLineIsEmpty = sLine.trimmed().isEmpty();
|
joachim99@69
|
1210 }
|
joachim99@69
|
1211 if ( !key.isEmpty() )
|
joachim99@69
|
1212 {
|
joachim99@69
|
1213 // Only insert new HistoryMapEntry if key not found; in either case p.first is a valid iterator to element key.
|
joachim99@69
|
1214 std::pair<HistoryMap::iterator, bool> p = historyMap.insert(HistoryMap::value_type(key,HistoryMapEntry()));
|
joachim99@69
|
1215 HistoryMapEntry& hme = p.first->second;
|
joachim99@69
|
1216 if ( src==A ) hme.mellA = melList;
|
joachim99@69
|
1217 if ( src==B ) hme.mellB = melList;
|
joachim99@69
|
1218 if ( src==C ) hme.mellC = melList;
|
joachim99@69
|
1219 if ( p.second ) // Not in list yet?
|
joachim99@69
|
1220 {
|
joachim99@69
|
1221 hitList.insert( itHitListFront, p.first );
|
joachim99@69
|
1222 }
|
joachim99@69
|
1223 }
|
joachim99@69
|
1224 // End of the history
|
joachim99@69
|
1225 }
|
joachim99@69
|
1226
|
joachim99@69
|
1227 MergeResultWindow::MergeEditLineList& MergeResultWindow::HistoryMapEntry::choice( bool bThreeInputs )
|
joachim99@69
|
1228 {
|
joachim99@69
|
1229 if ( !bThreeInputs )
|
joachim99@69
|
1230 return mellA.empty() ? mellB : mellA;
|
joachim99@69
|
1231 else
|
joachim99@69
|
1232 {
|
joachim99@69
|
1233 if ( mellA.empty() )
|
joachim99@69
|
1234 return mellC.empty() ? mellB : mellC; // A doesn't exist, return one that exists
|
joachim99@69
|
1235 else if ( ! mellB.empty() && ! mellC.empty() )
|
joachim99@69
|
1236 { // A, B and C exist
|
joachim99@69
|
1237 return mellA;
|
joachim99@69
|
1238 }
|
joachim99@69
|
1239 else
|
joachim99@69
|
1240 return mellB.empty() ? mellB : mellC; // A exists, return the one that doesn't exist
|
joachim99@69
|
1241 }
|
joachim99@69
|
1242 }
|
joachim99@69
|
1243
|
joachim99@69
|
1244 bool MergeResultWindow::HistoryMapEntry::staysInPlace( bool bThreeInputs, Diff3LineList::const_iterator& iHistoryEnd )
|
joachim99@69
|
1245 {
|
joachim99@69
|
1246 // The entry should stay in place if the decision made by the automerger is correct.
|
joachim99@69
|
1247 Diff3LineList::const_iterator& iHistoryLast = iHistoryEnd;
|
joachim99@69
|
1248 --iHistoryLast;
|
joachim99@69
|
1249 if ( !bThreeInputs )
|
joachim99@69
|
1250 {
|
joachim99@69
|
1251 if ( !mellA.empty() && !mellB.empty() && mellA.begin()->id3l()==mellB.begin()->id3l() &&
|
joachim99@69
|
1252 mellA.back().id3l() == iHistoryLast && mellB.back().id3l() == iHistoryLast )
|
joachim99@69
|
1253 {
|
joachim99@69
|
1254 iHistoryEnd = mellA.begin()->id3l();
|
joachim99@69
|
1255 return true;
|
joachim99@69
|
1256 }
|
joachim99@69
|
1257 else
|
joachim99@69
|
1258 {
|
joachim99@69
|
1259 return false;
|
joachim99@69
|
1260 }
|
joachim99@69
|
1261 }
|
joachim99@69
|
1262 else
|
joachim99@69
|
1263 {
|
joachim99@69
|
1264 if ( !mellA.empty() && !mellB.empty() && !mellC.empty()
|
joachim99@69
|
1265 && mellA.begin()->id3l()==mellB.begin()->id3l() && mellA.begin()->id3l()==mellC.begin()->id3l()
|
joachim99@69
|
1266 && mellA.back().id3l() == iHistoryLast && mellB.back().id3l() == iHistoryLast && mellC.back().id3l() == iHistoryLast )
|
joachim99@69
|
1267 {
|
joachim99@69
|
1268 iHistoryEnd = mellA.begin()->id3l();
|
joachim99@69
|
1269 return true;
|
joachim99@69
|
1270 }
|
joachim99@69
|
1271 else
|
joachim99@69
|
1272 {
|
joachim99@69
|
1273 return false;
|
joachim99@69
|
1274 }
|
joachim99@69
|
1275 }
|
joachim99@69
|
1276 }
|
joachim99@69
|
1277
|
joachim99@69
|
1278 void MergeResultWindow::slotMergeHistory()
|
joachim99@69
|
1279 {
|
joachim99@69
|
1280 Diff3LineList::const_iterator iD3LHistoryBegin;
|
joachim99@69
|
1281 Diff3LineList::const_iterator iD3LHistoryEnd;
|
joachim99@69
|
1282 int d3lHistoryBeginLineIdx = -1;
|
joachim99@69
|
1283 int d3lHistoryEndLineIdx = -1;
|
joachim99@69
|
1284
|
joachim99@69
|
1285 // Search for history start, history end in the diff3LineList
|
joachim99@77
|
1286 findHistoryRange( QRegExp(m_pOptionDialog->m_historyStartRegExp), m_pldC!=0, m_pDiff3LineList, iD3LHistoryBegin, iD3LHistoryEnd, d3lHistoryBeginLineIdx, d3lHistoryEndLineIdx );
|
joachim99@69
|
1287
|
joachim99@69
|
1288 if ( iD3LHistoryBegin != m_pDiff3LineList->end() )
|
joachim99@69
|
1289 {
|
joachim99@69
|
1290 // Now collect the historyMap information
|
joachim99@69
|
1291 HistoryMap historyMap;
|
joachim99@69
|
1292 std::list< HistoryMap::iterator > hitList;
|
joachim99@69
|
1293 if (m_pldC==0)
|
joachim99@69
|
1294 {
|
joachim99@69
|
1295 collectHistoryInformation( A, iD3LHistoryBegin, iD3LHistoryEnd, historyMap, hitList );
|
joachim99@69
|
1296 collectHistoryInformation( B, iD3LHistoryBegin, iD3LHistoryEnd, historyMap, hitList );
|
joachim99@69
|
1297 }
|
joachim99@69
|
1298 else
|
joachim99@69
|
1299 {
|
joachim99@69
|
1300 collectHistoryInformation( A, iD3LHistoryBegin, iD3LHistoryEnd, historyMap, hitList );
|
joachim99@69
|
1301 collectHistoryInformation( B, iD3LHistoryBegin, iD3LHistoryEnd, historyMap, hitList );
|
joachim99@69
|
1302 collectHistoryInformation( C, iD3LHistoryBegin, iD3LHistoryEnd, historyMap, hitList );
|
joachim99@69
|
1303 }
|
joachim99@69
|
1304
|
joachim99@69
|
1305 Diff3LineList::const_iterator iD3LHistoryOrigEnd = iD3LHistoryEnd;
|
joachim99@69
|
1306
|
joachim99@69
|
1307 bool bHistoryMergeSorting = m_pOptionDialog->m_bHistoryMergeSorting && ! m_pOptionDialog->m_historyEntryStartSortKeyOrder.isEmpty() &&
|
joachim99@69
|
1308 ! m_pOptionDialog->m_historyEntryStartRegExp.isEmpty();
|
joachim99@69
|
1309
|
joachim99@77
|
1310 if ( m_pOptionDialog->m_maxNofHistoryEntries==-1 )
|
joachim99@69
|
1311 {
|
joachim99@77
|
1312 // Remove parts from the historyMap and hitList that stay in place
|
joachim99@77
|
1313 if ( bHistoryMergeSorting )
|
joachim99@69
|
1314 {
|
joachim99@77
|
1315 while ( ! historyMap.empty() )
|
joachim99@77
|
1316 {
|
joachim99@77
|
1317 HistoryMap::iterator hMapIt = historyMap.begin();
|
joachim99@77
|
1318 if( hMapIt->second.staysInPlace( m_pldC!=0, iD3LHistoryEnd ) )
|
joachim99@77
|
1319 historyMap.erase(hMapIt);
|
joachim99@77
|
1320 else
|
joachim99@77
|
1321 break;
|
joachim99@77
|
1322 }
|
joachim99@69
|
1323 }
|
joachim99@77
|
1324 else
|
joachim99@69
|
1325 {
|
joachim99@77
|
1326 while ( ! hitList.empty() )
|
joachim99@77
|
1327 {
|
joachim99@77
|
1328 HistoryMap::iterator hMapIt = hitList.back();
|
joachim99@77
|
1329 if( hMapIt->second.staysInPlace( m_pldC!=0, iD3LHistoryEnd ) )
|
joachim99@77
|
1330 hitList.pop_back();
|
joachim99@77
|
1331 else
|
joachim99@77
|
1332 break;
|
joachim99@77
|
1333 }
|
joachim99@69
|
1334 }
|
joachim99@77
|
1335 while (iD3LHistoryOrigEnd != iD3LHistoryEnd)
|
joachim99@77
|
1336 {
|
joachim99@77
|
1337 --iD3LHistoryOrigEnd;
|
joachim99@77
|
1338 --d3lHistoryEndLineIdx;
|
joachim99@77
|
1339 }
|
joachim99@69
|
1340 }
|
joachim99@69
|
1341
|
joachim99@69
|
1342 MergeLineList::iterator iMLLStart = splitAtDiff3LineIdx(d3lHistoryBeginLineIdx);
|
joachim99@69
|
1343 MergeLineList::iterator iMLLEnd = splitAtDiff3LineIdx(d3lHistoryEndLineIdx);
|
joachim99@69
|
1344 // Now join all MergeLines in the history
|
joachim99@69
|
1345 MergeLineList::iterator i = iMLLStart;
|
joachim99@69
|
1346 if ( i != iMLLEnd )
|
joachim99@69
|
1347 {
|
joachim99@69
|
1348 ++i;
|
joachim99@69
|
1349 while ( i!=iMLLEnd )
|
joachim99@69
|
1350 {
|
joachim99@69
|
1351 iMLLStart->join(*i);
|
joachim99@69
|
1352 i = m_mergeLineList.erase( i );
|
joachim99@69
|
1353 }
|
joachim99@69
|
1354 }
|
joachim99@69
|
1355 iMLLStart->mergeEditLineList.clear();
|
joachim99@69
|
1356 // Now insert the complete history into the first MergeLine of the history
|
joachim99@69
|
1357 iMLLStart->mergeEditLineList.push_back( MergeEditLine( iD3LHistoryBegin, m_pldC == 0 ? B : C ) );
|
joachim99@77
|
1358 QString lead = calcHistoryLead( iD3LHistoryBegin->getString(A) );
|
joachim99@69
|
1359 MergeEditLine mel( m_pDiff3LineList->end() );
|
joachim99@69
|
1360 mel.setString( lead );
|
joachim99@69
|
1361 iMLLStart->mergeEditLineList.push_back(mel);
|
joachim99@69
|
1362
|
joachim99@77
|
1363 int historyCount = 0;
|
joachim99@69
|
1364 if ( bHistoryMergeSorting )
|
joachim99@69
|
1365 {
|
joachim99@69
|
1366 // Create a sorted history
|
joachim99@69
|
1367 HistoryMap::reverse_iterator hmit;
|
joachim99@69
|
1368 for ( hmit = historyMap.rbegin(); hmit != historyMap.rend(); ++hmit )
|
joachim99@69
|
1369 {
|
joachim99@77
|
1370 if ( historyCount==m_pOptionDialog->m_maxNofHistoryEntries )
|
joachim99@77
|
1371 break;
|
joachim99@77
|
1372 ++historyCount;
|
joachim99@69
|
1373 HistoryMapEntry& hme = hmit->second;
|
joachim99@69
|
1374 MergeEditLineList& mell = hme.choice(m_pldC!=0);
|
joachim99@69
|
1375 if (!mell.empty())
|
joachim99@69
|
1376 iMLLStart->mergeEditLineList.splice( iMLLStart->mergeEditLineList.end(), mell, mell.begin(), mell.end() );
|
joachim99@69
|
1377 }
|
joachim99@69
|
1378 }
|
joachim99@69
|
1379 else
|
joachim99@69
|
1380 {
|
joachim99@69
|
1381 // Create history in order of appearance
|
joachim99@69
|
1382 std::list< HistoryMap::iterator >::iterator hlit;
|
joachim99@69
|
1383 for ( hlit = hitList.begin(); hlit != hitList.end(); ++hlit )
|
joachim99@69
|
1384 {
|
joachim99@77
|
1385 if ( historyCount==m_pOptionDialog->m_maxNofHistoryEntries )
|
joachim99@77
|
1386 break;
|
joachim99@77
|
1387 ++historyCount;
|
joachim99@69
|
1388 HistoryMapEntry& hme = (*hlit)->second;
|
joachim99@69
|
1389 MergeEditLineList& mell = hme.choice(m_pldC!=0);
|
joachim99@69
|
1390 if (!mell.empty())
|
joachim99@69
|
1391 iMLLStart->mergeEditLineList.splice( iMLLStart->mergeEditLineList.end(), mell, mell.begin(), mell.end() );
|
joachim99@69
|
1392 }
|
joachim99@98
|
1393 // If the end of start is empty and the first line at the end is empty remove the last line of start
|
joachim99@98
|
1394 if ( !iMLLStart->mergeEditLineList.empty() && !iMLLEnd->mergeEditLineList.empty() )
|
joachim99@98
|
1395 {
|
joachim99@98
|
1396 QString lastLineOfStart = iMLLStart->mergeEditLineList.back().getString(this);
|
joachim99@98
|
1397 QString firstLineOfEnd = iMLLEnd->mergeEditLineList.front().getString(this);
|
joachim99@98
|
1398 if ( lastLineOfStart.mid(lead.length()).trimmed().isEmpty() && firstLineOfEnd.mid(lead.length()).trimmed().isEmpty() )
|
joachim99@98
|
1399 iMLLStart->mergeEditLineList.pop_back();
|
joachim99@98
|
1400 }
|
joachim99@69
|
1401 }
|
joachim99@69
|
1402 setFastSelector( iMLLStart );
|
joachim99@69
|
1403 update();
|
joachim99@69
|
1404 }
|
joachim99@69
|
1405 }
|
joachim99@69
|
1406
|
joachim99@69
|
1407 void MergeResultWindow::slotRegExpAutoMerge()
|
joachim99@69
|
1408 {
|
joachim99@69
|
1409 if ( m_pOptionDialog->m_autoMergeRegExp.isEmpty() )
|
joachim99@69
|
1410 return;
|
joachim99@69
|
1411
|
joachim99@70
|
1412 QRegExp vcsKeywords( m_pOptionDialog->m_autoMergeRegExp );
|
joachim99@69
|
1413 MergeLineList::iterator i;
|
joachim99@69
|
1414 for ( i=m_mergeLineList.begin(); i!=m_mergeLineList.end(); ++i )
|
joachim99@69
|
1415 {
|
joachim99@69
|
1416 if (i->bConflict )
|
joachim99@69
|
1417 {
|
joachim99@69
|
1418 Diff3LineList::const_iterator id3l = i->id3l;
|
joachim99@69
|
1419 if ( vcsKeywords.exactMatch( id3l->getString(A) ) &&
|
joachim99@69
|
1420 vcsKeywords.exactMatch( id3l->getString(B) ) &&
|
joachim99@69
|
1421 (m_pldC==0 || vcsKeywords.exactMatch( id3l->getString(C) )))
|
joachim99@69
|
1422 {
|
joachim99@69
|
1423 MergeEditLine& mel = *i->mergeEditLineList.begin();
|
joachim99@69
|
1424 mel.setSource( m_pldC==0 ? B : C, false );
|
joachim99@69
|
1425 splitAtDiff3LineIdx( i->d3lLineIdx+1 );
|
joachim99@69
|
1426 }
|
joachim99@69
|
1427 }
|
joachim99@69
|
1428 }
|
joachim99@69
|
1429 update();
|
joachim99@69
|
1430 }
|
joachim99@69
|
1431
|
joachim99@69
|
1432 // This doesn't detect user modifications and should only be called after automatic merge
|
joachim99@69
|
1433 // This will only do something for three file merge.
|
joachim99@69
|
1434 // Irrelevant changes are those where all contributions from B are already contained in C.
|
joachim99@69
|
1435 // Also irrelevant are conflicts automatically solved (automerge regexp and history automerge)
|
joachim99@69
|
1436 // Precondition: The VCS-keyword would also be C.
|
joachim99@69
|
1437 bool MergeResultWindow::doRelevantChangesExist()
|
joachim99@69
|
1438 {
|
joachim99@69
|
1439 if ( m_pldC==0 || m_mergeLineList.size() <= 1 )
|
joachim99@69
|
1440 return true;
|
joachim99@69
|
1441
|
joachim99@69
|
1442 MergeLineList::iterator i;
|
joachim99@69
|
1443 for ( i=m_mergeLineList.begin(); i!=m_mergeLineList.end(); ++i )
|
joachim99@69
|
1444 {
|
joachim99@69
|
1445 if ( ( i->bConflict && i->mergeEditLineList.begin()->src()!=C )
|
joachim99@69
|
1446 || i->srcSelect == B )
|
joachim99@69
|
1447 {
|
joachim99@69
|
1448 return true;
|
joachim99@69
|
1449 }
|
joachim99@69
|
1450 }
|
joachim99@69
|
1451
|
joachim99@69
|
1452 return false;
|
joachim99@69
|
1453 }
|
joachim99@69
|
1454
|
joachim99@69
|
1455 // Returns the iterator to the MergeLine after the split
|
joachim99@69
|
1456 MergeResultWindow::MergeLineList::iterator MergeResultWindow::splitAtDiff3LineIdx( int d3lLineIdx )
|
joachim99@69
|
1457 {
|
joachim99@69
|
1458 MergeLineList::iterator i;
|
joachim99@69
|
1459 for ( i = m_mergeLineList.begin(); i!=m_mergeLineList.end(); ++i )
|
joachim99@69
|
1460 {
|
joachim99@69
|
1461 if ( i->d3lLineIdx==d3lLineIdx )
|
joachim99@69
|
1462 {
|
joachim99@69
|
1463 // No split needed, this is the beginning of a MergeLine
|
joachim99@69
|
1464 return i;
|
joachim99@69
|
1465 }
|
joachim99@69
|
1466 else if ( i->d3lLineIdx > d3lLineIdx )
|
joachim99@69
|
1467 {
|
joachim99@69
|
1468 // The split must be in the previous MergeLine
|
joachim99@69
|
1469 --i;
|
joachim99@69
|
1470 MergeLine& ml = *i;
|
joachim99@69
|
1471 MergeLine newML;
|
joachim99@69
|
1472 ml.split(newML,d3lLineIdx);
|
joachim99@69
|
1473 ++i;
|
joachim99@69
|
1474 return m_mergeLineList.insert( i, newML );
|
joachim99@69
|
1475 }
|
joachim99@69
|
1476 }
|
joachim99@69
|
1477 // The split must be in the previous MergeLine
|
joachim99@69
|
1478 --i;
|
joachim99@69
|
1479 MergeLine& ml = *i;
|
joachim99@69
|
1480 MergeLine newML;
|
joachim99@69
|
1481 ml.split(newML,d3lLineIdx);
|
joachim99@69
|
1482 ++i;
|
joachim99@69
|
1483 return m_mergeLineList.insert( i, newML );
|
joachim99@69
|
1484 }
|
joachim99@69
|
1485
|
joachim99@69
|
1486 void MergeResultWindow::slotSplitDiff( int firstD3lLineIdx, int lastD3lLineIdx )
|
joachim99@69
|
1487 {
|
joachim99@69
|
1488 if (lastD3lLineIdx>=0)
|
joachim99@69
|
1489 splitAtDiff3LineIdx( lastD3lLineIdx + 1 );
|
joachim99@69
|
1490 setFastSelector( splitAtDiff3LineIdx(firstD3lLineIdx) );
|
joachim99@69
|
1491 }
|
joachim99@69
|
1492
|
joachim99@69
|
1493 void MergeResultWindow::slotJoinDiffs( int firstD3lLineIdx, int lastD3lLineIdx )
|
joachim99@69
|
1494 {
|
joachim99@69
|
1495 MergeLineList::iterator i;
|
joachim99@69
|
1496 MergeLineList::iterator iMLLStart = m_mergeLineList.end();
|
joachim99@69
|
1497 MergeLineList::iterator iMLLEnd = m_mergeLineList.end();
|
joachim99@69
|
1498 for ( i=m_mergeLineList.begin(); i!=m_mergeLineList.end(); ++i )
|
joachim99@69
|
1499 {
|
joachim99@69
|
1500 MergeLine& ml = *i;
|
joachim99@69
|
1501 if ( firstD3lLineIdx >= ml.d3lLineIdx && firstD3lLineIdx < ml.d3lLineIdx + ml.srcRangeLength )
|
joachim99@69
|
1502 {
|
joachim99@69
|
1503 iMLLStart = i;
|
joachim99@69
|
1504 }
|
joachim99@69
|
1505 if ( lastD3lLineIdx >= ml.d3lLineIdx && lastD3lLineIdx < ml.d3lLineIdx + ml.srcRangeLength )
|
joachim99@69
|
1506 {
|
joachim99@69
|
1507 iMLLEnd = i;
|
joachim99@69
|
1508 ++iMLLEnd;
|
joachim99@69
|
1509 break;
|
joachim99@69
|
1510 }
|
joachim99@69
|
1511 }
|
joachim99@69
|
1512
|
joachim99@69
|
1513 bool bJoined = false;
|
joachim99@69
|
1514 for( i=iMLLStart; i!=iMLLEnd && i!=m_mergeLineList.end(); )
|
joachim99@69
|
1515 {
|
joachim99@69
|
1516 if ( i==iMLLStart )
|
joachim99@69
|
1517 {
|
joachim99@69
|
1518 ++i;
|
joachim99@69
|
1519 }
|
joachim99@69
|
1520 else
|
joachim99@69
|
1521 {
|
joachim99@69
|
1522 iMLLStart->join(*i);
|
joachim99@69
|
1523 i = m_mergeLineList.erase( i );
|
joachim99@69
|
1524 bJoined = true;
|
joachim99@69
|
1525 }
|
joachim99@69
|
1526 }
|
joachim99@69
|
1527 if (bJoined)
|
joachim99@69
|
1528 {
|
joachim99@69
|
1529 iMLLStart->mergeEditLineList.clear();
|
joachim99@69
|
1530 // Insert a conflict line as placeholder
|
joachim99@69
|
1531 iMLLStart->mergeEditLineList.push_back( MergeEditLine( iMLLStart->id3l ) );
|
joachim99@69
|
1532 }
|
joachim99@69
|
1533 setFastSelector( iMLLStart );
|
joachim99@8
|
1534 }
|
joachim99@8
|
1535
|
joachim99@8
|
1536 void MergeResultWindow::myUpdate(int afterMilliSecs)
|
joachim99@8
|
1537 {
|
joachim99@75
|
1538 if ( m_delayedDrawTimer )
|
joachim99@75
|
1539 killTimer(m_delayedDrawTimer);
|
joachim99@8
|
1540 m_bMyUpdate = true;
|
joachim99@69
|
1541 m_delayedDrawTimer = startTimer( afterMilliSecs );
|
joachim99@8
|
1542 }
|
joachim99@8
|
1543
|
joachim99@8
|
1544 void MergeResultWindow::timerEvent(QTimerEvent*)
|
joachim99@8
|
1545 {
|
joachim99@69
|
1546 killTimer(m_delayedDrawTimer);
|
joachim99@69
|
1547 m_delayedDrawTimer = 0;
|
joachim99@8
|
1548
|
joachim99@8
|
1549 if ( m_bMyUpdate )
|
joachim99@8
|
1550 {
|
joachim99@69
|
1551 update();
|
joachim99@8
|
1552 m_bMyUpdate = false;
|
joachim99@8
|
1553 }
|
joachim99@8
|
1554
|
joachim99@8
|
1555 if ( m_scrollDeltaX != 0 || m_scrollDeltaY != 0 )
|
joachim99@8
|
1556 {
|
joachim99@8
|
1557 m_selection.end( m_selection.lastLine + m_scrollDeltaY, m_selection.lastPos + m_scrollDeltaX );
|
joachim99@8
|
1558 emit scroll( m_scrollDeltaX, m_scrollDeltaY );
|
joachim99@69
|
1559 killTimer(m_delayedDrawTimer);
|
joachim99@69
|
1560 m_delayedDrawTimer = startTimer(50);
|
joachim99@8
|
1561 }
|
joachim99@8
|
1562 }
|
joachim99@8
|
1563
|
joachim99@68
|
1564 QString MergeResultWindow::MergeEditLine::getString( const MergeResultWindow* mrw )
|
joachim99@8
|
1565 {
|
joachim99@68
|
1566 if ( isRemoved() ) { return QString(); }
|
joachim99@8
|
1567
|
joachim99@8
|
1568 if ( ! isModified() )
|
joachim99@8
|
1569 {
|
joachim99@8
|
1570 int src = m_src;
|
joachim99@77
|
1571 if ( src == 0 ) { return QString(); }
|
joachim99@8
|
1572 const Diff3Line& d3l = *m_id3l;
|
joachim99@8
|
1573 const LineData* pld = 0;
|
joachim99@8
|
1574 assert( src == A || src == B || src == C );
|
joachim99@8
|
1575 if ( src == A && d3l.lineA!=-1 ) pld = &mrw->m_pldA[ d3l.lineA ];
|
joachim99@8
|
1576 else if ( src == B && d3l.lineB!=-1 ) pld = &mrw->m_pldB[ d3l.lineB ];
|
joachim99@8
|
1577 else if ( src == C && d3l.lineC!=-1 ) pld = &mrw->m_pldC[ d3l.lineC ];
|
joachim99@8
|
1578
|
joachim99@8
|
1579 if ( pld == 0 )
|
joachim99@8
|
1580 {
|
joachim99@8
|
1581 // assert(false); This is no error.
|
joachim99@68
|
1582 return QString();
|
joachim99@8
|
1583 }
|
joachim99@8
|
1584
|
joachim99@68
|
1585 return QString( pld->pLine, pld->size );
|
joachim99@8
|
1586 }
|
joachim99@8
|
1587 else
|
joachim99@8
|
1588 {
|
joachim99@8
|
1589 return m_str;
|
joachim99@8
|
1590 }
|
joachim99@8
|
1591 return 0;
|
joachim99@8
|
1592 }
|
joachim99@8
|
1593
|
joachim99@8
|
1594 /// Converts the cursor-posOnScreen into a text index, considering tabulators.
|
joachim99@69
|
1595 int convertToPosInText( const QString& s, int posOnScreen, int tabSize )
|
joachim99@8
|
1596 {
|
joachim99@8
|
1597 int localPosOnScreen = 0;
|
joachim99@68
|
1598 int size=s.length();
|
joachim99@8
|
1599 for ( int i=0; i<size; ++i )
|
joachim99@8
|
1600 {
|
joachim99@8
|
1601 if ( localPosOnScreen>=posOnScreen )
|
joachim99@8
|
1602 return i;
|
joachim99@8
|
1603
|
joachim99@8
|
1604 // All letters except tabulator have width one.
|
joachim99@69
|
1605 int letterWidth = s[i]!='\t' ? 1 : tabber( localPosOnScreen, tabSize );
|
joachim99@8
|
1606
|
joachim99@8
|
1607 localPosOnScreen += letterWidth;
|
joachim99@8
|
1608
|
joachim99@8
|
1609 if ( localPosOnScreen>posOnScreen )
|
joachim99@8
|
1610 return i;
|
joachim99@8
|
1611 }
|
joachim99@8
|
1612 return size;
|
joachim99@8
|
1613 }
|
joachim99@8
|
1614
|
joachim99@8
|
1615
|
joachim99@8
|
1616 /// Converts the index into the text to a cursor-posOnScreen considering tabulators.
|
joachim99@69
|
1617 int convertToPosOnScreen( const QString& p, int posInText, int tabSize )
|
joachim99@8
|
1618 {
|
joachim99@8
|
1619 int posOnScreen = 0;
|
joachim99@8
|
1620 for ( int i=0; i<posInText; ++i )
|
joachim99@8
|
1621 {
|
joachim99@8
|
1622 // All letters except tabulator have width one.
|
joachim99@69
|
1623 int letterWidth = p[i]!='\t' ? 1 : tabber( posOnScreen, tabSize );
|
joachim99@8
|
1624
|
joachim99@8
|
1625 posOnScreen += letterWidth;
|
joachim99@8
|
1626 }
|
joachim99@8
|
1627 return posOnScreen;
|
joachim99@8
|
1628 }
|
joachim99@8
|
1629
|
joachim99@8
|
1630 void MergeResultWindow::writeLine(
|
joachim99@68
|
1631 MyPainter& p, int line, const QString& str,
|
joachim99@68
|
1632 int srcSelect, e_MergeDetails mergeDetails, int rangeMark, bool bUserModified, bool bLineRemoved, bool bWhiteSpaceConflict
|
joachim99@8
|
1633 )
|
joachim99@8
|
1634 {
|
joachim99@8
|
1635 const QFontMetrics& fm = fontMetrics();
|
joachim99@8
|
1636 int fontHeight = fm.height();
|
joachim99@8
|
1637 int fontWidth = fm.width("W");
|
joachim99@8
|
1638 int fontAscent = fm.ascent();
|
joachim99@8
|
1639
|
joachim99@75
|
1640 int topLineYOffset = 0;
|
joachim99@8
|
1641 int xOffset = fontWidth * leftInfoWidth;
|
joachim99@8
|
1642
|
joachim99@8
|
1643 int yOffset = ( line-m_firstLine ) * fontHeight;
|
joachim99@8
|
1644 if ( yOffset < 0 || yOffset > height() )
|
joachim99@8
|
1645 return;
|
joachim99@8
|
1646
|
joachim99@8
|
1647 yOffset += topLineYOffset;
|
joachim99@8
|
1648
|
joachim99@8
|
1649 QString srcName = " ";
|
joachim99@8
|
1650 if ( bUserModified ) srcName = "m";
|
joachim99@8
|
1651 else if ( srcSelect == A && mergeDetails != eNoChange ) srcName = "A";
|
joachim99@8
|
1652 else if ( srcSelect == B ) srcName = "B";
|
joachim99@8
|
1653 else if ( srcSelect == C ) srcName = "C";
|
joachim99@8
|
1654
|
joachim99@8
|
1655 if ( rangeMark & 4 )
|
joachim99@8
|
1656 {
|
joachim99@8
|
1657 p.fillRect( xOffset, yOffset, width(), fontHeight, m_pOptionDialog->m_currentRangeBgColor );
|
joachim99@8
|
1658 }
|
joachim99@68
|
1659
|
joachim99@8
|
1660 if( (srcSelect > 0 || bUserModified ) && !bLineRemoved )
|
joachim99@8
|
1661 {
|
joachim99@8
|
1662 int outPos = 0;
|
joachim99@68
|
1663 QString s;
|
joachim99@68
|
1664 int size = str.length();
|
joachim99@8
|
1665 for ( int i=0; i<size; ++i )
|
joachim99@8
|
1666 {
|
joachim99@8
|
1667 int spaces = 1;
|
joachim99@68
|
1668 if ( str[i]=='\t' )
|
joachim99@8
|
1669 {
|
joachim99@69
|
1670 spaces = tabber( outPos, m_pOptionDialog->m_tabSize );
|
joachim99@8
|
1671 for( int j=0; j<spaces; ++j )
|
joachim99@8
|
1672 s+=' ';
|
joachim99@8
|
1673 }
|
joachim99@8
|
1674 else
|
joachim99@8
|
1675 {
|
joachim99@68
|
1676 s+=str[i];
|
joachim99@8
|
1677 }
|
joachim99@8
|
1678 outPos += spaces;
|
joachim99@8
|
1679 }
|
joachim99@8
|
1680
|
joachim99@8
|
1681 if ( m_selection.lineWithin( line ) )
|
joachim99@8
|
1682 {
|
joachim99@69
|
1683 int firstPosInLine = convertToPosOnScreen( str, convertToPosInText( str, m_selection.firstPosInLine(line), m_pOptionDialog->m_tabSize ),m_pOptionDialog->m_tabSize );
|
joachim99@69
|
1684 int lastPosInLine = convertToPosOnScreen( str, convertToPosInText( str, m_selection.lastPosInLine(line), m_pOptionDialog->m_tabSize ), m_pOptionDialog->m_tabSize );
|
joachim99@8
|
1685 int lengthInLine = max2(0,lastPosInLine - firstPosInLine);
|
joachim99@8
|
1686 if (lengthInLine>0) m_selection.bSelectionContainsData = true;
|
joachim99@8
|
1687
|
joachim99@8
|
1688 if ( lengthInLine < int(s.length()) )
|
joachim99@8
|
1689 { // Draw a normal line first
|
joachim99@8
|
1690 p.setPen( m_pOptionDialog->m_fgColor );
|
joachim99@68
|
1691 p.drawText( xOffset, yOffset+fontAscent, s.mid(m_firstColumn), true );
|
joachim99@8
|
1692 }
|
joachim99@8
|
1693 int firstPosInLine2 = max2( firstPosInLine, m_firstColumn );
|
joachim99@8
|
1694 int lengthInLine2 = max2(0,lastPosInLine - firstPosInLine2);
|
joachim99@8
|
1695
|
joachim99@8
|
1696 if( m_selection.lineWithin( line+1 ) )
|
joachim99@8
|
1697 p.fillRect( xOffset + fontWidth*(firstPosInLine2-m_firstColumn), yOffset,
|
joachim99@75
|
1698 width(), fontHeight, palette().highlight() );
|
joachim99@69
|
1699 else if ( lengthInLine2>0 )
|
joachim99@8
|
1700 p.fillRect( xOffset + fontWidth*(firstPosInLine2-m_firstColumn), yOffset,
|
joachim99@75
|
1701 fontWidth*lengthInLine2, fontHeight, palette().highlight() );
|
joachim99@75
|
1702
|
joachim99@75
|
1703 p.setPen( palette().highlightedText().color() );
|
joachim99@8
|
1704 p.drawText( xOffset + fontWidth*(firstPosInLine2-m_firstColumn), yOffset+fontAscent,
|
joachim99@68
|
1705 s.mid(firstPosInLine2,lengthInLine2), true );
|
joachim99@8
|
1706 }
|
joachim99@8
|
1707 else
|
joachim99@8
|
1708 {
|
joachim99@8
|
1709 p.setPen( m_pOptionDialog->m_fgColor );
|
joachim99@68
|
1710 p.drawText( xOffset, yOffset+fontAscent, s.mid(m_firstColumn), true );
|
joachim99@8
|
1711 }
|
joachim99@8
|
1712
|
joachim99@8
|
1713 p.setPen( m_pOptionDialog->m_fgColor );
|
joachim99@8
|
1714 if ( m_cursorYPos==line )
|
joachim99@8
|
1715 {
|
joachim99@8
|
1716 m_cursorXPos = minMaxLimiter( m_cursorXPos, 0, outPos );
|
joachim99@69
|
1717 m_cursorXPos = convertToPosOnScreen( str, convertToPosInText( str, m_cursorXPos, m_pOptionDialog->m_tabSize ),m_pOptionDialog->m_tabSize );
|
joachim99@8
|
1718 }
|
joachim99@8
|
1719
|
joachim99@68
|
1720 p.drawText( 1, yOffset+fontAscent, srcName, true );
|
joachim99@8
|
1721 }
|
joachim99@8
|
1722 else if ( bLineRemoved )
|
joachim99@8
|
1723 {
|
joachim99@8
|
1724 p.setPen( m_pOptionDialog->m_colorForConflict );
|
joachim99@8
|
1725 p.drawText( xOffset, yOffset+fontAscent, i18n("<No src line>") );
|
joachim99@8
|
1726 p.drawText( 1, yOffset+fontAscent, srcName );
|
joachim99@8
|
1727 if ( m_cursorYPos==line ) m_cursorXPos = 0;
|
joachim99@8
|
1728 }
|
joachim99@8
|
1729 else if ( srcSelect == 0 )
|
joachim99@8
|
1730 {
|
joachim99@8
|
1731 p.setPen( m_pOptionDialog->m_colorForConflict );
|
joachim99@68
|
1732 if ( bWhiteSpaceConflict )
|
joachim99@68
|
1733 p.drawText( xOffset, yOffset+fontAscent, i18n("<Merge Conflict (Whitespace only)>") );
|
joachim99@68
|
1734 else
|
joachim99@68
|
1735 p.drawText( xOffset, yOffset+fontAscent, i18n("<Merge Conflict>") );
|
joachim99@8
|
1736 p.drawText( 1, yOffset+fontAscent, "?" );
|
joachim99@8
|
1737 if ( m_cursorYPos==line ) m_cursorXPos = 0;
|
joachim99@8
|
1738 }
|
joachim99@8
|
1739 else assert(false);
|
joachim99@8
|
1740
|
joachim99@8
|
1741 xOffset -= fontWidth;
|
joachim99@8
|
1742 p.setPen( m_pOptionDialog->m_fgColor );
|
joachim99@8
|
1743 if ( rangeMark & 1 ) // begin mark
|
joachim99@8
|
1744 {
|
joachim99@8
|
1745 p.drawLine( xOffset, yOffset+1, xOffset, yOffset+fontHeight/2 );
|
joachim99@8
|
1746 p.drawLine( xOffset, yOffset+1, xOffset-2, yOffset+1 );
|
joachim99@8
|
1747 }
|
joachim99@8
|
1748 else
|
joachim99@8
|
1749 {
|
joachim99@8
|
1750 p.drawLine( xOffset, yOffset, xOffset, yOffset+fontHeight/2 );
|
joachim99@8
|
1751 }
|
joachim99@8
|
1752
|
joachim99@8
|
1753 if ( rangeMark & 2 ) // end mark
|
joachim99@8
|
1754 {
|
joachim99@8
|
1755 p.drawLine( xOffset, yOffset+fontHeight/2, xOffset, yOffset+fontHeight-1 );
|
joachim99@8
|
1756 p.drawLine( xOffset, yOffset+fontHeight-1, xOffset-2, yOffset+fontHeight-1 );
|
joachim99@8
|
1757 }
|
joachim99@8
|
1758 else
|
joachim99@8
|
1759 {
|
joachim99@8
|
1760 p.drawLine( xOffset, yOffset+fontHeight/2, xOffset, yOffset+fontHeight );
|
joachim99@8
|
1761 }
|
joachim99@8
|
1762
|
joachim99@8
|
1763 if ( rangeMark & 4 )
|
joachim99@8
|
1764 {
|
joachim99@8
|
1765 p.fillRect( xOffset + 3, yOffset, 3, fontHeight, m_pOptionDialog->m_fgColor );
|
joachim99@8
|
1766 /* p.setPen( blue );
|
joachim99@8
|
1767 p.drawLine( xOffset+2, yOffset, xOffset+2, yOffset+fontHeight-1 );
|
joachim99@8
|
1768 p.drawLine( xOffset+3, yOffset, xOffset+3, yOffset+fontHeight-1 );*/
|
joachim99@8
|
1769 }
|
joachim99@8
|
1770 }
|
joachim99@8
|
1771
|
joachim99@58
|
1772 void MergeResultWindow::setPaintingAllowed(bool bPaintingAllowed)
|
joachim99@58
|
1773 {
|
joachim99@58
|
1774 m_bPaintingAllowed = bPaintingAllowed;
|
joachim99@66
|
1775 if ( !m_bPaintingAllowed )
|
joachim99@69
|
1776 {
|
joachim99@66
|
1777 m_currentMergeLineIt = m_mergeLineList.end();
|
joachim99@69
|
1778 reset();
|
joachim99@69
|
1779 }
|
joachim99@80
|
1780 update();
|
joachim99@58
|
1781 }
|
joachim99@58
|
1782
|
joachim99@80
|
1783 void MergeResultWindow::paintEvent( QPaintEvent* )
|
joachim99@8
|
1784 {
|
joachim99@80
|
1785 if (m_pDiff3LineList==0 || !m_bPaintingAllowed)
|
joachim99@80
|
1786 return;
|
joachim99@8
|
1787
|
joachim99@8
|
1788 bool bOldSelectionContainsData = m_selection.bSelectionContainsData;
|
joachim99@8
|
1789 const QFontMetrics& fm = fontMetrics();
|
joachim99@8
|
1790 int fontHeight = fm.height();
|
joachim99@8
|
1791 int fontWidth = fm.width("W");
|
joachim99@8
|
1792 int fontAscent = fm.ascent();
|
joachim99@8
|
1793
|
joachim99@69
|
1794 if ( !m_bCursorUpdate ) // Don't redraw everything for blinking cursor?
|
joachim99@8
|
1795 {
|
joachim99@8
|
1796 m_selection.bSelectionContainsData = false;
|
joachim99@8
|
1797 if ( size() != m_pixmap.size() )
|
joachim99@75
|
1798 m_pixmap = QPixmap(size());
|
joachim99@8
|
1799
|
joachim99@68
|
1800 MyPainter p(&m_pixmap, m_pOptionDialog->m_bRightToLeftLanguage, width(), fontWidth);
|
joachim99@8
|
1801 p.setFont( font() );
|
joachim99@68
|
1802 p.QPainter::fillRect( rect(), m_pOptionDialog->m_bgColor );
|
joachim99@8
|
1803
|
joachim99@8
|
1804 //int visibleLines = height() / fontHeight;
|
joachim99@8
|
1805
|
joachim99@8
|
1806 int lastVisibleLine = m_firstLine + getNofVisibleLines() + 5;
|
joachim99@8
|
1807 int nofColumns = 0;
|
joachim99@8
|
1808 int line = 0;
|
joachim99@8
|
1809 MergeLineList::iterator mlIt = m_mergeLineList.begin();
|
joachim99@8
|
1810 for(mlIt = m_mergeLineList.begin();mlIt!=m_mergeLineList.end(); ++mlIt)
|
joachim99@8
|
1811 {
|
joachim99@8
|
1812 MergeLine& ml = *mlIt;
|
joachim99@8
|
1813 if ( line > lastVisibleLine || line + ml.mergeEditLineList.size() < m_firstLine)
|
joachim99@8
|
1814 {
|
joachim99@8
|
1815 line += ml.mergeEditLineList.size();
|
joachim99@8
|
1816 }
|
joachim99@8
|
1817 else
|
joachim99@8
|
1818 {
|
joachim99@8
|
1819 MergeEditLineList::iterator melIt;
|
joachim99@8
|
1820 for( melIt = ml.mergeEditLineList.begin(); melIt != ml.mergeEditLineList.end(); ++melIt )
|
joachim99@8
|
1821 {
|
joachim99@8
|
1822 if (line>=m_firstLine && line<=lastVisibleLine)
|
joachim99@8
|
1823 {
|
joachim99@8
|
1824 MergeEditLine& mel = *melIt;
|
joachim99@8
|
1825 MergeEditLineList::iterator melIt1 = melIt;
|
joachim99@8
|
1826 ++melIt1;
|
joachim99@8
|
1827
|
joachim99@8
|
1828 int rangeMark = 0;
|
joachim99@8
|
1829 if ( melIt==ml.mergeEditLineList.begin() ) rangeMark |= 1; // Begin range mark
|
joachim99@8
|
1830 if ( melIt1==ml.mergeEditLineList.end() ) rangeMark |= 2; // End range mark
|
joachim99@8
|
1831
|
joachim99@8
|
1832 if ( mlIt == m_currentMergeLineIt ) rangeMark |= 4; // Mark of the current line
|
joachim99@8
|
1833
|
joachim99@68
|
1834 QString s;
|
joachim99@68
|
1835 s = mel.getString( this );
|
joachim99@69
|
1836 if ( convertToPosOnScreen(s,s.length(),m_pOptionDialog->m_tabSize) >nofColumns)
|
joachim99@68
|
1837 nofColumns = s.length();
|
joachim99@8
|
1838
|
joachim99@68
|
1839 writeLine( p, line, s, mel.src(), ml.mergeDetails, rangeMark,
|
joachim99@68
|
1840 mel.isModified(), mel.isRemoved(), ml.bWhiteSpaceConflict );
|
joachim99@8
|
1841 }
|
joachim99@8
|
1842 ++line;
|
joachim99@8
|
1843 }
|
joachim99@8
|
1844 }
|
joachim99@8
|
1845 }
|
joachim99@8
|
1846
|
joachim99@8
|
1847 if ( line != m_nofLines || nofColumns != m_nofColumns )
|
joachim99@8
|
1848 {
|
joachim99@8
|
1849 m_nofLines = line;
|
joachim99@58
|
1850 assert( m_nofLines == m_totalSize );
|
joachim99@8
|
1851
|
joachim99@8
|
1852 m_nofColumns = nofColumns;
|
joachim99@8
|
1853 emit resizeSignal();
|
joachim99@8
|
1854 }
|
joachim99@8
|
1855
|
joachim99@8
|
1856 p.end();
|
joachim99@8
|
1857 }
|
joachim99@8
|
1858
|
joachim99@8
|
1859 QPainter painter(this);
|
joachim99@8
|
1860
|
joachim99@75
|
1861 int topLineYOffset = 0;
|
joachim99@8
|
1862 int xOffset = fontWidth * leftInfoWidth;
|
joachim99@8
|
1863 int yOffset = ( m_cursorYPos - m_firstLine ) * fontHeight + topLineYOffset;
|
joachim99@8
|
1864 int xCursor = ( m_cursorXPos - m_firstColumn ) * fontWidth + xOffset;
|
joachim99@8
|
1865
|
joachim99@69
|
1866 if ( !m_bCursorUpdate )
|
joachim99@8
|
1867 painter.drawPixmap(0,0, m_pixmap);
|
joachim99@8
|
1868 else
|
joachim99@68
|
1869 {
|
joachim99@80
|
1870 painter.drawPixmap(0,0, m_pixmap ); // Draw everything. (Internally cursor rect is clipped anyway.)
|
joachim99@80
|
1871 //if (!m_pOptionDialog->m_bRightToLeftLanguage)
|
joachim99@80
|
1872 // painter.drawPixmap(xCursor-2, yOffset, m_pixmap,
|
joachim99@80
|
1873 // xCursor-2, yOffset, 5, fontAscent+2 );
|
joachim99@80
|
1874 //else
|
joachim99@80
|
1875 // painter.drawPixmap(width()-1-4-(xCursor-2), yOffset, m_pixmap,
|
joachim99@80
|
1876 // width()-1-4-(xCursor-2), yOffset, 5, fontAscent+2 );
|
joachim99@69
|
1877 m_bCursorUpdate = false;
|
joachim99@68
|
1878 }
|
joachim99@69
|
1879 painter.end();
|
joachim99@8
|
1880
|
joachim99@8
|
1881 if ( m_bCursorOn && hasFocus() && m_cursorYPos>=m_firstLine )
|
joachim99@8
|
1882 {
|
joachim99@68
|
1883 MyPainter painter(this, m_pOptionDialog->m_bRightToLeftLanguage, width(), fontWidth);
|
joachim99@75
|
1884 int topLineYOffset = 0;
|
joachim99@8
|
1885 int xOffset = fontWidth * leftInfoWidth;
|
joachim99@8
|
1886
|
joachim99@8
|
1887 int yOffset = ( m_cursorYPos-m_firstLine ) * fontHeight + topLineYOffset;
|
joachim99@8
|
1888
|
joachim99@8
|
1889 int xCursor = ( m_cursorXPos - m_firstColumn ) * fontWidth + xOffset;
|
joachim99@66
|
1890
|
joachim99@66
|
1891 painter.setPen( m_pOptionDialog->m_fgColor );
|
joachim99@66
|
1892
|
joachim99@8
|
1893 painter.drawLine( xCursor, yOffset, xCursor, yOffset+fontAscent );
|
joachim99@8
|
1894 painter.drawLine( xCursor-2, yOffset, xCursor+2, yOffset );
|
joachim99@8
|
1895 painter.drawLine( xCursor-2, yOffset+fontAscent+1, xCursor+2, yOffset+fontAscent+1 );
|
joachim99@8
|
1896 }
|
joachim99@8
|
1897
|
joachim99@8
|
1898 if( !bOldSelectionContainsData && m_selection.bSelectionContainsData )
|
joachim99@8
|
1899 emit newSelection();
|
joachim99@8
|
1900 }
|
joachim99@8
|
1901
|
joachim99@66
|
1902 void MergeResultWindow::updateSourceMask()
|
joachim99@66
|
1903 {
|
joachim99@66
|
1904 int srcMask=0;
|
joachim99@66
|
1905 int enabledMask = 0;
|
joachim99@66
|
1906 if( !hasFocus() || m_pDiff3LineList==0 || !m_bPaintingAllowed || m_currentMergeLineIt == m_mergeLineList.end() )
|
joachim99@66
|
1907 {
|
joachim99@66
|
1908 srcMask = 0;
|
joachim99@66
|
1909 enabledMask = 0;
|
joachim99@66
|
1910 }
|
joachim99@66
|
1911 else
|
joachim99@66
|
1912 {
|
joachim99@66
|
1913 enabledMask = m_pldC==0 ? 3 : 7;
|
joachim99@66
|
1914 MergeLine& ml = *m_currentMergeLineIt;
|
joachim99@66
|
1915
|
joachim99@66
|
1916 srcMask = 0;
|
joachim99@66
|
1917 bool bModified = false;
|
joachim99@66
|
1918 MergeEditLineList::iterator melIt;
|
joachim99@66
|
1919 for( melIt = ml.mergeEditLineList.begin(); melIt != ml.mergeEditLineList.end(); ++melIt )
|
joachim99@66
|
1920 {
|
joachim99@66
|
1921 MergeEditLine& mel = *melIt;
|
joachim99@66
|
1922 if ( mel.src()==1 ) srcMask |= 1;
|
joachim99@66
|
1923 if ( mel.src()==2 ) srcMask |= 2;
|
joachim99@66
|
1924 if ( mel.src()==3 ) srcMask |= 4;
|
joachim99@66
|
1925 if ( mel.isModified() || !mel.isEditableText() ) bModified = true;
|
joachim99@66
|
1926 }
|
joachim99@68
|
1927
|
joachim99@66
|
1928 if ( ml.mergeDetails == eNoChange )
|
joachim99@69
|
1929 {
|
joachim99@66
|
1930 srcMask = 0;
|
joachim99@66
|
1931 enabledMask = bModified ? 1 : 0;
|
joachim99@66
|
1932 }
|
joachim99@66
|
1933 }
|
joachim99@68
|
1934
|
joachim99@66
|
1935 emit sourceMask( srcMask, enabledMask );
|
joachim99@66
|
1936 }
|
joachim99@66
|
1937
|
joachim99@66
|
1938 void MergeResultWindow::focusInEvent( QFocusEvent* e )
|
joachim99@66
|
1939 {
|
joachim99@66
|
1940 updateSourceMask();
|
joachim99@66
|
1941 QWidget::focusInEvent(e);
|
joachim99@66
|
1942 }
|
joachim99@66
|
1943
|
joachim99@8
|
1944 void MergeResultWindow::convertToLinePos( int x, int y, int& line, int& pos )
|
joachim99@8
|
1945 {
|
joachim99@8
|
1946 const QFontMetrics& fm = fontMetrics();
|
joachim99@8
|
1947 int fontHeight = fm.height();
|
joachim99@8
|
1948 int fontWidth = fm.width('W');
|
joachim99@8
|
1949 int xOffset = (leftInfoWidth-m_firstColumn)*fontWidth;
|
joachim99@75
|
1950 int topLineYOffset = 0;
|
joachim99@8
|
1951
|
joachim99@8
|
1952 int yOffset = topLineYOffset - m_firstLine * fontHeight;
|
joachim99@8
|
1953
|
joachim99@58
|
1954 line = min2( ( y - yOffset ) / fontHeight, m_totalSize-1 );
|
joachim99@68
|
1955 if ( ! m_pOptionDialog->m_bRightToLeftLanguage )
|
joachim99@68
|
1956 pos = ( x - xOffset ) / fontWidth;
|
joachim99@68
|
1957 else
|
joachim99@68
|
1958 pos = ( (width() - 1 - x) - xOffset ) / fontWidth;
|
joachim99@8
|
1959 }
|
joachim99@8
|
1960
|
joachim99@8
|
1961 void MergeResultWindow::mousePressEvent ( QMouseEvent* e )
|
joachim99@8
|
1962 {
|
joachim99@8
|
1963 m_bCursorOn = true;
|
joachim99@8
|
1964
|
joachim99@8
|
1965 int line;
|
joachim99@8
|
1966 int pos;
|
joachim99@8
|
1967 convertToLinePos( e->x(), e->y(), line, pos );
|
joachim99@8
|
1968
|
joachim99@69
|
1969 bool bLMB = e->button() == Qt::LeftButton;
|
joachim99@69
|
1970 bool bMMB = e->button() == Qt::MidButton;
|
joachim99@69
|
1971 bool bRMB = e->button() == Qt::RightButton;
|
joachim99@8
|
1972
|
joachim99@8
|
1973 if ( bLMB && pos < m_firstColumn || bRMB ) // Fast range selection
|
joachim99@8
|
1974 {
|
joachim99@8
|
1975 m_cursorXPos = 0;
|
joachim99@8
|
1976 m_cursorOldXPos = 0;
|
joachim99@8
|
1977 m_cursorYPos = max2(line,0);
|
joachim99@8
|
1978 int l = 0;
|
joachim99@8
|
1979 MergeLineList::iterator i = m_mergeLineList.begin();
|
joachim99@8
|
1980 for(i = m_mergeLineList.begin();i!=m_mergeLineList.end(); ++i)
|
joachim99@8
|
1981 {
|
joachim99@8
|
1982 if (l==line)
|
joachim99@8
|
1983 break;
|
joachim99@8
|
1984
|
joachim99@8
|
1985 l += i->mergeEditLineList.size();
|
joachim99@8
|
1986 if (l>line)
|
joachim99@8
|
1987 break;
|
joachim99@8
|
1988 }
|
joachim99@8
|
1989 m_selection.reset(); // Disable current selection
|
joachim99@8
|
1990
|
joachim99@8
|
1991 m_bCursorOn = true;
|
joachim99@8
|
1992 setFastSelector( i );
|
joachim99@8
|
1993
|
joachim99@8
|
1994 if (bRMB)
|
joachim99@8
|
1995 {
|
joachim99@8
|
1996 showPopupMenu( QCursor::pos() );
|
joachim99@8
|
1997 }
|
joachim99@8
|
1998 }
|
joachim99@8
|
1999 else if ( bLMB ) // Normal cursor placement
|
joachim99@8
|
2000 {
|
joachim99@8
|
2001 pos = max2(pos,0);
|
joachim99@8
|
2002 line = max2(line,0);
|
joachim99@75
|
2003 if ( e->QInputEvent::modifiers() & Qt::ShiftModifier )
|
joachim99@8
|
2004 {
|
joachim99@8
|
2005 if (m_selection.firstLine==-1)
|
joachim99@8
|
2006 m_selection.start( line, pos );
|
joachim99@8
|
2007 m_selection.end( line, pos );
|
joachim99@8
|
2008 }
|
joachim99@8
|
2009 else
|
joachim99@8
|
2010 {
|
joachim99@8
|
2011 // Selection
|
joachim99@8
|
2012 m_selection.reset();
|
joachim99@8
|
2013 m_selection.start( line, pos );
|
joachim99@8
|
2014 m_selection.end( line, pos );
|
joachim99@8
|
2015 }
|
joachim99@8
|
2016 m_cursorXPos = pos;
|
joachim99@8
|
2017 m_cursorOldXPos = pos;
|
joachim99@8
|
2018 m_cursorYPos = line;
|
joachim99@8
|
2019
|
joachim99@8
|
2020 update();
|
joachim99@8
|
2021 //showStatusLine( line, m_winIdx, m_pFilename, m_pDiff3LineList, m_pStatusBar );
|
joachim99@8
|
2022 }
|
joachim99@8
|
2023 else if ( bMMB ) // Paste clipboard
|
joachim99@8
|
2024 {
|
joachim99@8
|
2025 pos = max2(pos,0);
|
joachim99@8
|
2026 line = max2(line,0);
|
joachim99@8
|
2027
|
joachim99@8
|
2028 m_selection.reset();
|
joachim99@8
|
2029 m_cursorXPos = pos;
|
joachim99@8
|
2030 m_cursorOldXPos = pos;
|
joachim99@8
|
2031 m_cursorYPos = line;
|
joachim99@8
|
2032
|
joachim99@66
|
2033 pasteClipboard( true );
|
joachim99@8
|
2034 }
|
joachim99@8
|
2035 }
|
joachim99@8
|
2036
|
joachim99@8
|
2037 void MergeResultWindow::mouseDoubleClickEvent( QMouseEvent* e )
|
joachim99@8
|
2038 {
|
joachim99@69
|
2039 if ( e->button() == Qt::LeftButton )
|
joachim99@8
|
2040 {
|
joachim99@8
|
2041 int line;
|
joachim99@8
|
2042 int pos;
|
joachim99@8
|
2043 convertToLinePos( e->x(), e->y(), line, pos );
|
joachim99@8
|
2044 m_cursorXPos = pos;
|
joachim99@8
|
2045 m_cursorOldXPos = pos;
|
joachim99@8
|
2046 m_cursorYPos = line;
|
joachim99@8
|
2047
|
joachim99@8
|
2048 // Get the string data of the current line
|
joachim99@8
|
2049
|
joachim99@8
|
2050 MergeLineList::iterator mlIt;
|
joachim99@8
|
2051 MergeEditLineList::iterator melIt;
|
joachim99@8
|
2052 calcIteratorFromLineNr( line, mlIt, melIt );
|
joachim99@68
|
2053 QString s = melIt->getString( this );
|
joachim99@8
|
2054
|
joachim99@68
|
2055 if ( !s.isEmpty() )
|
joachim99@8
|
2056 {
|
joachim99@8
|
2057 int pos1, pos2;
|
joachim99@8
|
2058
|
joachim99@69
|
2059 calcTokenPos( s, pos, pos1, pos2, m_pOptionDialog->m_tabSize );
|
joachim99@8
|
2060
|
joachim99@8
|
2061 resetSelection();
|
joachim99@69
|
2062 m_selection.start( line, convertToPosOnScreen( s, pos1, m_pOptionDialog->m_tabSize ) );
|
joachim99@69
|
2063 m_selection.end( line, convertToPosOnScreen( s, pos2, m_pOptionDialog->m_tabSize ) );
|
joachim99@8
|
2064
|
joachim99@8
|
2065 update();
|
joachim99@8
|
2066 // emit selectionEnd() happens in the mouseReleaseEvent.
|
joachim99@8
|
2067 }
|
joachim99@8
|
2068 }
|
joachim99@8
|
2069 }
|
joachim99@8
|
2070
|
joachim99@8
|
2071 void MergeResultWindow::mouseReleaseEvent ( QMouseEvent * e )
|
joachim99@8
|
2072 {
|
joachim99@69
|
2073 if ( e->button() == Qt::LeftButton )
|
joachim99@8
|
2074 {
|
joachim99@75
|
2075 if (m_delayedDrawTimer)
|
joachim99@75
|
2076 {
|
joachim99@75
|
2077 killTimer(m_delayedDrawTimer);
|
joachim99@75
|
2078 m_delayedDrawTimer = 0;
|
joachim99@75
|
2079 }
|
joachim99@8
|
2080
|
joachim99@8
|
2081 if (m_selection.firstLine != -1 )
|
joachim99@8
|
2082 {
|
joachim99@8
|
2083 emit selectionEnd();
|
joachim99@8
|
2084 }
|
joachim99@8
|
2085 }
|
joachim99@8
|
2086 }
|
joachim99@8
|
2087
|
joachim99@8
|
2088 void MergeResultWindow::mouseMoveEvent ( QMouseEvent * e )
|
joachim99@8
|
2089 {
|
joachim99@8
|
2090 int line;
|
joachim99@8
|
2091 int pos;
|
joachim99@8
|
2092 convertToLinePos( e->x(), e->y(), line, pos );
|
joachim99@8
|
2093 m_cursorXPos = pos;
|
joachim99@8
|
2094 m_cursorOldXPos = pos;
|
joachim99@8
|
2095 m_cursorYPos = line;
|
joachim99@8
|
2096 if (m_selection.firstLine != -1 )
|
joachim99@8
|
2097 {
|
joachim99@8
|
2098 m_selection.end( line, pos );
|
joachim99@8
|
2099 myUpdate(0);
|
joachim99@8
|
2100
|
joachim99@8
|
2101 //showStatusLine( line, m_winIdx, m_pFilename, m_pDiff3LineList, m_pStatusBar );
|
joachim99@8
|
2102
|
joachim99@8
|
2103 // Scroll because mouse moved out of the window
|
joachim99@8
|
2104 const QFontMetrics& fm = fontMetrics();
|
joachim99@8
|
2105 int fontWidth = fm.width('W');
|
joachim99@75
|
2106 int topLineYOffset = 0;
|
joachim99@8
|
2107 int deltaX=0;
|
joachim99@8
|
2108 int deltaY=0;
|
joachim99@68
|
2109 if ( ! m_pOptionDialog->m_bRightToLeftLanguage )
|
joachim99@68
|
2110 {
|
joachim99@68
|
2111 if ( e->x() < leftInfoWidth*fontWidth ) deltaX=-1;
|
joachim99@68
|
2112 if ( e->x() > width() ) deltaX=+1;
|
joachim99@68
|
2113 }
|
joachim99@68
|
2114 else
|
joachim99@68
|
2115 {
|
joachim99@68
|
2116 if ( e->x() > width()-1-leftInfoWidth*fontWidth ) deltaX=-1;
|
joachim99@68
|
2117 if ( e->x() < fontWidth ) deltaX=+1;
|
joachim99@68
|
2118 }
|
joachim99@8
|
2119 if ( e->y() < topLineYOffset ) deltaY=-1;
|
joachim99@8
|
2120 if ( e->y() > height() ) deltaY=+1;
|
joachim99@8
|
2121 m_scrollDeltaX = deltaX;
|
joachim99@8
|
2122 m_scrollDeltaY = deltaY;
|
joachim99@8
|
2123 if ( deltaX != 0 || deltaY!= 0)
|
joachim99@8
|
2124 {
|
joachim99@8
|
2125 emit scroll( deltaX, deltaY );
|
joachim99@8
|
2126 }
|
joachim99@8
|
2127 }
|
joachim99@8
|
2128 }
|
joachim99@8
|
2129
|
joachim99@8
|
2130
|
joachim99@8
|
2131 void MergeResultWindow::slotCursorUpdate()
|
joachim99@8
|
2132 {
|
joachim99@8
|
2133 m_cursorTimer.stop();
|
joachim99@8
|
2134 m_bCursorOn = !m_bCursorOn;
|
joachim99@8
|
2135
|
joachim99@8
|
2136 if ( isVisible() )
|
joachim99@69
|
2137 {
|
joachim99@69
|
2138 m_bCursorUpdate = true;
|
joachim99@69
|
2139
|
joachim99@69
|
2140 const QFontMetrics& fm = fontMetrics();
|
joachim99@69
|
2141 int fontWidth = fm.width("W");
|
joachim99@75
|
2142 int topLineYOffset = 0;
|
joachim99@69
|
2143 int xOffset = fontWidth * leftInfoWidth;
|
joachim99@69
|
2144 int yOffset = ( m_cursorYPos - m_firstLine ) * fm.height() + topLineYOffset;
|
joachim99@69
|
2145 int xCursor = ( m_cursorXPos - m_firstColumn ) * fontWidth + xOffset;
|
joachim99@69
|
2146
|
joachim99@69
|
2147 if (!m_pOptionDialog->m_bRightToLeftLanguage)
|
joachim99@69
|
2148 repaint( xCursor-2, yOffset, 5, fm.ascent()+2 );
|
joachim99@69
|
2149 else
|
joachim99@69
|
2150 repaint( width()-1-4-(xCursor-2), yOffset, 5, fm.ascent()+2 );
|
joachim99@69
|
2151
|
joachim99@69
|
2152 m_bCursorUpdate=false;
|
joachim99@69
|
2153 }
|
joachim99@8
|
2154
|
joachim99@75
|
2155 m_cursorTimer.start(500);
|
joachim99@8
|
2156 }
|
joachim99@8
|
2157
|
joachim99@8
|
2158
|
joachim99@8
|
2159 void MergeResultWindow::wheelEvent( QWheelEvent* e )
|
joachim99@8
|
2160 {
|
joachim99@8
|
2161 int d = -e->delta()*QApplication::wheelScrollLines()/120;
|
joachim99@8
|
2162 e->accept();
|
joachim99@8
|
2163 scroll( 0, min2(d, getNofVisibleLines()) );
|
joachim99@8
|
2164 }
|
joachim99@8
|
2165
|
joachim99@51
|
2166
|
joachim99@8
|
2167 void MergeResultWindow::keyPressEvent( QKeyEvent* e )
|
joachim99@8
|
2168 {
|
joachim99@8
|
2169 int y = m_cursorYPos;
|
joachim99@8
|
2170 MergeLineList::iterator mlIt;
|
joachim99@8
|
2171 MergeEditLineList::iterator melIt;
|
joachim99@8
|
2172 calcIteratorFromLineNr( y, mlIt, melIt );
|
joachim99@8
|
2173
|
joachim99@68
|
2174 QString str = melIt->getString( this );
|
joachim99@69
|
2175 int x = convertToPosInText( str, m_cursorXPos, m_pOptionDialog->m_tabSize );
|
joachim99@69
|
2176
|
joachim99@75
|
2177 bool bCtrl = ( e->QInputEvent::modifiers() & Qt::ControlModifier ) != 0 ;
|
joachim99@75
|
2178 bool bShift = ( e->QInputEvent::modifiers() & Qt::ShiftModifier ) != 0 ;
|
joachim99@8
|
2179 #ifdef _WIN32
|
joachim99@75
|
2180 bool bAlt = ( e->QInputEvent::modifiers() & Qt::AltModifier ) != 0 ;
|
joachim99@8
|
2181 if ( bCtrl && bAlt ){ bCtrl=false; bAlt=false; } // AltGr-Key pressed.
|
joachim99@8
|
2182 #endif
|
joachim99@8
|
2183
|
joachim99@8
|
2184 bool bYMoveKey = false;
|
joachim99@8
|
2185 // Special keys
|
joachim99@8
|
2186 switch ( e->key() )
|
joachim99@8
|
2187 {
|
joachim99@69
|
2188 case Qt::Key_Escape: break;
|
joachim99@8
|
2189 //case Key_Tab: break;
|
joachim99@69
|
2190 case Qt::Key_Backtab: break;
|
joachim99@69
|
2191 case Qt::Key_Delete:
|
joachim99@8
|
2192 {
|
joachim99@68
|
2193 if ( deleteSelection2( str, x, y, mlIt, melIt )) break;
|
joachim99@8
|
2194 if( !melIt->isEditableText() ) break;
|
joachim99@68
|
2195 if (x>=(int)str.length())
|
joachim99@8
|
2196 {
|
joachim99@58
|
2197 if ( y<m_totalSize-1 )
|
joachim99@8
|
2198 {
|
joachim99@8
|
2199 setModified();
|
joachim99@8
|
2200 MergeLineList::iterator mlIt1;
|
joachim99@8
|
2201 MergeEditLineList::iterator melIt1;
|
joachim99@8
|
2202 calcIteratorFromLineNr( y+1, mlIt1, melIt1 );
|
joachim99@8
|
2203 if ( melIt1->isEditableText() )
|
joachim99@8
|
2204 {
|
joachim99@68
|
2205 QString s2 = melIt1->getString( this );
|
joachim99@68
|
2206 melIt->setString( str + s2 );
|
joachim99@8
|
2207
|
joachim99@8
|
2208 // Remove the line
|
joachim99@8
|
2209 if ( mlIt1->mergeEditLineList.size()>1 )
|
joachim99@8
|
2210 mlIt1->mergeEditLineList.erase( melIt1 );
|
joachim99@8
|
2211 else
|
joachim99@8
|
2212 melIt1->setRemoved();
|
joachim99@8
|
2213 }
|
joachim99@8
|
2214 }
|
joachim99@8
|
2215 }
|
joachim99@8
|
2216 else
|
joachim99@8
|
2217 {
|
joachim99@68
|
2218 QString s = str.left(x);
|
joachim99@68
|
2219 s += str.mid( x+1 );
|
joachim99@8
|
2220 melIt->setString( s );
|
joachim99@8
|
2221 setModified();
|
joachim99@8
|
2222 }
|
joachim99@8
|
2223 break;
|
joachim99@8
|
2224 }
|
joachim99@69
|
2225 case Qt::Key_Backspace:
|
joachim99@8
|
2226 {
|
joachim99@68
|
2227 if ( deleteSelection2( str, x, y, mlIt, melIt )) break;
|
joachim99@8
|
2228 if( !melIt->isEditableText() ) break;
|
joachim99@8
|
2229 if (x==0)
|
joachim99@8
|
2230 {
|
joachim99@8
|
2231 if ( y>0 )
|
joachim99@8
|
2232 {
|
joachim99@8
|
2233 setModified();
|
joachim99@8
|
2234 MergeLineList::iterator mlIt1;
|
joachim99@8
|
2235 MergeEditLineList::iterator melIt1;
|
joachim99@8
|
2236 calcIteratorFromLineNr( y-1, mlIt1, melIt1 );
|
joachim99@8
|
2237 if ( melIt1->isEditableText() )
|
joachim99@8
|
2238 {
|
joachim99@68
|
2239 QString s1 = melIt1->getString( this );
|
joachim99@68
|
2240 melIt1->setString( s1 + str );
|
joachim99@8
|
2241
|
joachim99@8
|
2242 // Remove the previous line
|
joachim99@8
|
2243 if ( mlIt->mergeEditLineList.size()>1 )
|
joachim99@8
|
2244 mlIt->mergeEditLineList.erase( melIt );
|
joachim99@8
|
2245 else
|
joachim99@8
|
2246 melIt->setRemoved();
|
joachim99@8
|
2247
|
joachim99@8
|
2248 --y;
|
joachim99@68
|
2249 x=str.length();
|
joachim99@8
|
2250 }
|
joachim99@8
|
2251 }
|
joachim99@8
|
2252 }
|
joachim99@8
|
2253 else
|
joachim99@8
|
2254 {
|
joachim99@68
|
2255 QString s = str.left( x-1 );
|
joachim99@68
|
2256 s += str.mid( x );
|
joachim99@8
|
2257 --x;
|
joachim99@8
|
2258 melIt->setString( s );
|
joachim99@8
|
2259 setModified();
|
joachim99@8
|
2260 }
|
joachim99@8
|
2261 break;
|
joachim99@8
|
2262 }
|
joachim99@69
|
2263 case Qt::Key_Return:
|
joachim99@69
|
2264 case Qt::Key_Enter:
|
joachim99@8
|
2265 {
|
joachim99@8
|
2266 if( !melIt->isEditableText() ) break;
|
joachim99@68
|
2267 deleteSelection2( str, x, y, mlIt, melIt );
|
joachim99@8
|
2268 setModified();
|
joachim99@68
|
2269 QString indentation;
|
joachim99@8
|
2270 if ( m_pOptionDialog->m_bAutoIndentation )
|
joachim99@8
|
2271 { // calc last indentation
|
joachim99@8
|
2272 MergeLineList::iterator mlIt1 = mlIt;
|
joachim99@8
|
2273 MergeEditLineList::iterator melIt1 = melIt;
|
joachim99@8
|
2274 for(;;) {
|
joachim99@68
|
2275 const QString s = melIt1->getString(this);
|
joachim99@68
|
2276 if ( !s.isEmpty() ) {
|
joachim99@70
|
2277 int i;
|
joachim99@68
|
2278 for( i=0; i<s.length(); ++i ){ if(s[i]!=' ' && s[i]!='\t') break; }
|
joachim99@68
|
2279 if (i<s.length()) {
|
joachim99@68
|
2280 indentation = s.left(i);
|
joachim99@8
|
2281 break;
|
joachim99@8
|
2282 }
|
joachim99@8
|
2283 }
|
joachim99@77
|
2284 // Go back one line
|
joachim99@77
|
2285 if ( melIt1 != mlIt1->mergeEditLineList.begin() )
|
joachim99@77
|
2286 --melIt1;
|
joachim99@77
|
2287 else
|
joachim99@77
|
2288 {
|
joachim99@77
|
2289 if ( mlIt1 == m_mergeLineList.begin() ) break;
|
joachim99@8
|
2290 --mlIt1;
|
joachim99@8
|
2291 melIt1 = mlIt1->mergeEditLineList.end();
|
joachim99@8
|
2292 --melIt1;
|
joachim99@8
|
2293 }
|
joachim99@8
|
2294 }
|
joachim99@8
|
2295 }
|
joachim99@69
|
2296 MergeEditLine mel(mlIt->id3l); // Associate every mel with an id3l, even if not really valid.
|
joachim99@68
|
2297 mel.setString( indentation + str.mid(x) );
|
joachim99@8
|
2298
|
joachim99@68
|
2299 if ( x<(int)str.length() ) // Cut off the old line.
|
joachim99@8
|
2300 {
|
joachim99@8
|
2301 // Since ps possibly points into melIt->str, first copy it into a temporary.
|
joachim99@68
|
2302 QString temp = str.left(x);
|
joachim99@8
|
2303 melIt->setString( temp );
|
joachim99@8
|
2304 }
|
joachim99@8
|
2305
|
joachim99@8
|
2306 ++melIt;
|
joachim99@8
|
2307 mlIt->mergeEditLineList.insert( melIt, mel );
|
joachim99@68
|
2308 x = indentation.length();
|
joachim99@8
|
2309 ++y;
|
joachim99@8
|
2310 break;
|
joachim99@8
|
2311 }
|
joachim99@69
|
2312 case Qt::Key_Insert: m_bInsertMode = !m_bInsertMode; break;
|
joachim99@69
|
2313 case Qt::Key_Pause: break;
|
joachim99@69
|
2314 case Qt::Key_Print: break;
|
joachim99@69
|
2315 case Qt::Key_SysReq: break;
|
joachim99@69
|
2316 case Qt::Key_Home: x=0; if(bCtrl){y=0; } break; // cursor movement
|
joachim99@69
|
2317 case Qt::Key_End: x=INT_MAX; if(bCtrl){y=INT_MAX;} break;
|
joachim99@69
|
2318
|
joachim99@69
|
2319 case Qt::Key_Left:
|
joachim99@69
|
2320 case Qt::Key_Right:
|
joachim99@69
|
2321 if ( (e->key()==Qt::Key_Left) ^ m_pOptionDialog->m_bRightToLeftLanguage ) // operator^: XOR
|
joachim99@8
|
2322 {
|
joachim99@68
|
2323 if ( !bCtrl )
|
joachim99@68
|
2324 {
|
joachim99@68
|
2325 --x;
|
joachim99@68
|
2326 if(x<0 && y>0){--y; x=INT_MAX;}
|
joachim99@68
|
2327 }
|
joachim99@68
|
2328 else
|
joachim99@68
|
2329 {
|
joachim99@68
|
2330 while( x>0 && (str[x-1]==' ' || str[x-1]=='\t') ) --x;
|
joachim99@68
|
2331 while( x>0 && (str[x-1]!=' ' && str[x-1]!='\t') ) --x;
|
joachim99@68
|
2332 }
|
joachim99@8
|
2333 }
|
joachim99@8
|
2334 else
|
joachim99@8
|
2335 {
|
joachim99@68
|
2336 if ( !bCtrl )
|
joachim99@68
|
2337 {
|
joachim99@68
|
2338 ++x; if(x>(int)str.length() && y<m_totalSize-1){ ++y; x=0; }
|
joachim99@68
|
2339 }
|
joachim99@8
|
2340
|
joachim99@68
|
2341 else
|
joachim99@68
|
2342 {
|
joachim99@68
|
2343 while( x<(int)str.length() && (str[x]==' ' || str[x]=='\t') ) ++x;
|
joachim99@68
|
2344 while( x<(int)str.length() && (str[x]!=' ' && str[x]!='\t') ) ++x;
|
joachim99@68
|
2345 }
|
joachim99@8
|
2346 }
|
joachim99@8
|
2347 break;
|
joachim99@8
|
2348
|
joachim99@75
|
2349 case Qt::Key_Up: if (!bCtrl){ --y; bYMoveKey=true; } break;
|
joachim99@75
|
2350 case Qt::Key_Down: if (!bCtrl){ ++y; bYMoveKey=true; } break;
|
joachim99@75
|
2351 case Qt::Key_PageUp: if (!bCtrl){ y-=getNofVisibleLines(); bYMoveKey=true; } break;
|
joachim99@75
|
2352 case Qt::Key_PageDown: if (!bCtrl){ y+=getNofVisibleLines(); bYMoveKey=true; } break;
|
joachim99@8
|
2353 default:
|
joachim99@8
|
2354 {
|
joachim99@8
|
2355 QString t = e->text();
|
joachim99@8
|
2356 if( t.isEmpty() || bCtrl )
|
joachim99@8
|
2357 { e->ignore(); return; }
|
joachim99@8
|
2358 else
|
joachim99@8
|
2359 {
|
joachim99@8
|
2360 if( bCtrl )
|
joachim99@8
|
2361 {
|
joachim99@8
|
2362 e->ignore(); return;
|
joachim99@8
|
2363 }
|
joachim99@8
|
2364 else
|
joachim99@8
|
2365 {
|
joachim99@8
|
2366 if( !melIt->isEditableText() ) break;
|
joachim99@68
|
2367 deleteSelection2( str, x, y, mlIt, melIt );
|
joachim99@8
|
2368
|
joachim99@8
|
2369 setModified();
|
joachim99@8
|
2370 // Characters to insert
|
joachim99@68
|
2371 QString s=str;
|
joachim99@8
|
2372 if ( t[0]=='\t' && m_pOptionDialog->m_bReplaceTabs )
|
joachim99@8
|
2373 {
|
joachim99@69
|
2374 int spaces = (m_cursorXPos / m_pOptionDialog->m_tabSize + 1)*m_pOptionDialog->m_tabSize - m_cursorXPos;
|
joachim99@8
|
2375 t.fill( ' ', spaces );
|
joachim99@8
|
2376 }
|
joachim99@8
|
2377 if ( m_bInsertMode )
|
joachim99@68
|
2378 s.insert( x, t );
|
joachim99@8
|
2379 else
|
joachim99@68
|
2380 s.replace( x, t.length(), t );
|
joachim99@8
|
2381
|
joachim99@8
|
2382 melIt->setString( s );
|
joachim99@8
|
2383 x += t.length();
|
joachim99@8
|
2384 bShift = false;
|
joachim99@8
|
2385 }
|
joachim99@8
|
2386 }
|
joachim99@8
|
2387 }
|
joachim99@8
|
2388 }
|
joachim99@8
|
2389
|
joachim99@58
|
2390 y = minMaxLimiter( y, 0, m_totalSize-1 );
|
joachim99@8
|
2391
|
joachim99@8
|
2392 calcIteratorFromLineNr( y, mlIt, melIt );
|
joachim99@68
|
2393 str = melIt->getString( this );
|
joachim99@8
|
2394
|
joachim99@68
|
2395 x = minMaxLimiter( x, 0, (int)str.length() );
|
joachim99@8
|
2396
|
joachim99@8
|
2397 int newFirstLine = m_firstLine;
|
joachim99@8
|
2398 int newFirstColumn = m_firstColumn;
|
joachim99@8
|
2399
|
joachim99@8
|
2400 if ( y<m_firstLine )
|
joachim99@8
|
2401 newFirstLine = y;
|
joachim99@8
|
2402 else if ( y > m_firstLine + getNofVisibleLines() )
|
joachim99@8
|
2403 newFirstLine = y - getNofVisibleLines();
|
joachim99@8
|
2404
|
joachim99@8
|
2405 if (bYMoveKey)
|
joachim99@69
|
2406 x=convertToPosInText( str, m_cursorOldXPos, m_pOptionDialog->m_tabSize );
|
joachim99@69
|
2407
|
joachim99@69
|
2408 int xOnScreen = convertToPosOnScreen( str, x, m_pOptionDialog->m_tabSize );
|
joachim99@8
|
2409 if ( xOnScreen<m_firstColumn )
|
joachim99@8
|
2410 newFirstColumn = xOnScreen;
|
joachim99@8
|
2411 else if ( xOnScreen > m_firstColumn + getNofVisibleColumns() )
|
joachim99@8
|
2412 newFirstColumn = xOnScreen - getNofVisibleColumns();
|
joachim99@8
|
2413
|
joachim99@8
|
2414 if ( bShift )
|
joachim99@8
|
2415 {
|
joachim99@8
|
2416 if (m_selection.firstLine==-1)
|
joachim99@8
|
2417 m_selection.start( m_cursorYPos, m_cursorXPos );
|
joachim99@8
|
2418
|
joachim99@8
|
2419 m_selection.end( y, xOnScreen );
|
joachim99@8
|
2420 }
|
joachim99@8
|
2421 else
|
joachim99@8
|
2422 m_selection.reset();
|
joachim99@8
|
2423
|
joachim99@8
|
2424 m_cursorYPos = y;
|
joachim99@8
|
2425 m_cursorXPos = xOnScreen;
|
joachim99@92
|
2426 if ( m_cursorXPos>m_nofColumns )
|
joachim99@92
|
2427 {
|
joachim99@92
|
2428 m_nofColumns = m_cursorXPos;
|
joachim99@92
|
2429 emit resizeSignal();
|
joachim99@92
|
2430 }
|
joachim99@8
|
2431 if ( ! bYMoveKey )
|
joachim99@8
|
2432 m_cursorOldXPos = m_cursorXPos;
|
joachim99@8
|
2433
|
joachim99@8
|
2434 m_bCursorOn = false;
|
joachim99@8
|
2435
|
joachim99@8
|
2436 if ( newFirstLine!=m_firstLine || newFirstColumn!=m_firstColumn )
|
joachim99@8
|
2437 {
|
joachim99@8
|
2438 m_bCursorOn = true;
|
joachim99@8
|
2439 scroll( newFirstColumn-m_firstColumn, newFirstLine-m_firstLine );
|
joachim99@8
|
2440 return;
|
joachim99@8
|
2441 }
|
joachim99@8
|
2442
|
joachim99@8
|
2443 m_bCursorOn = true;
|
joachim99@8
|
2444 update();
|
joachim99@8
|
2445 }
|
joachim99@8
|
2446
|
joachim99@8
|
2447 void MergeResultWindow::calcIteratorFromLineNr(
|
joachim99@8
|
2448 int line,
|
joachim99@8
|
2449 MergeResultWindow::MergeLineList::iterator& mlIt,
|
joachim99@8
|
2450 MergeResultWindow::MergeEditLineList::iterator& melIt
|
joachim99@8
|
2451 )
|
joachim99@8
|
2452 {
|
joachim99@8
|
2453 for( mlIt = m_mergeLineList.begin(); mlIt!=m_mergeLineList.end(); ++mlIt)
|
joachim99@8
|
2454 {
|
joachim99@8
|
2455 MergeLine& ml = *mlIt;
|
joachim99@8
|
2456 if ( line > ml.mergeEditLineList.size() )
|
joachim99@8
|
2457 {
|
joachim99@8
|
2458 line -= ml.mergeEditLineList.size();
|
joachim99@8
|
2459 }
|
joachim99@8
|
2460 else
|
joachim99@8
|
2461 {
|
joachim99@8
|
2462 for( melIt = ml.mergeEditLineList.begin(); melIt != ml.mergeEditLineList.end(); ++melIt )
|
joachim99@8
|
2463 {
|
joachim99@8
|
2464 --line;
|
joachim99@8
|
2465 if (line<0) return;
|
joachim99@8
|
2466 }
|
joachim99@8
|
2467 }
|
joachim99@8
|
2468 }
|
joachim99@8
|
2469 assert(false);
|
joachim99@8
|
2470 }
|
joachim99@8
|
2471
|
joachim99@8
|
2472
|
joachim99@8
|
2473 QString MergeResultWindow::getSelection()
|
joachim99@8
|
2474 {
|
joachim99@8
|
2475 QString selectionString;
|
joachim99@8
|
2476
|
joachim99@8
|
2477 int line = 0;
|
joachim99@8
|
2478 MergeLineList::iterator mlIt = m_mergeLineList.begin();
|
joachim99@8
|
2479 for(mlIt = m_mergeLineList.begin();mlIt!=m_mergeLineList.end(); ++mlIt)
|
joachim99@8
|
2480 {
|
joachim99@8
|
2481 MergeLine& ml = *mlIt;
|
joachim99@8
|
2482 MergeEditLineList::iterator melIt;
|
joachim99@8
|
2483 for( melIt = ml.mergeEditLineList.begin(); melIt != ml.mergeEditLineList.end(); ++melIt )
|
joachim99@8
|
2484 {
|
joachim99@8
|
2485 MergeEditLine& mel = *melIt;
|
joachim99@8
|
2486
|
joachim99@8
|
2487 if ( m_selection.lineWithin(line) )
|
joachim99@8
|
2488 {
|
joachim99@8
|
2489 int outPos = 0;
|
joachim99@8
|
2490 if (mel.isEditableText())
|
joachim99@8
|
2491 {
|
joachim99@68
|
2492 const QString str = mel.getString( this );
|
joachim99@8
|
2493
|
joachim99@8
|
2494 // Consider tabs
|
joachim99@8
|
2495
|
joachim99@70
|
2496 for( int i=0; i<str.length(); ++i )
|
joachim99@8
|
2497 {
|
joachim99@8
|
2498 int spaces = 1;
|
joachim99@68
|
2499 if ( str[i]=='\t' )
|
joachim99@8
|
2500 {
|
joachim99@69
|
2501 spaces = tabber( outPos, m_pOptionDialog->m_tabSize );
|
joachim99@8
|
2502 }
|
joachim99@8
|
2503
|
joachim99@8
|
2504 if( m_selection.within( line, outPos ) )
|
joachim99@8
|
2505 {
|
joachim99@68
|
2506 selectionString += str[i];
|
joachim99@8
|
2507 }
|
joachim99@8
|
2508
|
joachim99@8
|
2509 outPos += spaces;
|
joachim99@8
|
2510 }
|
joachim99@8
|
2511 }
|
joachim99@8
|
2512 else if ( mel.isConflict() )
|
joachim99@8
|
2513 {
|
joachim99@58
|
2514 selectionString += i18n("<Merge Conflict>");
|
joachim99@8
|
2515 }
|
joachim99@68
|
2516
|
joachim99@8
|
2517 if( m_selection.within( line, outPos ) )
|
joachim99@8
|
2518 {
|
joachim99@8
|
2519 #ifdef _WIN32
|
joachim99@8
|
2520 selectionString += '\r';
|
joachim99@8
|
2521 #endif
|
joachim99@8
|
2522 selectionString += '\n';
|
joachim99@8
|
2523 }
|
joachim99@8
|
2524 }
|
joachim99@8
|
2525
|
joachim99@8
|
2526 ++line;
|
joachim99@8
|
2527 }
|
joachim99@8
|
2528 }
|
joachim99@8
|
2529
|
joachim99@8
|
2530 return selectionString;
|
joachim99@8
|
2531 }
|
joachim99@8
|
2532
|
joachim99@68
|
2533 bool MergeResultWindow::deleteSelection2( QString& s, int& x, int& y,
|
joachim99@8
|
2534 MergeLineList::iterator& mlIt, MergeEditLineList::iterator& melIt )
|
joachim99@8
|
2535 {
|
joachim99@8
|
2536 if (m_selection.firstLine!=-1 && m_selection.bSelectionContainsData )
|
joachim99@8
|
2537 {
|
joachim99@8
|
2538 deleteSelection();
|
joachim99@8
|
2539 y = m_cursorYPos;
|
joachim99@8
|
2540 calcIteratorFromLineNr( y, mlIt, melIt );
|
joachim99@68
|
2541 s = melIt->getString( this );
|
joachim99@69
|
2542 x = convertToPosInText( s, m_cursorXPos, m_pOptionDialog->m_tabSize );
|
joachim99@8
|
2543 return true;
|
joachim99@8
|
2544 }
|
joachim99@8
|
2545 return false;
|
joachim99@8
|
2546 }
|
joachim99@8
|
2547
|
joachim99@8
|
2548 void MergeResultWindow::deleteSelection()
|
joachim99@8
|
2549 {
|
joachim99@8
|
2550 if ( m_selection.firstLine==-1 || !m_selection.bSelectionContainsData )
|
joachim99@8
|
2551 {
|
joachim99@8
|
2552 return;
|
joachim99@8
|
2553 }
|
joachim99@8
|
2554 setModified();
|
joachim99@8
|
2555
|
joachim99@8
|
2556 int line = 0;
|
joachim99@8
|
2557 MergeLineList::iterator mlItFirst;
|
joachim99@8
|
2558 MergeEditLineList::iterator melItFirst;
|
joachim99@68
|
2559 QString firstLineString;
|
joachim99@8
|
2560
|
joachim99@8
|
2561 int firstLine = -1;
|
joachim99@8
|
2562 int lastLine = -1;
|
joachim99@8
|
2563
|
joachim99@8
|
2564 MergeLineList::iterator mlIt;
|
joachim99@8
|
2565 for(mlIt = m_mergeLineList.begin();mlIt!=m_mergeLineList.end(); ++mlIt)
|
joachim99@8
|
2566 {
|
joachim99@8
|
2567 MergeLine& ml = *mlIt;
|
joachim99@8
|
2568 MergeEditLineList::iterator melIt;
|
joachim99@8
|
2569 for( melIt = ml.mergeEditLineList.begin(); melIt != ml.mergeEditLineList.end(); ++melIt )
|
joachim99@8
|
2570 {
|
joachim99@8
|
2571 MergeEditLine& mel = *melIt;
|
joachim99@8
|
2572
|
joachim99@8
|
2573 if ( mel.isEditableText() && m_selection.lineWithin(line) )
|
joachim99@8
|
2574 {
|
joachim99@8
|
2575 if ( firstLine==-1 )
|
joachim99@8
|
2576 firstLine = line;
|
joachim99@8
|
2577 lastLine = line;
|
joachim99@8
|
2578 }
|
joachim99@8
|
2579
|
joachim99@8
|
2580 ++line;
|
joachim99@8
|
2581 }
|
joachim99@8
|
2582 }
|
joachim99@8
|
2583
|
joachim99@8
|
2584 if ( firstLine == -1 )
|
joachim99@8
|
2585 {
|
joachim99@8
|
2586 return; // Nothing to delete.
|
joachim99@8
|
2587 }
|
joachim99@8
|
2588
|
joachim99@8
|
2589 line = 0;
|
joachim99@8
|
2590 for(mlIt = m_mergeLineList.begin();mlIt!=m_mergeLineList.end(); ++mlIt)
|
joachim99@8
|
2591 {
|
joachim99@8
|
2592 MergeLine& ml = *mlIt;
|
joachim99@8
|
2593 MergeEditLineList::iterator melIt, melIt1;
|
joachim99@8
|
2594 for( melIt = ml.mergeEditLineList.begin(); melIt != ml.mergeEditLineList.end(); )
|
joachim99@8
|
2595 {
|
joachim99@8
|
2596 MergeEditLine& mel = *melIt;
|
joachim99@8
|
2597 melIt1 = melIt;
|
joachim99@8
|
2598 ++melIt1;
|
joachim99@8
|
2599
|
joachim99@8
|
2600 if ( mel.isEditableText() && m_selection.lineWithin(line) )
|
joachim99@8
|
2601 {
|
joachim99@68
|
2602 QString lineString = mel.getString( this );
|
joachim99@8
|
2603
|
joachim99@8
|
2604 int firstPosInLine = m_selection.firstPosInLine(line);
|
joachim99@8
|
2605 int lastPosInLine = m_selection.lastPosInLine(line);
|
joachim99@8
|
2606
|
joachim99@8
|
2607 if ( line==firstLine )
|
joachim99@8
|
2608 {
|
joachim99@8
|
2609 mlItFirst = mlIt;
|
joachim99@8
|
2610 melItFirst = melIt;
|
joachim99@69
|
2611 int pos = convertToPosInText( lineString, firstPosInLine, m_pOptionDialog->m_tabSize );
|
joachim99@68
|
2612 firstLineString = lineString.left( pos );
|
joachim99@8
|
2613 }
|
joachim99@8
|
2614
|
joachim99@8
|
2615 if ( line==lastLine )
|
joachim99@8
|
2616 {
|
joachim99@8
|
2617 // This is the last line in the selection
|
joachim99@69
|
2618 int pos = convertToPosInText( lineString, lastPosInLine, m_pOptionDialog->m_tabSize );
|
joachim99@68
|
2619 firstLineString += lineString.mid( pos ); // rest of line
|
joachim99@8
|
2620 melItFirst->setString( firstLineString );
|
joachim99@8
|
2621 }
|
joachim99@8
|
2622
|
joachim99@8
|
2623 if ( line!=firstLine )
|
joachim99@8
|
2624 {
|
joachim99@8
|
2625 // Remove the line
|
joachim99@8
|
2626 if ( mlIt->mergeEditLineList.size()>1 )
|
joachim99@58
|
2627 mlIt->mergeEditLineList.erase( melIt );
|
joachim99@8
|
2628 else
|
joachim99@58
|
2629 melIt->setRemoved();
|
joachim99@8
|
2630 }
|
joachim99@8
|
2631 }
|
joachim99@8
|
2632
|
joachim99@8
|
2633 ++line;
|
joachim99@8
|
2634 melIt = melIt1;
|
joachim99@8
|
2635 }
|
joachim99@8
|
2636 }
|
joachim99@8
|
2637
|
joachim99@8
|
2638 m_cursorYPos = m_selection.beginLine();
|
joachim99@8
|
2639 m_cursorXPos = m_selection.beginPos();
|
joachim99@8
|
2640 m_cursorOldXPos = m_cursorXPos;
|
joachim99@8
|
2641
|
joachim99@8
|
2642 m_selection.reset();
|
joachim99@8
|
2643 }
|
joachim99@8
|
2644
|
joachim99@66
|
2645 void MergeResultWindow::pasteClipboard( bool bFromSelection )
|
joachim99@8
|
2646 {
|
joachim99@8
|
2647 if (m_selection.firstLine != -1 )
|
joachim99@8
|
2648 deleteSelection();
|
joachim99@8
|
2649
|
joachim99@8
|
2650 setModified();
|
joachim99@8
|
2651
|
joachim99@8
|
2652 int y = m_cursorYPos;
|
joachim99@8
|
2653 MergeLineList::iterator mlIt;
|
joachim99@8
|
2654 MergeEditLineList::iterator melIt, melItAfter;
|
joachim99@8
|
2655 calcIteratorFromLineNr( y, mlIt, melIt );
|
joachim99@8
|
2656 melItAfter = melIt;
|
joachim99@8
|
2657 ++melItAfter;
|
joachim99@68
|
2658 QString str = melIt->getString( this );
|
joachim99@69
|
2659 int x = convertToPosInText( str, m_cursorXPos, m_pOptionDialog->m_tabSize );
|
joachim99@8
|
2660
|
joachim99@66
|
2661 if ( !QApplication::clipboard()->supportsSelection() )
|
joachim99@66
|
2662 bFromSelection = false;
|
joachim99@8
|
2663
|
joachim99@68
|
2664 QString clipBoard = QApplication::clipboard()->text( bFromSelection ? QClipboard::Selection : QClipboard::Clipboard );
|
joachim99@68
|
2665
|
joachim99@68
|
2666 QString currentLine = str.left(x);
|
joachim99@68
|
2667 QString endOfLine = str.mid(x);
|
joachim99@8
|
2668 int i;
|
joachim99@68
|
2669 int len = clipBoard.length();
|
joachim99@68
|
2670 for( i=0; i<len; ++i )
|
joachim99@8
|
2671 {
|
joachim99@68
|
2672 QChar c = clipBoard[i];
|
joachim99@8
|
2673 if ( c == '\r' ) continue;
|
joachim99@8
|
2674 if ( c == '\n' )
|
joachim99@8
|
2675 {
|
joachim99@8
|
2676 melIt->setString( currentLine );
|
joachim99@69
|
2677 MergeEditLine mel(mlIt->id3l); // Associate every mel with an id3l, even if not really valid.
|
joachim99@69
|
2678 melIt = mlIt->mergeEditLineList.insert( melItAfter, mel );
|
joachim99@8
|
2679 currentLine = "";
|
joachim99@8
|
2680 x=0;
|
joachim99@8
|
2681 ++y;
|
joachim99@8
|
2682 }
|
joachim99@8
|
2683 else
|
joachim99@8
|
2684 {
|
joachim99@8
|
2685 currentLine += c;
|
joachim99@8
|
2686 ++x;
|
joachim99@8
|
2687 }
|
joachim99@8
|
2688 }
|
joachim99@8
|
2689
|
joachim99@8
|
2690 currentLine += endOfLine;
|
joachim99@8
|
2691 melIt->setString( currentLine );
|
joachim99@8
|
2692
|
joachim99@8
|
2693 m_cursorYPos = y;
|
joachim99@69
|
2694 m_cursorXPos = convertToPosOnScreen( currentLine, x, m_pOptionDialog->m_tabSize );
|
joachim99@8
|
2695 m_cursorOldXPos = m_cursorXPos;
|
joachim99@8
|
2696
|
joachim99@8
|
2697 update();
|
joachim99@8
|
2698 }
|
joachim99@8
|
2699
|
joachim99@8
|
2700 void MergeResultWindow::resetSelection()
|
joachim99@8
|
2701 {
|
joachim99@8
|
2702 m_selection.reset();
|
joachim99@8
|
2703 update();
|
joachim99@8
|
2704 }
|
joachim99@8
|
2705
|
joachim99@75
|
2706 void MergeResultWindow::setModified(bool bModified)
|
joachim99@8
|
2707 {
|
joachim99@75
|
2708 if (bModified != m_bModified)
|
joachim99@8
|
2709 {
|
joachim99@75
|
2710 m_bModified = bModified;
|
joachim99@75
|
2711 emit modifiedChanged(m_bModified);
|
joachim99@8
|
2712 }
|
joachim99@8
|
2713 }
|
joachim99@8
|
2714
|
joachim99@8
|
2715 /// Saves and returns true when successful.
|
joachim99@80
|
2716 bool MergeResultWindow::saveDocument( const QString& fileName, QTextCodec* pEncoding, e_LineEndStyle eLineEndStyle )
|
joachim99@8
|
2717 {
|
joachim99@8
|
2718 // Are still conflicts somewhere?
|
joachim99@8
|
2719 if ( getNrOfUnsolvedConflicts()>0 )
|
joachim99@8
|
2720 {
|
joachim99@8
|
2721 KMessageBox::error( this,
|
joachim99@8
|
2722 i18n("Not all conflicts are solved yet.\n"
|
joachim99@8
|
2723 "File not saved.\n"),
|
joachim99@51
|
2724 i18n("Conflicts Left"));
|
joachim99@8
|
2725 return false;
|
joachim99@8
|
2726 }
|
joachim99@8
|
2727
|
joachim99@80
|
2728 if ( eLineEndStyle==eLineEndStyleConflict || eLineEndStyle==eLineEndStyleUndefined )
|
joachim99@80
|
2729 {
|
joachim99@80
|
2730 KMessageBox::error( this,
|
joachim99@80
|
2731 i18n("There is a line end style conflict. Please choose the line end style manually.\n"
|
joachim99@80
|
2732 "File not saved.\n"),
|
joachim99@80
|
2733 i18n("Conflicts Left"));
|
joachim99@80
|
2734 return false;
|
joachim99@80
|
2735 }
|
joachim99@80
|
2736
|
joachim99@8
|
2737 update();
|
joachim99@8
|
2738
|
joachim99@8
|
2739 FileAccess file( fileName, true /*bWantToWrite*/ );
|
joachim99@8
|
2740 if ( m_pOptionDialog->m_bDmCreateBakFiles && file.exists() )
|
joachim99@8
|
2741 {
|
joachim99@8
|
2742 bool bSuccess = file.createBackup(".orig");
|
joachim99@8
|
2743 if ( !bSuccess )
|
joachim99@8
|
2744 {
|
joachim99@68
|
2745 KMessageBox::error( this, file.getStatusText() + i18n("\n\nCreating backup failed. File not saved."), i18n("File Save Error") );
|
joachim99@8
|
2746 return false;
|
joachim99@8
|
2747 }
|
joachim99@8
|
2748 }
|
joachim99@8
|
2749
|
joachim99@8
|
2750 QByteArray dataArray;
|
joachim99@75
|
2751 QTextStream textOutStream(&dataArray, QIODevice::WriteOnly);
|
joachim99@91
|
2752 if ( pEncoding->name()=="UTF-8" )
|
joachim99@91
|
2753 textOutStream.setGenerateByteOrderMark( false ); // Shouldn't be necessary. Bug in Qt or docs
|
joachim99@91
|
2754 else
|
joachim99@91
|
2755 textOutStream.setGenerateByteOrderMark( true ); // Only for UTF-16
|
joachim99@75
|
2756 textOutStream.setCodec( pEncoding );
|
joachim99@68
|
2757
|
joachim99@68
|
2758 int line = 0;
|
joachim99@68
|
2759 MergeLineList::iterator mlIt = m_mergeLineList.begin();
|
joachim99@68
|
2760 for(mlIt = m_mergeLineList.begin();mlIt!=m_mergeLineList.end(); ++mlIt)
|
joachim99@8
|
2761 {
|
joachim99@68
|
2762 MergeLine& ml = *mlIt;
|
joachim99@68
|
2763 MergeEditLineList::iterator melIt;
|
joachim99@68
|
2764 for( melIt = ml.mergeEditLineList.begin(); melIt != ml.mergeEditLineList.end(); ++melIt )
|
joachim99@8
|
2765 {
|
joachim99@68
|
2766 MergeEditLine& mel = *melIt;
|
joachim99@68
|
2767
|
joachim99@68
|
2768 if ( mel.isEditableText() )
|
joachim99@8
|
2769 {
|
joachim99@68
|
2770 QString str = mel.getString( this );
|
joachim99@8
|
2771
|
joachim99@68
|
2772 if (line>0) // Prepend line feed, but not for first line
|
joachim99@8
|
2773 {
|
joachim99@80
|
2774 if ( eLineEndStyle == eLineEndStyleDos )
|
joachim99@68
|
2775 { str.prepend("\r\n"); }
|
joachim99@8
|
2776 else
|
joachim99@68
|
2777 { str.prepend("\n"); }
|
joachim99@8
|
2778 }
|
joachim99@8
|
2779
|
joachim99@68
|
2780 textOutStream << str;
|
joachim99@77
|
2781 ++line;
|
joachim99@8
|
2782 }
|
joachim99@8
|
2783 }
|
joachim99@8
|
2784 }
|
joachim99@75
|
2785 textOutStream.flush();
|
joachim99@68
|
2786 bool bSuccess = file.writeFile( dataArray.data(), dataArray.size() );
|
joachim99@8
|
2787 if ( ! bSuccess )
|
joachim99@8
|
2788 {
|
joachim99@51
|
2789 KMessageBox::error( this, i18n("Error while writing."), i18n("File Save Error") );
|
joachim99@8
|
2790 return false;
|
joachim99@8
|
2791 }
|
joachim99@8
|
2792
|
joachim99@75
|
2793 setModified( false );
|
joachim99@8
|
2794 update();
|
joachim99@8
|
2795
|
joachim99@8
|
2796 return true;
|
joachim99@8
|
2797 }
|
joachim99@8
|
2798
|
joachim99@68
|
2799 QString MergeResultWindow::getString( int lineIdx )
|
joachim99@8
|
2800 {
|
joachim99@8
|
2801 MergeResultWindow::MergeLineList::iterator mlIt;
|
joachim99@8
|
2802 MergeResultWindow::MergeEditLineList::iterator melIt;
|
joachim99@8
|
2803 calcIteratorFromLineNr( lineIdx, mlIt, melIt );
|
joachim99@68
|
2804 QString s = melIt->getString( this );
|
joachim99@68
|
2805 return s;
|
joachim99@8
|
2806 }
|
joachim99@8
|
2807
|
joachim99@68
|
2808 bool MergeResultWindow::findString( const QString& s, int& d3vLine, int& posInLine, bool bDirDown, bool bCaseSensitive )
|
joachim99@8
|
2809 {
|
joachim99@8
|
2810 int it = d3vLine;
|
joachim99@8
|
2811 int endIt = bDirDown ? getNofLines() : -1;
|
joachim99@8
|
2812 int step = bDirDown ? 1 : -1;
|
joachim99@8
|
2813 int startPos = posInLine;
|
joachim99@8
|
2814
|
joachim99@8
|
2815 for( ; it!=endIt; it+=step )
|
joachim99@8
|
2816 {
|
joachim99@68
|
2817 QString line = getString( it );
|
joachim99@8
|
2818 if ( !line.isEmpty() )
|
joachim99@8
|
2819 {
|
joachim99@75
|
2820 int pos = line.indexOf( s, startPos, bCaseSensitive ? Qt::CaseSensitive : Qt::CaseInsensitive );
|
joachim99@8
|
2821 if ( pos != -1 )
|
joachim99@8
|
2822 {
|
joachim99@8
|
2823 d3vLine = it;
|
joachim99@8
|
2824 posInLine = pos;
|
joachim99@8
|
2825 return true;
|
joachim99@8
|
2826 }
|
joachim99@8
|
2827
|
joachim99@8
|
2828 startPos = 0;
|
joachim99@8
|
2829 }
|
joachim99@8
|
2830 }
|
joachim99@8
|
2831 return false;
|
joachim99@8
|
2832 }
|
joachim99@8
|
2833
|
joachim99@8
|
2834 void MergeResultWindow::setSelection( int firstLine, int startPos, int lastLine, int endPos )
|
joachim99@8
|
2835 {
|
joachim99@69
|
2836 if ( lastLine >= getNofLines() )
|
joachim99@69
|
2837 {
|
joachim99@69
|
2838 lastLine = getNofLines()-1;
|
joachim99@69
|
2839 QString s = getString( lastLine );
|
joachim99@69
|
2840 endPos = s.length();
|
joachim99@69
|
2841 }
|
joachim99@8
|
2842 m_selection.reset();
|
joachim99@69
|
2843 m_selection.start( firstLine, convertToPosOnScreen( getString(firstLine), startPos, m_pOptionDialog->m_tabSize ) );
|
joachim99@69
|
2844 m_selection.end( lastLine, convertToPosOnScreen( getString(lastLine), endPos, m_pOptionDialog->m_tabSize ) );
|
joachim99@8
|
2845 update();
|
joachim99@8
|
2846 }
|
joachim99@8
|
2847
|
joachim99@75
|
2848 Overview::Overview( OptionDialog* pOptions )
|
joachim99@75
|
2849 //: QWidget( pParent, 0, Qt::WNoAutoErase )
|
joachim99@8
|
2850 {
|
joachim99@8
|
2851 m_pDiff3LineList = 0;
|
joachim99@8
|
2852 m_pOptions = pOptions;
|
joachim99@8
|
2853 m_bTripleDiff = false;
|
joachim99@66
|
2854 m_eOverviewMode = eOMNormal;
|
joachim99@66
|
2855 m_nofLines = 1;
|
joachim99@69
|
2856 m_bPaintingAllowed = false;
|
joachim99@8
|
2857 setFixedWidth(20);
|
joachim99@8
|
2858 }
|
joachim99@8
|
2859
|
joachim99@8
|
2860 void Overview::init( Diff3LineList* pDiff3LineList, bool bTripleDiff )
|
joachim99@8
|
2861 {
|
joachim99@8
|
2862 m_pDiff3LineList = pDiff3LineList;
|
joachim99@8
|
2863 m_bTripleDiff = bTripleDiff;
|
joachim99@75
|
2864 m_pixmap = QPixmap( QSize(0,0) ); // make sure that a redraw happens
|
joachim99@8
|
2865 update();
|
joachim99@8
|
2866 }
|
joachim99@8
|
2867
|
joachim99@69
|
2868 void Overview::reset()
|
joachim99@69
|
2869 {
|
joachim99@69
|
2870 m_pDiff3LineList = 0;
|
joachim99@69
|
2871 }
|
joachim99@69
|
2872
|
joachim99@51
|
2873 void Overview::slotRedraw()
|
joachim99@51
|
2874 {
|
joachim99@75
|
2875 m_pixmap = QPixmap( QSize(0,0) ); // make sure that a redraw happens
|
joachim99@51
|
2876 update();
|
joachim99@51
|
2877 }
|
joachim99@51
|
2878
|
joachim99@8
|
2879 void Overview::setRange( int firstLine, int pageHeight )
|
joachim99@8
|
2880 {
|
joachim99@8
|
2881 m_firstLine = firstLine;
|
joachim99@8
|
2882 m_pageHeight = pageHeight;
|
joachim99@8
|
2883 update();
|
joachim99@8
|
2884 }
|
joachim99@8
|
2885 void Overview::setFirstLine( int firstLine )
|
joachim99@8
|
2886 {
|
joachim99@8
|
2887 m_firstLine = firstLine;
|
joachim99@8
|
2888 update();
|
joachim99@8
|
2889 }
|
joachim99@8
|
2890
|
joachim99@66
|
2891 void Overview::setOverviewMode( e_OverviewMode eOverviewMode )
|
joachim99@66
|
2892 {
|
joachim99@66
|
2893 m_eOverviewMode = eOverviewMode;
|
joachim99@69
|
2894 slotRedraw();
|
joachim99@66
|
2895 }
|
joachim99@66
|
2896
|
joachim99@66
|
2897 Overview::e_OverviewMode Overview::getOverviewMode()
|
joachim99@66
|
2898 {
|
joachim99@66
|
2899 return m_eOverviewMode;
|
joachim99@66
|
2900 }
|
joachim99@66
|
2901
|
joachim99@8
|
2902 void Overview::mousePressEvent( QMouseEvent* e )
|
joachim99@8
|
2903 {
|
joachim99@8
|
2904 int h = height()-1;
|
joachim99@66
|
2905 int h1 = h * m_pageHeight / max2(1,m_nofLines)+3;
|
joachim99@8
|
2906 if ( h>0 )
|
joachim99@66
|
2907 emit setLine( ( e->y() - h1/2 )*m_nofLines/h );
|
joachim99@8
|
2908 }
|
joachim99@8
|
2909
|
joachim99@8
|
2910 void Overview::mouseMoveEvent( QMouseEvent* e )
|
joachim99@8
|
2911 {
|
joachim99@8
|
2912 mousePressEvent(e);
|
joachim99@8
|
2913 }
|
joachim99@8
|
2914
|
joachim99@8
|
2915 void Overview::setPaintingAllowed( bool bAllowPainting )
|
joachim99@8
|
2916 {
|
joachim99@8
|
2917 if (m_bPaintingAllowed != bAllowPainting)
|
joachim99@8
|
2918 {
|
joachim99@8
|
2919 m_bPaintingAllowed = bAllowPainting;
|
joachim99@8
|
2920 if ( m_bPaintingAllowed ) update();
|
joachim99@69
|
2921 else reset();
|
joachim99@8
|
2922 }
|
joachim99@8
|
2923 }
|
joachim99@8
|
2924
|
joachim99@66
|
2925 void Overview::drawColumn( QPainter& p, e_OverviewMode eOverviewMode, int x, int w, int h, int nofLines )
|
joachim99@66
|
2926 {
|
joachim99@69
|
2927 p.setPen(Qt::black);
|
joachim99@66
|
2928 p.drawLine( x, 0, x, h );
|
joachim99@66
|
2929
|
joachim99@66
|
2930 if (nofLines==0) return;
|
joachim99@66
|
2931
|
joachim99@66
|
2932 int line = 0;
|
joachim99@66
|
2933 int oldY = 0;
|
joachim99@66
|
2934 int oldConflictY = -1;
|
joachim99@66
|
2935 int wrapLineIdx=0;
|
joachim99@66
|
2936 Diff3LineList::const_iterator i;
|
joachim99@66
|
2937 for( i = m_pDiff3LineList->begin(); i!= m_pDiff3LineList->end(); )
|
joachim99@66
|
2938 {
|
joachim99@66
|
2939 const Diff3Line& d3l = *i;
|
joachim99@66
|
2940 int y = h * (line+1) / nofLines;
|
joachim99@66
|
2941 e_MergeDetails md;
|
joachim99@66
|
2942 bool bConflict;
|
joachim99@66
|
2943 bool bLineRemoved;
|
joachim99@66
|
2944 int src;
|
joachim99@66
|
2945 mergeOneLine( d3l, md, bConflict, bLineRemoved, src, !m_bTripleDiff );
|
joachim99@66
|
2946
|
joachim99@66
|
2947 QColor c = m_pOptions->m_bgColor;
|
joachim99@66
|
2948 bool bWhiteSpaceChange = false;
|
joachim99@66
|
2949 //if( bConflict ) c=m_pOptions->m_colorForConflict;
|
joachim99@66
|
2950 //else
|
joachim99@66
|
2951 if ( eOverviewMode==eOMNormal )
|
joachim99@66
|
2952 {
|
joachim99@66
|
2953 switch( md )
|
joachim99@66
|
2954 {
|
joachim99@66
|
2955 case eDefault:
|
joachim99@66
|
2956 case eNoChange:
|
joachim99@66
|
2957 c = m_pOptions->m_bgColor;
|
joachim99@66
|
2958 break;
|
joachim99@66
|
2959
|
joachim99@66
|
2960 case eBAdded:
|
joachim99@66
|
2961 case eBDeleted:
|
joachim99@66
|
2962 case eBChanged:
|
joachim99@66
|
2963 c = bConflict ? m_pOptions->m_colorForConflict : m_pOptions->m_colorB;
|
joachim99@66
|
2964 bWhiteSpaceChange = d3l.bAEqB || d3l.bWhiteLineA && d3l.bWhiteLineB;
|
joachim99@66
|
2965 break;
|
joachim99@66
|
2966
|
joachim99@66
|
2967 case eCAdded:
|
joachim99@66
|
2968 case eCDeleted:
|
joachim99@66
|
2969 case eCChanged:
|
joachim99@66
|
2970 bWhiteSpaceChange = d3l.bAEqC || d3l.bWhiteLineA && d3l.bWhiteLineC;
|
joachim99@66
|
2971 c = bConflict ? m_pOptions->m_colorForConflict : m_pOptions->m_colorC;
|
joachim99@66
|
2972 break;
|
joachim99@66
|
2973
|
joachim99@66
|
2974 case eBCChanged: // conflict
|
joachim99@66
|
2975 case eBCChangedAndEqual: // possible conflict
|
joachim99@66
|
2976 case eBCDeleted: // possible conflict
|
joachim99@66
|
2977 case eBChanged_CDeleted: // conflict
|
joachim99@66
|
2978 case eCChanged_BDeleted: // conflict
|
joachim99@66
|
2979 case eBCAdded: // conflict
|
joachim99@66
|
2980 case eBCAddedAndEqual: // possible conflict
|
joachim99@66
|
2981 c=m_pOptions->m_colorForConflict;
|
joachim99@66
|
2982 break;
|
joachim99@66
|
2983 default: assert(false); break;
|
joachim99@66
|
2984 }
|
joachim99@66
|
2985 }
|
joachim99@66
|
2986 else if ( eOverviewMode==eOMAvsB )
|
joachim99@66
|
2987 {
|
joachim99@66
|
2988 switch( md )
|
joachim99@66
|
2989 {
|
joachim99@66
|
2990 case eDefault:
|
joachim99@66
|
2991 case eNoChange:
|
joachim99@66
|
2992 case eCAdded:
|
joachim99@66
|
2993 case eCDeleted:
|
joachim99@66
|
2994 case eCChanged: break;
|
joachim99@66
|
2995 default: c = m_pOptions->m_colorForConflict;
|
joachim99@66
|
2996 bWhiteSpaceChange = d3l.bAEqB || d3l.bWhiteLineA && d3l.bWhiteLineB;
|
joachim99@66
|
2997 break;
|
joachim99@66
|
2998 }
|
joachim99@66
|
2999 }
|
joachim99@66
|
3000 else if ( eOverviewMode==eOMAvsC )
|
joachim99@66
|
3001 {
|
joachim99@66
|
3002 switch( md )
|
joachim99@66
|
3003 {
|
joachim99@66
|
3004 case eDefault:
|
joachim99@66
|
3005 case eNoChange:
|
joachim99@66
|
3006 case eBAdded:
|
joachim99@66
|
3007 case eBDeleted:
|
joachim99@66
|
3008 case eBChanged: break;
|
joachim99@66
|
3009 default: c = m_pOptions->m_colorForConflict;
|
joachim99@66
|
3010 bWhiteSpaceChange = d3l.bAEqC || d3l.bWhiteLineA && d3l.bWhiteLineC;
|
joachim99@69
|
3011 break;
|
joachim99@66
|
3012 }
|
joachim99@66
|
3013 }
|
joachim99@66
|
3014 else if ( eOverviewMode==eOMBvsC )
|
joachim99@66
|
3015 {
|
joachim99@66
|
3016 switch( md )
|
joachim99@66
|
3017 {
|
joachim99@66
|
3018 case eDefault:
|
joachim99@66
|
3019 case eNoChange:
|
joachim99@66
|
3020 case eBCChangedAndEqual:
|
joachim99@66
|
3021 case eBCDeleted:
|
joachim99@66
|
3022 case eBCAddedAndEqual: break;
|
joachim99@66
|
3023 default: c=m_pOptions->m_colorForConflict;
|
joachim99@66
|
3024 bWhiteSpaceChange = d3l.bBEqC || d3l.bWhiteLineB && d3l.bWhiteLineC;
|
joachim99@66
|
3025 break;
|
joachim99@66
|
3026 }
|
joachim99@66
|
3027 }
|
joachim99@66
|
3028
|
joachim99@66
|
3029 if (!bWhiteSpaceChange || m_pOptions->m_bShowWhiteSpace )
|
joachim99@66
|
3030 {
|
joachim99@66
|
3031 // Make sure that lines with conflict are not overwritten.
|
joachim99@66
|
3032 if ( c == m_pOptions->m_colorForConflict )
|
joachim99@66
|
3033 {
|
joachim99@69
|
3034 p.fillRect(x+1, oldY, w, max2(1,y-oldY), bWhiteSpaceChange ? QBrush(c,Qt::Dense4Pattern) : QBrush(c) );
|
joachim99@66
|
3035 oldConflictY = oldY;
|
joachim99@66
|
3036 }
|
joachim99@66
|
3037 else if ( c!=m_pOptions->m_bgColor && oldY>oldConflictY )
|
joachim99@66
|
3038 {
|
joachim99@69
|
3039 p.fillRect(x+1, oldY, w, max2(1,y-oldY), bWhiteSpaceChange ? QBrush(c,Qt::Dense4Pattern) : QBrush(c) );
|
joachim99@66
|
3040 }
|
joachim99@66
|
3041 }
|
joachim99@66
|
3042
|
joachim99@66
|
3043 oldY = y;
|
joachim99@66
|
3044
|
joachim99@66
|
3045 ++line;
|
joachim99@66
|
3046 if ( m_pOptions->m_bWordWrap )
|
joachim99@66
|
3047 {
|
joachim99@66
|
3048 ++wrapLineIdx;
|
joachim99@66
|
3049 if(wrapLineIdx>=d3l.linesNeededForDisplay)
|
joachim99@66
|
3050 {
|
joachim99@66
|
3051 wrapLineIdx=0;
|
joachim99@66
|
3052 ++i;
|
joachim99@66
|
3053 }
|
joachim99@66
|
3054 }
|
joachim99@66
|
3055 else
|
joachim99@66
|
3056 {
|
joachim99@66
|
3057 ++i;
|
joachim99@66
|
3058 }
|
joachim99@66
|
3059 }
|
joachim99@66
|
3060 }
|
joachim99@66
|
3061
|
joachim99@8
|
3062 void Overview::paintEvent( QPaintEvent* )
|
joachim99@8
|
3063 {
|
joachim99@8
|
3064 if (m_pDiff3LineList==0 || !m_bPaintingAllowed ) return;
|
joachim99@8
|
3065 int h = height()-1;
|
joachim99@8
|
3066 int w = width();
|
joachim99@66
|
3067
|
joachim99@8
|
3068
|
joachim99@8
|
3069 if ( m_pixmap.size() != size() )
|
joachim99@8
|
3070 {
|
joachim99@66
|
3071 if ( m_pOptions->m_bWordWrap )
|
joachim99@66
|
3072 {
|
joachim99@66
|
3073 m_nofLines = 0;
|
joachim99@66
|
3074 Diff3LineList::const_iterator i;
|
joachim99@66
|
3075 for( i = m_pDiff3LineList->begin(); i!= m_pDiff3LineList->end(); ++i )
|
joachim99@66
|
3076 {
|
joachim99@66
|
3077 m_nofLines += i->linesNeededForDisplay;
|
joachim99@69
|
3078 }
|
joachim99@66
|
3079 }
|
joachim99@66
|
3080 else
|
joachim99@66
|
3081 {
|
joachim99@66
|
3082 m_nofLines = m_pDiff3LineList->size();
|
joachim99@66
|
3083 }
|
joachim99@66
|
3084
|
joachim99@75
|
3085 m_pixmap = QPixmap( size() );
|
joachim99@8
|
3086
|
joachim99@8
|
3087 QPainter p(&m_pixmap);
|
joachim99@66
|
3088 p.fillRect( rect(), m_pOptions->m_bgColor );
|
joachim99@8
|
3089
|
joachim99@66
|
3090 if ( !m_bTripleDiff || m_eOverviewMode == eOMNormal )
|
joachim99@8
|
3091 {
|
joachim99@66
|
3092 drawColumn( p, eOMNormal, 0, w, h, m_nofLines );
|
joachim99@8
|
3093 }
|
joachim99@66
|
3094 else
|
joachim99@66
|
3095 {
|
joachim99@66
|
3096 drawColumn( p, eOMNormal, 0, w/2, h, m_nofLines );
|
joachim99@66
|
3097 drawColumn( p, m_eOverviewMode, w/2, w/2, h, m_nofLines );
|
joachim99@69
|
3098 }
|
joachim99@8
|
3099 }
|
joachim99@8
|
3100
|
joachim99@8
|
3101 QPainter painter( this );
|
joachim99@8
|
3102 painter.drawPixmap( 0,0, m_pixmap );
|
joachim99@8
|
3103
|
joachim99@66
|
3104 int y1 = h * m_firstLine / m_nofLines-1;
|
joachim99@66
|
3105 int h1 = h * m_pageHeight / m_nofLines+3;
|
joachim99@69
|
3106 painter.setPen(Qt::black);
|
joachim99@8
|
3107 painter.drawRect( 1, y1, w-1, h1 );
|
joachim99@8
|
3108 }
|
joachim99@8
|
3109
|
joachim99@75
|
3110 WindowTitleWidget::WindowTitleWidget(OptionDialog* pOptionDialog)
|
joachim99@75
|
3111 {
|
joachim99@75
|
3112 m_pOptionDialog = pOptionDialog;
|
joachim99@75
|
3113 setAutoFillBackground(true);
|
joachim99@75
|
3114
|
joachim99@75
|
3115 QHBoxLayout* pHLayout = new QHBoxLayout(this);
|
joachim99@75
|
3116 pHLayout->setMargin(2);
|
joachim99@75
|
3117 pHLayout->setSpacing(2);
|
joachim99@75
|
3118
|
joachim99@75
|
3119 m_pLabel = new QLabel(i18n("Output")+":");
|
joachim99@75
|
3120 pHLayout->addWidget( m_pLabel );
|
joachim99@75
|
3121
|
joachim99@75
|
3122 m_pFileNameLineEdit = new QLineEdit();
|
joachim99@75
|
3123 pHLayout->addWidget( m_pFileNameLineEdit, 6 );
|
joachim99@75
|
3124 m_pFileNameLineEdit->installEventFilter( this );
|
joachim99@75
|
3125 m_pFileNameLineEdit->setReadOnly( true );
|
joachim99@75
|
3126
|
joachim99@75
|
3127 //m_pBrowseButton = new QPushButton("...");
|
joachim99@75
|
3128 //pHLayout->addWidget( m_pBrowseButton, 0 );
|
joachim99@75
|
3129 //connect( m_pBrowseButton, SIGNAL(clicked()), this, SLOT(slotBrowseButtonClicked()));
|
joachim99@75
|
3130
|
joachim99@75
|
3131 m_pModifiedLabel = new QLabel(i18n("[Modified]"));
|
joachim99@75
|
3132 pHLayout->addWidget( m_pModifiedLabel );
|
joachim99@75
|
3133 m_pModifiedLabel->setMinimumSize( m_pModifiedLabel->sizeHint() );
|
joachim99@75
|
3134 m_pModifiedLabel->setText("");
|
joachim99@75
|
3135
|
joachim99@75
|
3136 pHLayout->addStretch(1);
|
joachim99@75
|
3137
|
joachim99@75
|
3138 m_pEncodingLabel = new QLabel(i18n("Encoding for saving")+":");
|
joachim99@75
|
3139 pHLayout->addWidget( m_pEncodingLabel );
|
joachim99@75
|
3140
|
joachim99@75
|
3141 m_pEncodingSelector = new QComboBox();
|
joachim99@80
|
3142 m_pEncodingSelector->setSizeAdjustPolicy( QComboBox::AdjustToContents );
|
joachim99@75
|
3143 pHLayout->addWidget( m_pEncodingSelector, 2 );
|
joachim99@75
|
3144 setEncodings(0,0,0);
|
joachim99@80
|
3145
|
joachim99@80
|
3146 m_pLineEndStyleLabel = new QLabel( i18n("Line end style:") );
|
joachim99@80
|
3147 pHLayout->addWidget( m_pLineEndStyleLabel );
|
joachim99@80
|
3148 m_pLineEndStyleSelector = new QComboBox();
|
joachim99@80
|
3149 m_pLineEndStyleSelector->setSizeAdjustPolicy( QComboBox::AdjustToContents );
|
joachim99@80
|
3150 pHLayout->addWidget( m_pLineEndStyleSelector );
|
joachim99@80
|
3151 setLineEndStyles(eLineEndStyleUndefined,eLineEndStyleUndefined,eLineEndStyleUndefined);
|
joachim99@75
|
3152 }
|
joachim99@75
|
3153
|
joachim99@75
|
3154 void WindowTitleWidget::setFileName( const QString& fileName )
|
joachim99@75
|
3155 {
|
joachim99@75
|
3156 m_pFileNameLineEdit->setText( QDir::toNativeSeparators(fileName) );
|
joachim99@75
|
3157 }
|
joachim99@75
|
3158
|
joachim99@75
|
3159 QString WindowTitleWidget::getFileName()
|
joachim99@75
|
3160 {
|
joachim99@75
|
3161 return m_pFileNameLineEdit->text();
|
joachim99@75
|
3162 }
|
joachim99@75
|
3163
|
joachim99@80
|
3164 static QString getLineEndStyleName( e_LineEndStyle eLineEndStyle )
|
joachim99@80
|
3165 {
|
joachim99@80
|
3166 if ( eLineEndStyle == eLineEndStyleDos )
|
joachim99@80
|
3167 return "DOS";
|
joachim99@80
|
3168 else if ( eLineEndStyle == eLineEndStyleUnix )
|
joachim99@80
|
3169 return "Unix";
|
joachim99@80
|
3170 return QString();
|
joachim99@80
|
3171 }
|
joachim99@80
|
3172
|
joachim99@80
|
3173 void WindowTitleWidget::setLineEndStyles( e_LineEndStyle eLineEndStyleA, e_LineEndStyle eLineEndStyleB, e_LineEndStyle eLineEndStyleC)
|
joachim99@80
|
3174 {
|
joachim99@80
|
3175 m_pLineEndStyleSelector->clear();
|
joachim99@80
|
3176 QString dosUsers;
|
joachim99@80
|
3177 if ( eLineEndStyleA == eLineEndStyleDos )
|
joachim99@80
|
3178 dosUsers += "A";
|
joachim99@80
|
3179 if ( eLineEndStyleB == eLineEndStyleDos )
|
joachim99@80
|
3180 dosUsers += (dosUsers.isEmpty() ? "" : ", ") + QString("B");
|
joachim99@80
|
3181 if ( eLineEndStyleC == eLineEndStyleDos )
|
joachim99@80
|
3182 dosUsers += (dosUsers.isEmpty() ? "" : ", ") + QString("C");
|
joachim99@80
|
3183 QString unxUsers;
|
joachim99@80
|
3184 if ( eLineEndStyleA == eLineEndStyleUnix )
|
joachim99@80
|
3185 unxUsers += "A";
|
joachim99@80
|
3186 if ( eLineEndStyleB == eLineEndStyleUnix )
|
joachim99@80
|
3187 unxUsers += (unxUsers.isEmpty() ? "" : ", ") + QString("B");
|
joachim99@80
|
3188 if ( eLineEndStyleC == eLineEndStyleUnix )
|
joachim99@80
|
3189 unxUsers += (unxUsers.isEmpty() ? "" : ", ") + QString("C");
|
joachim99@80
|
3190
|
joachim99@80
|
3191 m_pLineEndStyleSelector->addItem( i18n("Unix") + (unxUsers.isEmpty() ? "" : " (" + unxUsers + ")" ) );
|
joachim99@80
|
3192 m_pLineEndStyleSelector->addItem( i18n("DOS") + (dosUsers.isEmpty() ? "" : " (" + dosUsers + ")" ) );
|
joachim99@80
|
3193
|
joachim99@80
|
3194 e_LineEndStyle autoChoice = (e_LineEndStyle)m_pOptionDialog->m_lineEndStyle;
|
joachim99@80
|
3195
|
joachim99@80
|
3196 if ( m_pOptionDialog->m_lineEndStyle == eLineEndStyleAutoDetect )
|
joachim99@80
|
3197 {
|
joachim99@80
|
3198 if ( eLineEndStyleA != eLineEndStyleUndefined && eLineEndStyleB != eLineEndStyleUndefined && eLineEndStyleC != eLineEndStyleUndefined )
|
joachim99@80
|
3199 {
|
joachim99@80
|
3200 if ( eLineEndStyleA == eLineEndStyleB )
|
joachim99@80
|
3201 autoChoice = eLineEndStyleC;
|
joachim99@80
|
3202 else if ( eLineEndStyleA == eLineEndStyleC )
|
joachim99@80
|
3203 autoChoice = eLineEndStyleB;
|
joachim99@80
|
3204 else
|
joachim99@80
|
3205 autoChoice = eLineEndStyleConflict; //conflict (not likely while only two values exist)
|
joachim99@80
|
3206 }
|
joachim99@80
|
3207 else
|
joachim99@80
|
3208 {
|
joachim99@80
|
3209 e_LineEndStyle c1, c2;
|
joachim99@80
|
3210 if ( eLineEndStyleA == eLineEndStyleUndefined ) { c1 = eLineEndStyleB; c2 = eLineEndStyleC; }
|
joachim99@80
|
3211 else if( eLineEndStyleB == eLineEndStyleUndefined ) { c1 = eLineEndStyleA; c2 = eLineEndStyleC; }
|
joachim99@80
|
3212 else /*if( eLineEndStyleC == eLineEndStyleUndefined )*/ { c1 = eLineEndStyleA; c2 = eLineEndStyleB; }
|
joachim99@80
|
3213 if ( c1 == c2 && c1!=eLineEndStyleUndefined )
|
joachim99@80
|
3214 autoChoice = c1;
|
joachim99@80
|
3215 else
|
joachim99@80
|
3216 autoChoice = eLineEndStyleConflict;
|
joachim99@80
|
3217 }
|
joachim99@80
|
3218 }
|
joachim99@80
|
3219
|
joachim99@80
|
3220 if ( autoChoice == eLineEndStyleUnix )
|
joachim99@80
|
3221 m_pLineEndStyleSelector->setCurrentIndex(0);
|
joachim99@80
|
3222 else if ( autoChoice == eLineEndStyleDos )
|
joachim99@80
|
3223 m_pLineEndStyleSelector->setCurrentIndex(1);
|
joachim99@80
|
3224 else if ( autoChoice == eLineEndStyleConflict )
|
joachim99@80
|
3225 {
|
joachim99@80
|
3226 m_pLineEndStyleSelector->addItem( i18n("Conflict") );
|
joachim99@80
|
3227 m_pLineEndStyleSelector->setCurrentIndex(2);
|
joachim99@80
|
3228 }
|
joachim99@80
|
3229 }
|
joachim99@80
|
3230
|
joachim99@80
|
3231 e_LineEndStyle WindowTitleWidget::getLineEndStyle( )
|
joachim99@80
|
3232 {
|
joachim99@80
|
3233
|
joachim99@80
|
3234 int current = m_pLineEndStyleSelector->currentIndex();
|
joachim99@80
|
3235 if (current == 0)
|
joachim99@80
|
3236 return eLineEndStyleUnix;
|
joachim99@80
|
3237 else if (current == 1)
|
joachim99@80
|
3238 return eLineEndStyleDos;
|
joachim99@80
|
3239 else
|
joachim99@80
|
3240 return eLineEndStyleConflict;
|
joachim99@80
|
3241 }
|
joachim99@80
|
3242
|
joachim99@75
|
3243 void WindowTitleWidget::setEncodings( QTextCodec* pCodecForA, QTextCodec* pCodecForB, QTextCodec* pCodecForC )
|
joachim99@75
|
3244 {
|
joachim99@75
|
3245 m_pEncodingSelector->clear();
|
joachim99@75
|
3246
|
joachim99@75
|
3247 // First sort codec names:
|
joachim99@75
|
3248 std::map<QString, QTextCodec*> names;
|
joachim99@75
|
3249 QList<int> mibs = QTextCodec::availableMibs();
|
joachim99@75
|
3250 foreach(int i, mibs)
|
joachim99@75
|
3251 {
|
joachim99@75
|
3252 QTextCodec* c = QTextCodec::codecForMib(i);
|
joachim99@75
|
3253 if ( c!=0 )
|
joachim99@75
|
3254 names[QString(c->name())]=c;
|
joachim99@75
|
3255 }
|
joachim99@75
|
3256
|
joachim99@75
|
3257 if ( pCodecForA )
|
joachim99@75
|
3258 m_pEncodingSelector->addItem( i18n("Codec from") + " A: " + pCodecForA->name(), QVariant::fromValue((void*)pCodecForA) );
|
joachim99@75
|
3259 if ( pCodecForB )
|
joachim99@75
|
3260 m_pEncodingSelector->addItem( i18n("Codec from") + " B: " + pCodecForB->name(), QVariant::fromValue((void*)pCodecForB) );
|
joachim99@75
|
3261 if ( pCodecForC )
|
joachim99@75
|
3262 m_pEncodingSelector->addItem( i18n("Codec from") + " C: " + pCodecForC->name(), QVariant::fromValue((void*)pCodecForC) );
|
joachim99@75
|
3263
|
joachim99@75
|
3264 std::map<QString, QTextCodec*>::iterator it;
|
joachim99@75
|
3265 for(it=names.begin();it!=names.end();++it)
|
joachim99@75
|
3266 {
|
joachim99@75
|
3267 m_pEncodingSelector->addItem( it->first, QVariant::fromValue((void*)it->second) );
|
joachim99@75
|
3268 }
|
joachim99@75
|
3269 m_pEncodingSelector->setMinimumSize( m_pEncodingSelector->sizeHint() );
|
joachim99@75
|
3270
|
joachim99@75
|
3271 if ( pCodecForC && pCodecForB && pCodecForA )
|
joachim99@75
|
3272 {
|
joachim99@75
|
3273 if ( pCodecForA == pCodecForB )
|
joachim99@75
|
3274 m_pEncodingSelector->setCurrentIndex( 2 ); // C
|
joachim99@75
|
3275 else if ( pCodecForA == pCodecForC )
|
joachim99@75
|
3276 m_pEncodingSelector->setCurrentIndex( 1 ); // B
|
joachim99@75
|
3277 else
|
joachim99@75
|
3278 m_pEncodingSelector->setCurrentIndex( 2 ); // C
|
joachim99@75
|
3279 }
|
joachim99@75
|
3280 else if ( pCodecForA && pCodecForB )
|
joachim99@75
|
3281 m_pEncodingSelector->setCurrentIndex( 1 ); // B
|
joachim99@75
|
3282 else
|
joachim99@75
|
3283 m_pEncodingSelector->setCurrentIndex( 0 );
|
joachim99@75
|
3284 }
|
joachim99@75
|
3285
|
joachim99@75
|
3286 QTextCodec* WindowTitleWidget::getEncoding()
|
joachim99@75
|
3287 {
|
joachim99@75
|
3288 return (QTextCodec*)m_pEncodingSelector->itemData( m_pEncodingSelector->currentIndex() ).value<void*>();
|
joachim99@75
|
3289 }
|
joachim99@75
|
3290
|
joachim99@75
|
3291 void WindowTitleWidget::setEncoding(QTextCodec* pEncoding)
|
joachim99@75
|
3292 {
|
joachim99@75
|
3293 int idx = m_pEncodingSelector->findText( pEncoding->name() );
|
joachim99@75
|
3294 if (idx>=0)
|
joachim99@75
|
3295 m_pEncodingSelector->setCurrentIndex( idx );
|
joachim99@75
|
3296 }
|
joachim99@75
|
3297
|
joachim99@75
|
3298 //void WindowTitleWidget::slotBrowseButtonClicked()
|
joachim99@75
|
3299 //{
|
joachim99@75
|
3300 // QString current = m_pFileNameLineEdit->text();
|
joachim99@75
|
3301 //
|
joachim99@80
|
3302 // KUrl newURL = KFileDialog::getSaveUrl( current, 0, this, i18n("Select file (not saving yet)"));
|
joachim99@75
|
3303 // if ( !newURL.isEmpty() )
|
joachim99@75
|
3304 // {
|
joachim99@75
|
3305 // m_pFileNameLineEdit->setText( newURL.url() );
|
joachim99@75
|
3306 // }
|
joachim99@75
|
3307 //}
|
joachim99@75
|
3308
|
joachim99@75
|
3309 void WindowTitleWidget::slotSetModified( bool bModified )
|
joachim99@75
|
3310 {
|
joachim99@75
|
3311 m_pModifiedLabel->setText( bModified ? i18n("[Modified]") : "" );
|
joachim99@75
|
3312 }
|
joachim99@75
|
3313
|
joachim99@75
|
3314 bool WindowTitleWidget::eventFilter( QObject* o, QEvent* e )
|
joachim99@75
|
3315 {
|
joachim99@75
|
3316 if ( e->type()==QEvent::FocusIn || e->type()==QEvent::FocusOut )
|
joachim99@75
|
3317 {
|
joachim99@75
|
3318 QPalette p = m_pLabel->palette();
|
joachim99@75
|
3319
|
joachim99@75
|
3320 QColor c1 = m_pOptionDialog->m_fgColor;
|
joachim99@75
|
3321 QColor c2 = Qt::lightGray;
|
joachim99@75
|
3322 if ( e->type()==QEvent::FocusOut )
|
joachim99@75
|
3323 c2 = m_pOptionDialog->m_bgColor;
|
joachim99@75
|
3324
|
joachim99@75
|
3325 p.setColor(QPalette::Window, c2);
|
joachim99@75
|
3326 setPalette( p );
|
joachim99@75
|
3327
|
joachim99@75
|
3328 p.setColor(QPalette::WindowText, c1);
|
joachim99@75
|
3329 m_pLabel->setPalette( p );
|
joachim99@75
|
3330 m_pEncodingLabel->setPalette( p );
|
joachim99@75
|
3331 m_pEncodingSelector->setPalette( p );
|
joachim99@75
|
3332 }
|
joachim99@75
|
3333 if (o == m_pFileNameLineEdit && e->type()==QEvent::Drop)
|
joachim99@75
|
3334 {
|
joachim99@75
|
3335 QDropEvent* d = static_cast<QDropEvent*>(e);
|
joachim99@75
|
3336
|
joachim99@75
|
3337 if ( d->mimeData()->hasUrls() )
|
joachim99@75
|
3338 {
|
joachim99@75
|
3339 QList<QUrl> lst = d->mimeData()->urls();
|
joachim99@75
|
3340
|
joachim99@75
|
3341 if ( lst.count() > 0 )
|
joachim99@75
|
3342 {
|
joachim99@75
|
3343 static_cast<QLineEdit*>(o)->setText( lst[0].toString() );
|
joachim99@75
|
3344 static_cast<QLineEdit*>(o)->setFocus();
|
joachim99@75
|
3345 return true;
|
joachim99@75
|
3346 }
|
joachim99@75
|
3347 }
|
joachim99@75
|
3348 }
|
joachim99@75
|
3349 return false;
|
joachim99@75
|
3350 }
|
joachim99@8
|
3351
|
joachim99@70
|
3352 //#include "mergeresultwindow.moc"
|