annotate kdiff3/src-QT4/mergeresultwindow.cpp @ 77:1184fc843210

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