annotate kdiff3/src-QT4/mergeresultwindow.cpp @ 113:7bca1f1340f6 tip

Build fixes for Xcode 10 / Qt 5.12
author Chris Cannam
date Mon, 17 Dec 2018 11:13:01 +0000
parents 1b9430d5cf2b
children
rev   line source
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"