Tools__TextMergeInfo.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Wed, 27 Feb 2013 12:34:59 +0000
branchjv
changeset 12431 9f0c59c742d5
parent 12307 d7a3df44366a
child 15566 184cea584be5
permissions -rw-r--r--
Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     1
"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     2
 COPYRIGHT (c) 2006 by eXept Software AG
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     3
              All Rights Reserved
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     4
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     5
 This software is furnished under a license and may be used
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    10
 hereby transferred.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    11
"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    12
"{ Package: 'stx:libtool' }"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    13
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    14
"{ NameSpace: Tools }"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    15
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    16
Object subclass:#TextMergeInfo
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    17
	instanceVariableNames:'list listInfos'
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    18
	classVariableNames:''
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    19
	poolDictionaries:''
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    20
	category:'Interface-Diff'
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    21
!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    22
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    23
Object subclass:#LineInfo
12202
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
    24
	instanceVariableNames:'line resolution conflict offset'
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    25
	classVariableNames:''
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    26
	poolDictionaries:''
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    27
	privateIn:TextMergeInfo
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    28
!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    29
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    30
!TextMergeInfo class methodsFor:'documentation'!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    31
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    32
copyright
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    33
"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    34
 COPYRIGHT (c) 2006 by eXept Software AG
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    35
              All Rights Reserved
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    36
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    37
 This software is furnished under a license and may be used
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    38
 only in accordance with the terms of that license and with the
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    39
 inclusion of the above copyright notice.   This software may not
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    40
 be provided or otherwise made available to, or used by, any
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    41
 other person.  No title to or ownership of the software is
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    42
 hereby transferred.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    43
"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    44
! !
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    45
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    46
!TextMergeInfo methodsFor:'* uncategorized *'!
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    47
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    48
conflictLineText
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    49
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    50
    ^ '<conflict>' asText allBold colorizeAllWith: Color red.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    51
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    52
    "Created: / 03-04-2012 / 23:26:04 / Jan Vrany <jan.vrany@fit.cvut.cz>"
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    53
!
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    54
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    55
noSourceLineText
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    56
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    57
    ^'<no source line>' asText colorizeAllWith: Color red.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    58
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    59
    "Created: / 03-04-2012 / 23:26:05 / Jan Vrany <jan.vrany@fit.cvut.cz>"
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    60
! !
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    61
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    62
!TextMergeInfo methodsFor:'accessing'!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    63
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    64
list
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    65
    ^ list
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    66
!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    67
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    68
listInfos
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    69
    ^ listInfos
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    70
!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    71
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    72
text
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    73
    ^String  streamContents:[:s|
12288
2fa2855b6ba5 - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12227
diff changeset
    74
        list withIndexDo:[:ln :i|
2fa2855b6ba5 - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12227
diff changeset
    75
            | info |
2fa2855b6ba5 - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12227
diff changeset
    76
2fa2855b6ba5 - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12227
diff changeset
    77
            info := listInfos at: i ifAbsent:[nil].
2fa2855b6ba5 - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12227
diff changeset
    78
            (info isNil or:[info offset ~~ -1]) ifTrue:[
2fa2855b6ba5 - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12227
diff changeset
    79
                ln notNil ifTrue:[
2fa2855b6ba5 - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12227
diff changeset
    80
                    s nextPutLine: (list at: i)
2fa2855b6ba5 - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12227
diff changeset
    81
                ].
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    82
            ]
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    83
        ].
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
    84
    ].
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    85
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    86
    "Created: / 19-03-2012 / 14:58:42 / Jan Vrany <jan.vrany@fit.cvut.cz>"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    87
! !
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    88
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    89
!TextMergeInfo methodsFor:'initialization'!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    90
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    91
text1: text1 text2: text2 text3: text3
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    92
12227
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
    93
    | t1c t2c  t3c diff3 diffs merges resolution lnr i |
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    94
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    95
    list := StringCollection new.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    96
    listInfos := OrderedCollection new.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    97
12202
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
    98
    t1c := (text1 ? #()) asStringCollection.
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
    99
    t2c := (text2 ? #()) asStringCollection.
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   100
    t3c := (text3 ? #()) asStringCollection.
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   101
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   102
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   103
    diff3 := Diff3 new
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   104
                    file0: t1c; "/Base version
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   105
                    file1: t2c; "/A
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   106
                    file2: t3c. "/B\
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   107
    diffs := diff3 diffIndices.
12227
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   108
    merges := diff3 mergeIndicesDiscardEmpty: false.
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   109
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   110
    lnr := 1.
12227
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   111
    i := 1.
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   112
    [ i <= merges size ] whileTrue:[
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   113
        | diff merge lines |
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   114
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   115
        diff := diffs at: i.
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   116
        merge := merges at: i.
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   117
        diff isChunk ifTrue:[
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   118
            lines := merge extractFromDiff: diff3.
12227
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   119
            1 to: diff length do:[:j|
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   120
                list add: (lines at: j).
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   121
                listInfos add: (LineInfo line: lnr resolution: #NoConflict conflict: diff offset: j ).
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   122
                lnr := lnr + 1.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   123
            ].
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   124
        ].
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   125
        diff isConflict ifTrue:[
12227
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   126
            1 to: diff length do:[:j|
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   127
                merge isConflict ifTrue:[
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   128
                    list add: self conflictLineText.
12227
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   129
                    listInfos add: (LineInfo line: lnr resolution: #Conflict conflict: diff offset: j).
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   130
                ] ifFalse:[
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   131
                    lines := merge extractFromDiff: diff3.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   132
                    resolution := merge extractResolution.
12227
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   133
                    j <= lines size ifTrue:[
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   134
                        list add: (lines at: j).
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   135
                        listInfos add: (LineInfo line: lnr resolution: resolution conflict: diff offset: j).
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   136
                    ] ifFalse:[
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   137
                        list add: self noSourceLineText.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   138
                        listInfos add: (LineInfo line: lnr resolution: resolution conflict: diff offset: -1).
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   139
                    ].
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   140
                ].
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   141
                lnr := lnr + 1.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   142
            ].
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   143
        ].
12227
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   144
        i := i + 1.
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   145
    ].
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   146
    "Sanity check:"
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   147
    i < diffs size ifTrue:[
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   148
        i + 1 to: diffs size do:[:j|
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   149
            self assert: (diffs at:j) length == 0.
f82b3ed0726a - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12225
diff changeset
   150
        ]
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   151
    ].
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   152
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   153
    self changed: #value
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   154
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   155
    "Created: / 19-03-2012 / 12:10:55 / Jan Vrany <jan.vrany@fit.cvut.cz>"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   156
! !
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   157
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   158
!TextMergeInfo methodsFor:'merging'!
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   159
12307
d7a3df44366a - Tools::TextDiff3Tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12288
diff changeset
   160
mergeUsing: text
d7a3df44366a - Tools::TextDiff3Tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12288
diff changeset
   161
d7a3df44366a - Tools::TextDiff3Tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12288
diff changeset
   162
    list := (text ? #()) asStringCollection.
d7a3df44366a - Tools::TextDiff3Tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12288
diff changeset
   163
    listInfos := 
d7a3df44366a - Tools::TextDiff3Tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12288
diff changeset
   164
        (1 to: list size) collect:[:lineNr|
d7a3df44366a - Tools::TextDiff3Tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12288
diff changeset
   165
            (LineInfo line: lineNr resolution: #Merged )
d7a3df44366a - Tools::TextDiff3Tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12288
diff changeset
   166
        ].
d7a3df44366a - Tools::TextDiff3Tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12288
diff changeset
   167
    self changed:#resolution
d7a3df44366a - Tools::TextDiff3Tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12288
diff changeset
   168
d7a3df44366a - Tools::TextDiff3Tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12288
diff changeset
   169
    "Created: / 30-11-2012 / 14:12:29 / Jan Vrany <jan.vrany@fit.cvut.cz>"
d7a3df44366a - Tools::TextDiff3Tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12288
diff changeset
   170
!
d7a3df44366a - Tools::TextDiff3Tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12288
diff changeset
   171
12203
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   172
mergeUsingA: textA
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   173
12204
ba9ffe0fd036 Fixes in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12203
diff changeset
   174
    list := (textA ? #()) asStringCollection.
12203
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   175
    listInfos := 
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   176
        (1 to: list size) collect:[:lineNr|
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   177
            (LineInfo line: lineNr resolution: #MergedUsingA )
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   178
        ].
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   179
    self changed:#resolution
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   180
12203
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   181
    "Created: / 21-03-2012 / 12:03:42 / Jan Vrany <jan.vrany@fit.cvut.cz>"
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   182
!
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   183
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   184
mergeUsingA: textA interval: interval
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   185
    "Given textA and section interval, merges the section
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   186
     using textA."
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   187
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   188
    | listA offset |
12288
2fa2855b6ba5 - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12227
diff changeset
   189
    listA := (textA ? '') asStringCollection.
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   190
    offset := 0.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   191
    interval do:[:lineNr|
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   192
        | info chunk line |
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   193
        info := listInfos at: lineNr.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   194
        chunk := info conflict left.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   195
        offset < chunk length ifTrue:[
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   196
            line := listA at: chunk offset + offset.            
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   197
            info offset: offset + 1.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   198
        ] ifFalse:[
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   199
            line := self noSourceLineText.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   200
            info offset: -1
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   201
        ].
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   202
        list at: lineNr put: line.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   203
        info resolution: #MergedUsingA.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   204
        offset := offset + 1.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   205
    ].
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   206
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   207
    self changed:#resolution
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   208
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   209
    "Created: / 04-04-2012 / 00:51:09 / Jan Vrany <jan.vrany@fit.cvut.cz>"
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   210
!
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   211
12203
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   212
mergeUsingB: textB
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   213
12204
ba9ffe0fd036 Fixes in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12203
diff changeset
   214
    list := (textB ? #())  asStringCollection.
12203
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   215
    listInfos := 
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   216
        (1 to: list size) collect:[:lineNr|
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   217
            (LineInfo line: lineNr resolution: #MergedUsingB )
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   218
        ].
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   219
    self changed:#resulution
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   220
12203
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   221
    "Created: / 21-03-2012 / 12:04:17 / Jan Vrany <jan.vrany@fit.cvut.cz>"
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   222
!
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   223
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   224
mergeUsingB: textA interval: interval
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   225
    "Given textA and section interval, merges the section
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   226
     using textA."
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   227
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   228
    | listA offset |
12288
2fa2855b6ba5 - Tools::TextMergeInfo
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12227
diff changeset
   229
    listA := (textA ? #()) asStringCollection.
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   230
    offset := 0.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   231
    interval do:[:lineNr|
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   232
        | info chunk line |
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   233
        info := listInfos at: lineNr.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   234
        chunk := info conflict right.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   235
        offset < chunk length ifTrue:[
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   236
            line := listA at: chunk offset + offset.            
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   237
            info offset: offset + 1.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   238
        ] ifFalse:[
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   239
            line := self noSourceLineText.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   240
            info offset: -1
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   241
        ].
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   242
        list at: lineNr put: line.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   243
        info resolution: #MergedUsingB.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   244
        offset := offset + 1.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   245
    ].
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   246
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   247
    self changed:#resolution
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   248
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   249
    "Created: / 04-04-2012 / 01:01:18 / Jan Vrany <jan.vrany@fit.cvut.cz>"
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   250
!
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   251
12203
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   252
mergeUsingBase: textBase
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   253
12204
ba9ffe0fd036 Fixes in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12203
diff changeset
   254
    list := (textBase ? #()) asStringCollection.
12203
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   255
    listInfos := 
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   256
        (1 to: list size) collect:[:lineNr|
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   257
            (LineInfo line: lineNr resolution: #MergedUsingBase )
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   258
        ].
12203
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   259
    self changed:#resulution
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   260
12203
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   261
    "Created: / 21-03-2012 / 12:07:58 / Jan Vrany <jan.vrany@fit.cvut.cz>"
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   262
!
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   263
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   264
mergeUsingBase: textA interval: interval
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   265
    "Given textA and section interval, merges the section
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   266
     using textA."
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   267
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   268
    | listA offset |
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   269
    listA := textA asStringCollection.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   270
    offset := 0.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   271
    interval do:[:lineNr|
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   272
        | info chunk line |
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   273
        info := listInfos at: lineNr.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   274
        chunk := info conflict original.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   275
        offset < chunk length ifTrue:[
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   276
            line := listA at: chunk offset + offset.            
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   277
            info offset: offset + 1.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   278
        ] ifFalse:[
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   279
            line := self noSourceLineText.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   280
            info offset: -1
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   281
        ].
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   282
        list at: lineNr put: line.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   283
        info resolution: #MergedUsingBase.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   284
        offset := offset + 1.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   285
    ].
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   286
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   287
    self changed:#resolution
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   288
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   289
    "Created: / 04-04-2012 / 01:01:31 / Jan Vrany <jan.vrany@fit.cvut.cz>"
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   290
! !
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   291
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   292
!TextMergeInfo methodsFor:'testing'!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   293
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   294
isMerged
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   295
12225
60dfd3fa018d - Diff3
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12218
diff changeset
   296
    ^listInfos allSatisfy:[:info|info isMergedOrNoConflict].
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   297
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   298
    "Created: / 19-03-2012 / 15:09:38 / Jan Vrany <jan.vrany@fit.cvut.cz>"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   299
! !
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   300
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   301
!TextMergeInfo::LineInfo class methodsFor:'accessing'!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   302
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   303
line:lineArg resolution:resolutionArg
12202
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   304
    ^self new line:lineArg resolution:resolutionArg conflict:nil offset: nil
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   305
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   306
    "Created: / 19-03-2012 / 15:04:15 / Jan Vrany <jan.vrany@fit.cvut.cz>"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   307
!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   308
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   309
line:lineArg resolution:resolutionArg conflict:conflictArg 
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   310
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   311
    ^self new line:lineArg resolution:resolutionArg conflict:conflictArg
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   312
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   313
    "Modified: / 19-03-2012 / 15:07:19 / Jan Vrany <jan.vrany@fit.cvut.cz>"
12202
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   314
!
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   315
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   316
line:lineArg resolution:resolutionArg conflict:conflictArg offset: offsetArg 
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   317
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   318
    ^self new line:lineArg resolution:resolutionArg conflict:conflictArg offset: offsetArg
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   319
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   320
    "Modified: / 19-03-2012 / 15:07:19 / Jan Vrany <jan.vrany@fit.cvut.cz>"
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   321
    "Created: / 20-03-2012 / 20:42:21 / Jan Vrany <jan.vrany@fit.cvut.cz>"
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   322
! !
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   323
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   324
!TextMergeInfo::LineInfo methodsFor:'accessing'!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   325
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   326
color
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   327
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   328
    | color |
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   329
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   330
    self isMerged ifTrue:[ 
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   331
        self isMergedUsingA ifTrue:[ 
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   332
            color := Tools::TextDiff3Tool colorA
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   333
        ] ifFalse:[self isMergedUsingB ifTrue:[ 
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   334
                color := Tools::TextDiff3Tool colorB
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   335
        ] ifFalse:[self isMergedUsingBase ifTrue:[ 
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   336
            color := Tools::TextDiff3Tool colorBase
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   337
        ] ifFalse:[
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   338
            color :=  Tools::TextDiff3Tool colorMerged
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   339
        ]]].
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   340
        offset == -1 ifTrue:[
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   341
            color := color lighter.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   342
        ].
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   343
    ] ifFalse:[
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   344
        self isConflict ifTrue:[ 
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   345
            color :=  Tools::TextDiff3Tool colorConflict 
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   346
        ].
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   347
    ].
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   348
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   349
    ^color
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   350
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   351
    "Created: / 19-03-2012 / 15:05:51 / Jan Vrany <jan.vrany@fit.cvut.cz>"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   352
!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   353
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   354
conflict
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   355
    ^ conflict
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   356
!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   357
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   358
line
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   359
    ^ line
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   360
!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   361
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   362
line:lineArg resolution:resolutionArg
12202
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   363
    self line:lineArg resolution:resolutionArg conflict:nil offset: nil
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   364
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   365
    "Created: / 19-03-2012 / 15:04:15 / Jan Vrany <jan.vrany@fit.cvut.cz>"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   366
!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   367
12202
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   368
line:lineArg resolution:resolutionArg conflict:conflictArg offset: offsetArg
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   369
    line := lineArg.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   370
    resolution := resolutionArg.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   371
    conflict := conflictArg.
12202
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   372
    offset := offsetArg
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   373
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   374
    "Created: / 20-03-2012 / 20:41:44 / Jan Vrany <jan.vrany@fit.cvut.cz>"
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   375
!
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   376
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   377
offset
eaa1f6cb6ce8 Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12201
diff changeset
   378
    ^ offset
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   379
!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   380
12218
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   381
offset:something
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   382
    offset := something.
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   383
!
8b88c30fb1e7 Improvements in text merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12204
diff changeset
   384
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   385
resolution
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   386
    ^ resolution
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   387
!
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   388
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   389
resolution:something
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   390
    resolution := something.
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   391
! !
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   392
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   393
!TextMergeInfo::LineInfo methodsFor:'printing & storing'!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   394
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   395
printOn:aStream
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   396
    "append a printed representation if the receiver to the argument, aStream"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   397
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   398
    self class nameWithoutPrefix printOn:aStream.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   399
    aStream space.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   400
    aStream nextPutAll:'line: '.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   401
    line printOn:aStream.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   402
    aStream space.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   403
    aStream nextPutAll:'resolution: '.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   404
    resolution printOn:aStream.
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   405
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   406
    "Modified: / 19-03-2012 / 12:30:56 / Jan Vrany <jan.vrany@fit.cvut.cz>"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   407
    "Created: / 19-03-2012 / 15:05:37 / Jan Vrany <jan.vrany@fit.cvut.cz>"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   408
! !
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   409
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   410
!TextMergeInfo::LineInfo methodsFor:'testing'!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   411
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   412
isConflict
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   413
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   414
    ^resolution == #Conflict
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   415
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   416
    "Created: / 19-03-2012 / 15:06:16 / Jan Vrany <jan.vrany@fit.cvut.cz>"
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   417
!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   418
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   419
isMerged
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   420
12225
60dfd3fa018d - Diff3
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12218
diff changeset
   421
    ^
60dfd3fa018d - Diff3
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12218
diff changeset
   422
     resolution == #Merged
60dfd3fa018d - Diff3
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12218
diff changeset
   423
            or:[self isMergedUsingA
60dfd3fa018d - Diff3
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12218
diff changeset
   424
                or:[self isMergedUsingB
60dfd3fa018d - Diff3
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12218
diff changeset
   425
                    or:[self isMergedUsingBase]]]
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   426
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   427
    "Created: / 19-03-2012 / 15:06:08 / Jan Vrany <jan.vrany@fit.cvut.cz>"
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   428
!
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   429
12225
60dfd3fa018d - Diff3
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12218
diff changeset
   430
isMergedOrNoConflict
60dfd3fa018d - Diff3
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12218
diff changeset
   431
60dfd3fa018d - Diff3
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12218
diff changeset
   432
    ^resolution == #NoConflict or:[self isMerged]
60dfd3fa018d - Diff3
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12218
diff changeset
   433
60dfd3fa018d - Diff3
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12218
diff changeset
   434
    "Created: / 06-04-2012 / 10:40:36 / Jan Vrany <jan.vrany@fit.cvut.cz>"
60dfd3fa018d - Diff3
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12218
diff changeset
   435
!
60dfd3fa018d - Diff3
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12218
diff changeset
   436
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   437
isMergedUsingA
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   438
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   439
    ^resolution == #MergedUsingA
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   440
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   441
    "Created: / 20-03-2012 / 14:21:30 / Jan Vrany <jan.vrany@fit.cvut.cz>"
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   442
!
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   443
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   444
isMergedUsingB
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   445
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   446
    ^resolution == #MergedUsingB
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   447
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   448
    "Created: / 20-03-2012 / 14:21:33 / Jan Vrany <jan.vrany@fit.cvut.cz>"
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   449
!
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   450
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   451
isMergedUsingBase
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   452
12203
bcfd4488d8a2 Improvements in Diff3/Merge
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12202
diff changeset
   453
    ^resolution == #MergedUsingBase
12201
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   454
283826cb8bcc Improvements in merge tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12198
diff changeset
   455
    "Created: / 20-03-2012 / 14:21:37 / Jan Vrany <jan.vrany@fit.cvut.cz>"
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   456
! !
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   457
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   458
!TextMergeInfo class methodsFor:'documentation'!
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   459
12431
9f0c59c742d5 Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12307
diff changeset
   460
version_HG
9f0c59c742d5 Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12307
diff changeset
   461
9f0c59c742d5 Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12307
diff changeset
   462
    ^ '$Changeset: <not expanded> $'
9f0c59c742d5 Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12307
diff changeset
   463
!
9f0c59c742d5 Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12307
diff changeset
   464
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   465
version_SVN
12307
d7a3df44366a - Tools::TextDiff3Tool
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12288
diff changeset
   466
    ^ '$Id: Tools__TextMergeInfo.st 8073 2012-11-30 14:25:59Z vranyj1 $'
12198
414e7b69ecda Text/ChangeSet diff improved
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   467
! !
12431
9f0c59c742d5 Added LintRuleSettingsApplication and LintRuleEditDialog to define user-defined rule sets.
Jan Vrany <jan.vrany@fit.cvut.cz>
parents: 12307
diff changeset
   468