CBrowser.st
author claus
Thu, 10 Aug 1995 15:14:54 +0200
changeset 110 570a38362ae1
parent 108 a936f81cc162
child 111 b4ef3e799345
permissions -rw-r--r--
.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
     1
"
4
77d8e96499b2 *** empty log message ***
claus
parents: 1
diff changeset
     2
 COPYRIGHT (c) 1990 by Claus Gittinger
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
     3
	      All Rights Reserved
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
     4
571fd5eee315 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
571fd5eee315 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
571fd5eee315 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
571fd5eee315 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
571fd5eee315 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
571fd5eee315 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
571fd5eee315 Initial revision
claus
parents:
diff changeset
    11
"
571fd5eee315 Initial revision
claus
parents:
diff changeset
    12
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
    13
'From Smalltalk/X, Version:2.10.4 on 26-feb-1995 at 5:18:24 am'!
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    14
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    15
StandardSystemView subclass:#ChangesBrowser
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    16
	 instanceVariableNames:'changeListView codeView changeFileName changeChunks
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    17
		changePositions changeClassNames changeHeaderLines anyChanges
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
    18
		changeNrShown changeNrProcessed skipSignal compareChanges compareCheckBox'
58
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
    19
	 classVariableNames:'CompressSnapshotInfo'
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    20
	 poolDictionaries:''
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    21
	 category:'Interface-Browsers'
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    22
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
    23
571fd5eee315 Initial revision
claus
parents:
diff changeset
    24
ChangesBrowser comment:'
4
77d8e96499b2 *** empty log message ***
claus
parents: 1
diff changeset
    25
COPYRIGHT (c) 1990 by Claus Gittinger
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    26
	    All Rights Reserved
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    27
110
claus
parents: 108
diff changeset
    28
$Header: /cvs/stx/stx/libtool/Attic/CBrowser.st,v 1.39 1995-08-10 13:13:33 claus Exp $
29
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    29
'!
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    30
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    31
!ChangesBrowser class methodsFor:'documentation'!
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    32
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    33
copyright
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    34
"
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    35
 COPYRIGHT (c) 1990 by Claus Gittinger
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    36
	      All Rights Reserved
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    37
29
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    38
 This software is furnished under a license and may be used
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    39
 only in accordance with the terms of that license and with the
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    40
 inclusion of the above copyright notice.   This software may not
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    41
 be provided or otherwise made available to, or used by, any
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    42
 other person.  No title to or ownership of the software is
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    43
 hereby transferred.
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    44
"
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    45
!
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    46
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    47
version
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    48
"
110
claus
parents: 108
diff changeset
    49
$Header: /cvs/stx/stx/libtool/Attic/CBrowser.st,v 1.39 1995-08-10 13:13:33 claus Exp $
claus
parents: 108
diff changeset
    50
$Revision: 1.39 $
31
7ee4217817fa *** empty log message ***
claus
parents: 29
diff changeset
    51
"
29
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    52
!
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    53
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    54
documentation
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    55
"
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    56
    this implements a browser for the changes-file.
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    57
    See the extra document 'doc/misc/cbrowser.doc' for how to use this browser.
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    58
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    59
    written jan 90 by claus
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
    60
58
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
    61
    Class variables:
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
    62
	CompressSnapshotInfo            if true (the default), snapshot entries
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
    63
					are also compressed in the compress function.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
    64
					Some users prefer them to be not compressed.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
    65
					Set it to false for this.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
    66
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
    67
    Notice:
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
    68
	this needs a total rewrite, to build up a changeSet from the file
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
    69
	(which did not exist when the ChangesBrowser was written) and
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
    70
	manipulate that changeSet.
58
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
    71
	This way, we get a browser for any upcoming incore changeSets for
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
    72
	free. Also, this will put the chunk analyzation code into Change and
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
    73
	subclasses (where it belongs) and give a better encapsulation and
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
    74
	overall structure. Do not take this as an example for good style ;-)
29
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    75
"
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
    76
! !
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    77
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    78
!ChangesBrowser class methodsFor:'instance creation'!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    79
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    80
new
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    81
    "create a new changes browser"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    82
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    83
    ^ super label:'Changes Browser'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    84
	     icon:(Form fromFile:'CBrowser.xbm' resolution:100)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    85
!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    86
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    87
openOn:aFileName
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    88
    "create c changes browser on a change file"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    89
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
    90
    ^ ((self new label:'Changes Browser: ', aFileName) changeFileName:aFileName) open
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    91
! !
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
    92
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
    93
!ChangesBrowser class methodsFor:'behavior'!
571fd5eee315 Initial revision
claus
parents:
diff changeset
    94
571fd5eee315 Initial revision
claus
parents:
diff changeset
    95
autoSelectNext
571fd5eee315 Initial revision
claus
parents:
diff changeset
    96
    "returning true here, makes a Delete operation automatically
571fd5eee315 Initial revision
claus
parents:
diff changeset
    97
     select the next change"
571fd5eee315 Initial revision
claus
parents:
diff changeset
    98
571fd5eee315 Initial revision
claus
parents:
diff changeset
    99
    ^ true
571fd5eee315 Initial revision
claus
parents:
diff changeset
   100
! !
571fd5eee315 Initial revision
claus
parents:
diff changeset
   101
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   102
!ChangesBrowser class methodsFor:'defaults'!
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   103
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   104
defaultLabel
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   105
    ^ 'Changes Browser'
28
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   106
! !
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   107
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   108
!ChangesBrowser methodsFor:'private'!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   109
571fd5eee315 Initial revision
claus
parents:
diff changeset
   110
streamForChange:changeNr
571fd5eee315 Initial revision
claus
parents:
diff changeset
   111
    "answer a stream for change"
571fd5eee315 Initial revision
claus
parents:
diff changeset
   112
 
571fd5eee315 Initial revision
claus
parents:
diff changeset
   113
    |aStream|
571fd5eee315 Initial revision
claus
parents:
diff changeset
   114
56
d0cb937cbcaa *** empty log message ***
claus
parents: 51
diff changeset
   115
    (changeNr between:1 and:changePositions size) ifFalse:[^ nil].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   116
    aStream := FileStream readonlyFileNamed:changeFileName.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   117
    aStream isNil ifTrue:[^ nil].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   118
    aStream position:(changePositions at:changeNr).
571fd5eee315 Initial revision
claus
parents:
diff changeset
   119
    ^ aStream
571fd5eee315 Initial revision
claus
parents:
diff changeset
   120
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   121
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   122
autoSelect:changeNr
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   123
    "select a change"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   124
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   125
    self class autoSelectNext ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   126
	(changeNr <= changePositions size) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   127
	    changeListView selection:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   128
	    self changeSelection:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   129
	    ^ self
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   130
	]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   131
    ].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   132
    self clearCodeView.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   133
    changeListView selection:nil.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   134
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   135
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   136
clearCodeView
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   137
    self unselect "changeListView deselect".
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   138
    codeView contents:nil.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   139
    changeNrShown := nil
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   140
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   141
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   142
applyChange:changeNr
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   143
    "fileIn a change"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   144
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   145
    |aStream upd nm|
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   146
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   147
    aStream := self streamForChange:changeNr.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   148
    aStream isNil ifTrue:[^ self].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   149
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   150
    nm := self classNameOfChange:changeNr.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   151
    nm notNil ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   152
	|cls|
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   153
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   154
	cls := Smalltalk at:(nm asSymbol) ifAbsent:[].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   155
	cls notNil ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   156
	    cls isLoaded ifFalse:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   157
		cls autoload
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   158
	    ]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   159
	]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   160
    ].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   161
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   162
    changeNrProcessed := changeNr.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   163
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   164
    upd := Class updateChanges:false.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   165
    [
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   166
	|sig|
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   167
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   168
	(skipSignal notNil) ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   169
	    sig := skipSignal
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   170
	] ifFalse:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   171
	    sig := Object abortSignal
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   172
	].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   173
	sig catch:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   174
	    aStream fileInNextChunkNotifying:self
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   175
	].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   176
	changeNrProcessed := nil.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   177
    ] valueNowOrOnUnwindDo:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   178
	Class updateChanges:upd.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   179
	aStream close
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   180
    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   181
!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   182
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   183
unselect
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   184
    "common unselect"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   185
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   186
    changeListView deselect.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   187
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   188
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   189
setChangeList
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   190
    "extract type-information from changes and stuff into top selection
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   191
     view"
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   192
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   193
    changeListView setList:changeHeaderLines expandTabs:false.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   194
    "/ changeListView deselect.
107
claus
parents: 106
diff changeset
   195
! !
claus
parents: 106
diff changeset
   196
claus
parents: 106
diff changeset
   197
!ChangesBrowser methodsFor:'private'!
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   198
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   199
readChangesFileInBackground:inBackground
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   200
    "read the changes file, create a list of header-lines (changeChunks)
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   201
     and a list of chunk-positions (changePositions).
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   202
     Starting with 2.10.3, the entries are multi-col entries;
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   203
     the cols are:
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   204
	1   class/selector
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   205
	2   delta (only if comparing)
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   206
		'+' -> new method (w.r.t. current state)
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   207
		'-' -> removed method (w.r.t. current state)
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   208
		'?' -> class does not exist currently
81
b3b4d34c5ada *** empty log message ***
claus
parents: 77
diff changeset
   209
		'=' -> change is same as current methods source
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   210
	3   type of change
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   211
		doit
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   212
		method
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   213
		category change
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   214
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   215
     since comparing slows down startup time, it is now disabled by
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   216
     default and can be enabled via a toggle.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   217
     "
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   218
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   219
    |aStream maxLen|
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   220
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   221
    maxLen := 60.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   222
571fd5eee315 Initial revision
claus
parents:
diff changeset
   223
    aStream := FileStream readonlyFileNamed:changeFileName.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   224
    aStream isNil ifTrue:[^ nil].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   225
571fd5eee315 Initial revision
claus
parents:
diff changeset
   226
    self withCursor:(Cursor read) do:[
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   227
	|tabSpec myProcess myPriority|
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   228
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   229
	tabSpec := TabulatorSpecification new.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   230
	tabSpec unit:#inch.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   231
	tabSpec positions:#(0         4.5       4.65   5.5 ).
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   232
	"                   cls>>sel  +/-       type   info"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   233
	tabSpec align:    #(#left     #left     #left  #left).
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   234
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   235
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   236
	 this is a time consuming operation (especially, if reading an
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   237
	 NFS-mounted directory; therefore lower my priority ...
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   238
	"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   239
	inBackground ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   240
	    myProcess := Processor activeProcess.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   241
	    myPriority := myProcess priority.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   242
	    myProcess priority:(Processor userBackgroundPriority).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   243
	].
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   244
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   245
	[
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   246
	    |excla|
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   247
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   248
	    changeChunks := OrderedCollection new.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   249
	    changeHeaderLines := OrderedCollection new.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   250
	    changePositions := OrderedCollection new.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   251
	    excla := aStream class chunkSeparator.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   252
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   253
	    [aStream atEnd] whileFalse:[
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   254
		|entry changeDelta changeString changeType 
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   255
		 line s l changeClass sawExcla category 
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   256
		 chunkText chunkPos|
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   257
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   258
		"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   259
		 get a chunk (separated by excla)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   260
		"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   261
		aStream skipSeparators.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   262
		chunkPos := aStream position.
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   263
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   264
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   265
		sawExcla := aStream peekFor:excla.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   266
		chunkText := aStream nextChunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   267
		chunkText notNil ifTrue:[
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   268
		    |index headerLine|
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   269
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   270
		    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   271
		     only first line is saved in changeChunks ...
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   272
		    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   273
		    index := chunkText indexOf:(Character cr).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   274
		    (index ~~ 0) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   275
			chunkText := chunkText copyTo:(index - 1).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   276
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   277
			"take care for comment changes - must still be a
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   278
			 valid expression for classNameOfChange: to work"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   279
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   280
			(chunkText endsWith:'comment:''') ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   281
			    chunkText := chunkText , '...'''
107
claus
parents: 106
diff changeset
   282
			].
claus
parents: 106
diff changeset
   283
			(chunkText endsWith:'primitiveDefinitions:''%{') ifTrue:[
claus
parents: 106
diff changeset
   284
			    chunkText := chunkText , '... %}'''
claus
parents: 106
diff changeset
   285
			].
claus
parents: 106
diff changeset
   286
			(chunkText endsWith:'primitiveVariables:''%{') ifTrue:[
claus
parents: 106
diff changeset
   287
			    chunkText := chunkText , '... %}'''
claus
parents: 106
diff changeset
   288
			].
claus
parents: 106
diff changeset
   289
			(chunkText endsWith:'primitiveFunctions:''%{') ifTrue:[
claus
parents: 106
diff changeset
   290
			    chunkText := chunkText , '... %}'''
claus
parents: 106
diff changeset
   291
			].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   292
		    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   293
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   294
		    changeChunks add:chunkText.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   295
		    changePositions add:chunkPos.
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   296
		    headerLine := nil.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   297
		    changeDelta := ' '.
29
8a72e10043f6 *** empty log message ***
claus
parents: 28
diff changeset
   298
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   299
		    sawExcla ifFalse:[
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   300
			(chunkText startsWith:'''---- snap') ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   301
			    changeType := ''.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   302
			    headerLine := chunkText.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   303
			    changeString := (chunkText contractTo:maxLen).
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   304
			] ifFalse:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   305
			    |p sel cls|
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   306
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   307
			    headerLine := chunkText , ' (doIt)'.
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   308
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   309
			    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   310
			     first, assume doIt - then lets have a more detailed look ...
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   311
			    "
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   312
			    (chunkText startsWith:'''---- file') ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   313
				changeType := ''.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   314
			    ] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   315
				changeType := '(doIt)'.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   316
			    ].    
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   317
			    changeString := (chunkText contractTo:maxLen).
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   318
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   319
			    p := Parser parseExpression:chunkText.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   320
			    (p notNil 
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   321
			     and:[p ~~ #Error
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   322
			     and:[p isMessage]]) ifTrue:[
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   323
				sel := p selector.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   324
			    ].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   325
			    (sel == #removeSelector:) ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   326
				p receiver isUnaryMessage ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   327
				    cls := p receiver receiver name.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   328
				    changeClass := (Smalltalk classNamed:cls) class.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   329
				    cls := cls , ' class'.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   330
				] ifFalse:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   331
				    cls := p receiver name.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   332
				    changeClass := (Smalltalk classNamed:cls)
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   333
				].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   334
				sel := (p args at:1) evaluate.
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   335
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   336
				compareChanges ifTrue:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   337
				    (changeClass isNil or:[changeClass isLoaded not]) ifTrue:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   338
					changeDelta := '?'
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   339
				    ] ifFalse:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   340
					(changeClass implements:sel asSymbol) ifTrue:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   341
					    changeDelta := '-'.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   342
					]
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   343
				    ]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   344
				].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   345
				changeType := '(remove)'.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   346
				changeString := self contractClass:cls selector:sel to:maxLen.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   347
			    ].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   348
			    (sel == #category:) ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   349
				(p receiver isMessage
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   350
				and:[p receiver selector == #compiledMethodAt:]) ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   351
				    p receiver receiver isUnaryMessage ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   352
					cls := p receiver receiver receiver name.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   353
					changeClass := (Smalltalk classNamed:cls) class.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   354
					cls := cls , ' class'.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   355
				    ] ifFalse:[
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   356
					cls := p receiver receiver name.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   357
					changeClass := (Smalltalk classNamed:cls)
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   358
				    ].
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   359
				    sel := (p receiver args at:1) evaluate.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   360
				    changeType := '(category change)'.
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   361
				    changeString := self contractClass:cls selector:sel to:maxLen.
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   362
				]
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   363
			    ].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   364
			    (#(#'subclass:'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   365
			      #'variableSubclass:'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   366
			      #'variableByteSubclass:'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   367
			      #'variableWordSubclass:'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   368
			      #'variableLongSubclass:'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   369
			      #'variableFloatSubclass:'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   370
			      #'variableDoubleSubclass:'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   371
			     ) includes:sel) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   372
				changeType := '(class definition)'.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   373
			    ].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   374
			].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   375
		    ] ifTrue:[
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   376
			|done first p sel cls text|
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   377
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   378
			"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   379
			 method definitions actually consist of
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   380
			 two (or more) chunks; skip next chunk(s)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   381
			 up to an empty one.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   382
			 The system only writes one chunk,
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   383
			 and we cannot handle more in this ChangesBrowser ....
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   384
			"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   385
			cls := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   386
			p := Parser parseExpression:chunkText.
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   387
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   388
			(p notNil and:[p ~~ #Error]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   389
			    sel := p selector.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   390
			    (sel == #methodsFor:) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   391
				p receiver isUnaryMessage ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   392
				    cls := p receiver receiver name.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   393
				    changeClass := (Smalltalk classNamed:cls) class.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   394
				    cls := cls , ' class'.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   395
				] ifFalse:[
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   396
				    cls := p receiver name.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   397
				    changeClass := Smalltalk classNamed:cls
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   398
				].
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   399
				category := (p args at:1) evaluate.
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   400
			    ].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   401
			].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   402
			done := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   403
			first := true.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   404
			[done] whileFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   405
			    text := aStream nextChunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   406
			    text isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   407
				done := true
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   408
			    ] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   409
				done := text isEmpty
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   410
			    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   411
			    done ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   412
				first ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   413
				    Transcript showCr:'only one method per ''methodsFor:'' handled'.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   414
				] ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   415
				    first := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   416
				    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   417
				     try to find the selector
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   418
				    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   419
				    sel := nil.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   420
				    cls notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   421
					p := Parser 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   422
						 parseMethodSpecification:text
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   423
						 in:nil
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   424
						 ignoreErrors:true
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   425
						 ignoreWarnings:true.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   426
					(p notNil and:[p ~~ #Error]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   427
					    sel := p selector.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   428
					]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   429
				    ].
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   430
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   431
				    sel isNil ifTrue:[
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   432
					changeString := (chunkText contractTo:maxLen).
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   433
					changeType := '(change)'.
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   434
				    ] ifFalse:[
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   435
					changeString :=  self contractClass:cls selector:sel to:maxLen.
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   436
					changeType := '(method in: ''' , category , ''')'.
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   437
				    ].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   438
				    sel isNil ifTrue:[
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   439
					headerLine := chunkText , ' (change)'.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   440
				    ] ifFalse:[
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   441
					headerLine := cls , ' ' , sel , ' ' , '(change category: ''' , category , ''')'.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   442
				    ].
81
b3b4d34c5ada *** empty log message ***
claus
parents: 77
diff changeset
   443
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   444
				    compareChanges ifTrue:[    
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   445
					(changeClass isNil or:[changeClass isLoaded not]) ifTrue:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   446
					    changeDelta := '?'
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   447
					] ifFalse:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   448
					    (changeClass implements:sel asSymbol) ifFalse:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   449
						changeDelta := '+'.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   450
					    ] ifTrue:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   451
						|m currentText|
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   452
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   453
						m := changeClass compiledMethodAt:sel asSymbol.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   454
						currentText := m source.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   455
						currentText notNil ifTrue:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   456
						    text asString = currentText asString ifTrue:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   457
							changeDelta := '='
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   458
						    ]
81
b3b4d34c5ada *** empty log message ***
claus
parents: 77
diff changeset
   459
						]
b3b4d34c5ada *** empty log message ***
claus
parents: 77
diff changeset
   460
					    ]
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   461
					]
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   462
				    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   463
				]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   464
			    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   465
			]
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   466
		    ].
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   467
		    changeString notNil ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   468
			entry := MultiColListEntry new.
50
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   469
			entry tabulatorSpecification:tabSpec.
3106c0de1707 *** empty log message ***
claus
parents: 49
diff changeset
   470
			entry colAt:1 put:changeString.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   471
			entry colAt:2 put:changeDelta.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   472
			entry colAt:3 put:changeType.
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   473
			changeHeaderLines add:entry
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   474
		    ] ifFalse:[
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   475
			headerLine notNil ifTrue:[
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   476
			    changeHeaderLines add:headerLine
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
   477
			]
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   478
		    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   479
		]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   480
	    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   481
	    changeClassNames := OrderedCollection new grow:(changeChunks size).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   482
	    aStream close.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   483
	    anyChanges := false
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   484
	] valueNowOrOnUnwindDo:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   485
	    inBackground ifTrue:[myProcess priority:myPriority].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   486
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   487
    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   488
!
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   489
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   490
contractClass:className selector:selector to:maxLen
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   491
    |s l|
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   492
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   493
    s := className , ' ', selector.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   494
    s size > maxLen ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   495
	l := maxLen - 1 - selector size max:20.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   496
	s := (className contractTo:l) , ' ' , selector.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   497
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   498
	s size > maxLen ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   499
	    l := maxLen - 1 - className size max:20.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   500
	    s := className , ' ', (selector contractTo:l).
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   501
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   502
	    s size > maxLen ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   503
		s := (className contractTo:(maxLen // 2 - 1)) , ' ' , (selector contractTo:maxLen // 2)
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   504
	    ]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   505
	]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   506
    ].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   507
    ^ s
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   508
!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   509
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   510
silentDeleteChange:changeNr
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   511
    "delete a change do not update changeListView"
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   512
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   513
    anyChanges := true.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   514
    changeChunks removeIndex:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   515
    changePositions removeIndex:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   516
    changeClassNames removeIndex:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   517
    changeHeaderLines removeIndex:changeNr
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   518
!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   519
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   520
classNameOfChange:changeNr
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   521
    "return the classname of a change (for xxx class - changes xxx is returned)
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   522
     - since parsing ascii methods is slow, keep result cached in 
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   523
       changeClassNames for the next query"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   524
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   525
    |chunk aParseTree recTree sel name arg1Tree|
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   526
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   527
    changeNr isNil ifTrue:[^ nil].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   528
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   529
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   530
     first look, if not already known
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   531
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   532
    name := changeClassNames at:changeNr.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   533
    name notNil ifTrue:[^ name].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   534
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   535
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   536
     get the chunk
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   537
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   538
    chunk := changeChunks at:changeNr.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   539
    chunk isNil ifTrue:[^ nil].       "mhmh - empty"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   540
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   541
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   542
     use parser to construct a parseTree
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   543
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   544
    aParseTree := Parser parseExpression:chunk.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   545
    (aParseTree isNil or:[aParseTree == #Error]) ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   546
	^ nil        "seems strange ... (could be a comment)"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   547
    ].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   548
    aParseTree isMessage ifFalse:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   549
	^ nil        "very strange ... (whats that ?)"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   550
    ].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   551
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   552
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   553
     ask parser for selector
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   554
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   555
    sel := aParseTree selector.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   556
    recTree := aParseTree receiver.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   557
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   558
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   559
     is it a method-change, methodRemove or comment-change ?
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   560
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   561
    (#(#'methodsFor:' 
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   562
       #'privateMethodsFor:' 
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   563
       #'protectedMethodsFor:' 
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   564
       #'publicMethodsFor:' 
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   565
       #'removeSelector:' 
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   566
       #'comment:'
107
claus
parents: 106
diff changeset
   567
       #'primitiveDefinitions:'
claus
parents: 106
diff changeset
   568
       #'primitiveFunctions:'
claus
parents: 106
diff changeset
   569
       #'primitiveVariables:'
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   570
       #'renameCategory:to:'
61
cb5e3560bd82 *** empty log message ***
claus
parents: 58
diff changeset
   571
       #'instanceVariableNames:'
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   572
    ) includes:sel) ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   573
	"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   574
	 yes, the className is the receiver
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   575
	"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   576
	(recTree notNil and:[recTree ~~ #Error]) ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   577
	    recTree isUnaryMessage ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   578
		(recTree selector ~~ #class) ifTrue:[^ nil].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   579
		"id class methodsFor:..."
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   580
		recTree := recTree receiver
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   581
	    ].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   582
	    recTree isPrimary ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   583
		name := recTree name.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   584
		changeClassNames at:changeNr put:name.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   585
		^ name
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   586
	    ]
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   587
	].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   588
	"more strange things"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   589
	^ nil
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   590
    ].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   591
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   592
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   593
     is it a change in a class-description ?
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   594
    "
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   595
    (('subclass:*' match:sel) 
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   596
    or:[('variable*subclass:*' match:sel)]) ifTrue:[
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   597
	arg1Tree := aParseTree arg1.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   598
	(arg1Tree notNil and:[arg1Tree isConstant]) ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   599
	    name := arg1Tree value asString.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   600
	    changeClassNames at:changeNr put:name.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   601
	    ^ name
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   602
	].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   603
	"very strange"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   604
	^ nil
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   605
    ].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   606
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   607
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   608
     is it a class remove ?
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   609
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   610
    (sel == #removeClass:) ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   611
	(recTree notNil 
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   612
	and:[recTree ~~ #Error
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   613
	and:[recTree isPrimary
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   614
	and:[recTree name = 'Smalltalk']]]) ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   615
	    arg1Tree := aParseTree arg1.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   616
	    (arg1Tree notNil and:[arg1Tree isPrimary]) ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   617
		name := arg1Tree name.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   618
		changeClassNames at:changeNr put:name.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   619
		^ name
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   620
	    ].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   621
	]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   622
    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   623
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   624
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   625
     is it a method category change ?
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   626
    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   627
    (sel == #category:) ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   628
	(recTree notNil 
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   629
	and:[recTree ~~ #Error
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   630
	and:[recTree isMessage
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   631
	and:[recTree selector == #compiledMethodAt:]]]) ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   632
	    recTree := recTree receiver.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   633
	    recTree isUnaryMessage ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   634
		(recTree selector ~~ #class) ifTrue:[^ nil].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   635
		"id class "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   636
		recTree := recTree receiver
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   637
	    ].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   638
	    recTree isPrimary ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   639
		name := recTree name.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   640
		changeClassNames at:changeNr put:name.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   641
		^ name
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   642
	    ]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   643
	]
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   644
    ].
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   645
    ^ nil
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   646
!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   647
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   648
autoSelectOrEnd:changeNr
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   649
    "select the next change or the last"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   650
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   651
    |last|
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   652
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   653
    last := changePositions size.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   654
    changeNr < last ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   655
	self autoSelect:changeNr
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   656
    ] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   657
	changeListView selection:last .
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   658
	self changeSelection:last.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   659
    ]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   660
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   661
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   662
withSelectedChangeDo:aBlock
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   663
    "just a helper, check for a selected change and evaluate aBlock
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   664
     with busy cursor"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   665
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   666
    |changeNr|
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   667
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   668
    changeNr := changeListView selection.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   669
    changeNr notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   670
	self withCursor:(Cursor execute) do:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   671
	    aBlock value:changeNr
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   672
	]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   673
    ]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   674
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   675
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   676
autoSelectLast
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   677
    "select the last change"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   678
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   679
    self autoSelect:(changePositions size)
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   680
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   681
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   682
compareChange:changeNr
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   683
    "compare a change with current version"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   684
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   685
    |aStream chunk sawExcla parseTree thisClass cat oldSource newSource
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   686
     parser sel oldMethod outcome showDiff d t1 t2|
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   687
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   688
    aStream := self streamForChange:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   689
    aStream isNil ifTrue:[^ self].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   690
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   691
    sawExcla := aStream peekFor:(aStream class chunkSeparator).
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   692
    chunk := aStream nextChunk.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   693
    sawExcla ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   694
	outcome := 'not comparable ...'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   695
    ] ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   696
	parseTree := Parser parseExpression:chunk.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   697
	(parseTree notNil and:[parseTree isMessage]) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   698
	    (parseTree selector == #methodsFor:) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   699
		thisClass := (parseTree receiver evaluate).
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   700
		thisClass isBehavior ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   701
		    showDiff := false.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   702
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   703
		    cat := parseTree arg1 evaluate.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   704
		    newSource := aStream nextChunk.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   705
		    parser := Parser parseMethod:newSource in:thisClass.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   706
		    (parser notNil and:[parser ~~ #Error]) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   707
			sel := parser selector.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   708
			oldMethod := thisClass compiledMethodAt:sel.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   709
			oldMethod notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   710
			    (oldMethod category = cat) ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   711
				Transcript showCr:'category changed.'.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   712
			    ].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   713
			    oldSource := oldMethod source.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   714
			    (oldSource = newSource) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   715
				outcome := 'same source'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   716
			    ] ifFalse:[
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   717
				oldSource isNil ifTrue:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   718
				    outcome := 'no source for compare.'
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   719
				] ifFalse:[
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   720
				    "/
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   721
				    "/ compare for tabulator <-> space changes
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   722
				    "/ before showing diff ...
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   723
				    "/
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   724
				    t1 := oldSource asString withTabsExpanded.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   725
				    t2 := newSource asString withTabsExpanded.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   726
				    t1 = t2 ifTrue:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   727
					outcome := 'same source (tabs <-> spaces)'
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   728
				    ] ifFalse:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   729
					outcome := 'source changed.'.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   730
					showDiff := true
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   731
				    ]
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   732
				]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   733
			    ]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   734
			] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   735
			    outcome := 'method does not exist.'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   736
			]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   737
		    ] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   738
			outcome := 'change unparsable.'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   739
		    ].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   740
		    (showDiff and:[oldSource notNil and:[newSource notNil]]) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   741
			d := DiffTextView openOn:oldSource and:newSource.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   742
			d label:'differences (current left; change right)'.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   743
		    ]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   744
		] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   745
		    outcome := 'class does not exist.'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   746
		]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   747
	    ] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   748
		outcome := 'not comparable.'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   749
	    ]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   750
	] ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   751
	    outcome := 'not comparable.'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   752
	]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   753
    ].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   754
    aStream close.
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   755
    showDiff ifFalse:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   756
	self information:outcome.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   757
"/        Transcript showCr:outcome.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
   758
    ].
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   759
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   760
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   761
writeBackChanges
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   762
    "write back the changes file"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   763
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   764
    |inStream outStream|
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   765
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   766
    outStream := FileStream newFileNamed:'n_changes'.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   767
    outStream isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   768
	self warn:'cannot create temporary file'.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   769
	^ self
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   770
    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   771
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   772
    inStream := FileStream readonlyFileNamed:changeFileName.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   773
    inStream isNil ifTrue:[^ nil].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   774
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   775
    self withCursor:(Cursor write) do:[
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   776
	|excla sawExcla done dir chunk
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   777
	 nChanges "{Class:SmallInteger}" |
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   778
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   779
	excla := inStream class chunkSeparator.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   780
	nChanges := changePositions size.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   781
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   782
	1 to:nChanges do:[:index |
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   783
	    inStream position:(changePositions at:index).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   784
	    sawExcla := inStream peekFor:excla.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   785
	    chunk := inStream nextChunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   786
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   787
	    sawExcla ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   788
		outStream nextPut:excla.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   789
		outStream nextChunkPut:chunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   790
		outStream cr.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   791
		"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   792
		 a method-definition chunk - skip followups
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   793
		"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   794
		done := false.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   795
		[done] whileFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   796
		    chunk := inStream nextChunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   797
		    chunk isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   798
			done := true
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   799
		    ] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   800
			outStream nextChunkPut:chunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   801
			outStream cr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   802
			done := chunk isEmpty
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   803
		    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   804
		].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   805
	    ] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   806
		outStream nextChunkPut:chunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   807
		outStream cr
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   808
	    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   809
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   810
	outStream close.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   811
	inStream close.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   812
	dir := FileDirectory currentDirectory.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   813
	dir renameFile:changeFileName newName:'changes.bak'.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   814
	dir renameFile:'n_changes' newName:changeFileName.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   815
	anyChanges := false
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   816
    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   817
!
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   818
571fd5eee315 Initial revision
claus
parents:
diff changeset
   819
deleteChange:changeNr
571fd5eee315 Initial revision
claus
parents:
diff changeset
   820
    "delete a change"
571fd5eee315 Initial revision
claus
parents:
diff changeset
   821
571fd5eee315 Initial revision
claus
parents:
diff changeset
   822
    changeListView deselect.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   823
    self silentDeleteChange:changeNr.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   824
    self setChangeList 
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   825
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   826
!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   827
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   828
deleteChangesFrom:start to:stop
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   829
    "delete a range of changes"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   830
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   831
    changeListView deselect.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   832
    stop to:start by:-1 do:[:changeNr |
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   833
	self silentDeleteChange:changeNr
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   834
    ].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   835
    self setChangeList 
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   836
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   837
!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   838
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   839
queryCloseText
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   840
    "made this a method for easy redefinition in subclasses"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   841
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   842
    ^ 'Quit without updating changeFile ?'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   843
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   844
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   845
changeFileName:aFileName
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   846
    changeFileName := aFileName
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   847
!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   848
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   849
readChangesFile
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   850
    "read the changes file, create a list of header-lines (changeChunks)
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   851
     and a list of chunk-positions (changePositions)"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   852
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   853
    ^ self readChangesFileInBackground:false
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   854
!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   855
28
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   856
appendChange:changeNr toFile:fileName
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   857
    "append change to a file. return true if ok."
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   858
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   859
    |aStream outStream chunk sawExcla separator|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   860
28
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   861
    outStream := FileStream oldFileNamed:fileName.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   862
    outStream isNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   863
	outStream isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   864
	    outStream := FileStream newFileNamed:fileName.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   865
	    outStream isNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   866
		self warn:'cannot update file ''%1''' with:fileName.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   867
		^ false
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   868
	    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   869
	]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   870
    ].
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   871
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   872
    outStream setToEnd.
28
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   873
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   874
    aStream := self streamForChange:changeNr.
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   875
    aStream isNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   876
	self warn:'oops cannot read change'.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   877
	^ false
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   878
    ].
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   879
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   880
    separator := aStream class chunkSeparator.
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   881
    sawExcla := aStream peekFor:separator.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   882
    sawExcla ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   883
	outStream nextPut:separator
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   884
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   885
    chunk := aStream nextChunk.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   886
    outStream nextChunkPut:chunk.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   887
    outStream cr.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   888
    sawExcla ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   889
	chunk := aStream nextChunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   890
	outStream nextChunkPut:chunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   891
	outStream space
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   892
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   893
    sawExcla ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   894
	outStream nextPut:separator
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   895
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   896
    outStream cr.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   897
    aStream close.
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   898
    outStream close.
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   899
    ^ true
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   900
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   901
28
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   902
makeChangeAPatch:changeNr
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   903
    "append change to patchfile"
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   904
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   905
    self appendChange:changeNr toFile:'patches'
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   906
!
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   907
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   908
makeChangePermanent:changeNr
28
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   909
    "rewrite the source file where change changeNr lies"
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   910
571fd5eee315 Initial revision
claus
parents:
diff changeset
   911
    self notify:'this is not yet implemented'
571fd5eee315 Initial revision
claus
parents:
diff changeset
   912
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
   913
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   914
silentDeleteChangesFor:aClassName from:start to:stop
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   915
    "delete changes for a given class in a range"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   916
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   917
    |thisClassName index|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   918
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   919
    index := stop.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   920
    [index >= start] whileTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   921
	thisClassName := self classNameOfChange:index.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   922
	thisClassName = aClassName ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   923
	    self silentDeleteChange:index
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   924
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   925
	index := index - 1
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   926
    ]
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   927
571fd5eee315 Initial revision
claus
parents:
diff changeset
   928
! !
571fd5eee315 Initial revision
claus
parents:
diff changeset
   929
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   930
!ChangesBrowser methodsFor:'user interaction'!
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   931
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   932
doApply
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   933
    "user wants a change to be applied"
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   934
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   935
    self withSelectedChangeDo:[:changeNr |
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   936
	skipSignal := nil.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   937
	self applyChange:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   938
	self autoSelect:(changeNr + 1)
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
   939
    ]
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   940
!
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
   941
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   942
changeSelection:lineNr
571fd5eee315 Initial revision
claus
parents:
diff changeset
   943
    "show a change in the codeView"
571fd5eee315 Initial revision
claus
parents:
diff changeset
   944
571fd5eee315 Initial revision
claus
parents:
diff changeset
   945
    |aStream sawExcla chunk|
571fd5eee315 Initial revision
claus
parents:
diff changeset
   946
571fd5eee315 Initial revision
claus
parents:
diff changeset
   947
    aStream := self streamForChange:lineNr.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   948
    aStream isNil ifTrue:[^ self].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   949
    sawExcla := aStream peekFor:(aStream class chunkSeparator).
571fd5eee315 Initial revision
claus
parents:
diff changeset
   950
    chunk := aStream nextChunk.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   951
    sawExcla ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   952
	chunk := aStream nextChunk
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   953
    ].
571fd5eee315 Initial revision
claus
parents:
diff changeset
   954
    aStream close.
571fd5eee315 Initial revision
claus
parents:
diff changeset
   955
    codeView contents:chunk.
13
145a9461122e *** empty log message ***
claus
parents: 6
diff changeset
   956
    codeView acceptAction:[:theCode | self doApply "noChangesAllowed"].
15
7fc8fcef7bc6 *** empty log message ***
claus
parents: 13
diff changeset
   957
    changeNrShown := lineNr.
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
   958
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   959
!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
   960
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   961
noChangesAllowed
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   962
    "show a warning that changes cannot be changed"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   963
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   964
    self warn:'changes are not allowed to be changed'
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   965
!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   966
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   967
doSaveClass
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   968
    "user wants changes for some class from current to end to be appended to a file"
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   969
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   970
    self doSaveClassFrom:1
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   971
!
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   972
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   973
doSaveClassAll
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   974
    "user wants changes for some class from current to end to be appended to a file"
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   975
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   976
    self doSaveClassFrom:1
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   977
!
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   978
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   979
doSaveClassRest
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   980
    "user wants changes for some class from current to end to be appended to a file"
28
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   981
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   982
    |changeNr|
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   983
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   984
    changeNr := changeListView selection.
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
   985
    changeNr notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   986
	self doSaveClassFrom:changeNr
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   987
    ]
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   988
!
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
   989
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   990
doBrowse
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   991
    "user wants a browser on the class of a change"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   992
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   993
    |changeNr className cls|
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   994
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   995
    changeNr := changeListView selection.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   996
    changeNr notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   997
	className := self classNameOfChange:changeNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   998
	className notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
   999
	    (cls := Smalltalk classNamed:className) notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1000
		SystemBrowser browseClass:cls
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1001
	    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1002
	]
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1003
    ]
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1004
!
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1005
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1006
doCompare
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1007
    "compare change with current system version
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1008
     - give a note in transcript"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1009
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1010
    |changeNr|
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1011
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1012
    changeNr := changeListView selection.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1013
    changeNr notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1014
	self withCursor:(Cursor execute) do:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1015
	    self compareChange:changeNr
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1016
	]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1017
    ]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1018
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1019
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1020
saveClass:aClassName from:startNr
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1021
    "user wants changes from current to end to be appended to a file"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1022
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1023
    |changeNr fileName|
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1024
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1025
    changeNr := changeListView selection.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1026
    changeNr notNil ifTrue:[
77
bfb07ce94a87 *** empty log message ***
claus
parents: 75
diff changeset
  1027
	fileName := Dialog
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1028
			requestFileName:'append changes for class to:'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1029
			default:''
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1030
			ok:'append'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1031
			abort:'abort'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1032
			pattern:'*.chg'.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1033
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1034
	fileName notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1035
	    self withCursor:(Cursor write) do:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1036
		startNr to:(changePositions size) do:[:changeNr |
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1037
		    |thisClassName|
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1038
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1039
		    thisClassName := self classNameOfChange:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1040
		    thisClassName = aClassName ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1041
			changeListView selection:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1042
			(self appendChange:changeNr toFile:fileName) ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1043
			    ^ self
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1044
			]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1045
		    ]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1046
		]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1047
	    ]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1048
	].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1049
    ]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1050
!
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1051
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1052
doDelete
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1053
    "delete currently selected change"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1054
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1055
    |changeNr|
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1056
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1057
    changeNr := changeListView selection.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1058
    changeNr notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1059
	self deleteChange:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1060
	self autoSelectOrEnd:changeNr
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1061
    ]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1062
!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1063
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1064
doSaveClassFrom:startNr
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1065
    "user wants changes from current to end to be appended to a file"
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1066
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1067
    |changeNr classNameToSave|
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1068
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1069
    changeNr := changeListView selection.
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1070
    changeNr notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1071
	classNameToSave := self classNameOfChange:changeNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1072
	classNameToSave notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1073
	    self saveClass:classNameToSave from:startNr
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1074
	]
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1075
    ]
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1076
!
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1077
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1078
doSaveRest
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1079
    "user wants changes from current to end to be appended to a file"
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1080
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1081
    |changeNr fileName|
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1082
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1083
    changeNr := changeListView selection.
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1084
    changeNr notNil ifTrue:[
77
bfb07ce94a87 *** empty log message ***
claus
parents: 75
diff changeset
  1085
	fileName := Dialog
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1086
			requestFileName:'append changes to:'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1087
			default:''
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1088
			ok:'append'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1089
			abort:'abort'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1090
			pattern:'*.chg'.
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1091
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1092
	fileName notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1093
	    self withCursor:(Cursor write) do:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1094
		changeNr to:(changePositions size) do:[:changeNr |
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1095
		    changeListView selection:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1096
		    (self appendChange:changeNr toFile:fileName) ifFalse:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1097
			^ self
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1098
		    ]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1099
		]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1100
	    ]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1101
	].
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1102
    ]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1103
!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1104
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1105
doSave
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1106
    "user wants a change to be appended to a file"
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1107
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1108
    |changeNr fileName|
37
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1109
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1110
    changeNr := changeListView selection.
50f59bad66b1 *** empty log message ***
claus
parents: 33
diff changeset
  1111
    changeNr notNil ifTrue:[
77
bfb07ce94a87 *** empty log message ***
claus
parents: 75
diff changeset
  1112
	fileName := Dialog
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1113
			requestFileName:'append change to:'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1114
			default:''
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1115
			ok:'append'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1116
			abort:'abort'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1117
			pattern:'*.chg'.
28
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
  1118
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1119
	fileName notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1120
	    self withCursor:(Cursor write) do:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1121
		self appendChange:changeNr toFile:fileName.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1122
	    ].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1123
	    self autoSelect:(changeNr + 1)
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1124
	].
28
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
  1125
    ]
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
  1126
!
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
  1127
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1128
doUpdate
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1129
    "reread the changes-file"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1130
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1131
    self readChangesFileInBackground:true.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1132
    realized ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1133
	self setChangeList.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1134
    ]
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1135
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1136
!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1137
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1138
doMakePermanent
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1139
    "user wants a change to be made permanent
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1140
     - rewrite the source file where this change has to go"
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1141
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1142
    |yesNoBox|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1143
28
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
  1144
    yesNoBox := YesNoBox new.
1
4bb1d231596f *** empty log message ***
claus
parents: 0
diff changeset
  1145
    yesNoBox title:(resources at:'Warning: this operation cannot be undone').
28
eea5a71a1e23 *** empty log message ***
claus
parents: 27
diff changeset
  1146
    yesNoBox okText:(resources at:'continue').
1
4bb1d231596f *** empty log message ***
claus
parents: 0
diff changeset
  1147
    yesNoBox noText:(resources at:'abort').
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1148
    yesNoBox okAction:[   |changeNr|
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1149
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1150
			  changeNr := changeListView selection.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1151
			  changeNr notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1152
			      self makeChangePermanent:changeNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1153
			      self autoSelect:(changeNr + 1)
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1154
			  ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1155
		      ].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1156
    yesNoBox showAtPointer
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1157
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1158
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1159
doMakePatch
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1160
    "user wants a change to be made a patch
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1161
     - copy it over to the patches file"
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1162
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1163
    |changeNr|
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1164
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1165
    changeNr := changeListView selection.
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1166
    changeNr notNil ifTrue:[
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1167
	self makeChangeAPatch:changeNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1168
	self autoSelect:(changeNr + 1)
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1169
    ]
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1170
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1171
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1172
doDeleteRest
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1173
    "delete all changes from current to the end"
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1174
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1175
    |changeNr|
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1176
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1177
    changeNr := changeListView selection.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1178
    changeNr notNil ifTrue:[
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1179
	self deleteChangesFrom:changeNr to:(changePositions size).
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1180
	self clearCodeView.
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1181
	self autoSelectOrEnd:changeNr-1
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1182
    ]
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1183
!
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1184
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1185
doCompress
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1186
    "compress the change-set; this replaces multiple method-changes by the last 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1187
     (i.e. the most recent) change"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1188
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1189
    |aStream searchIndex anyMore deleteSet index  
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1190
     str snapshotProto snapshotPrefix snapshotNameIndex fileName|
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1191
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1192
    aStream := FileStream readonlyFileNamed:changeFileName.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1193
    aStream isNil ifTrue:[^ self].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1194
58
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1195
    CompressSnapshotInfo == true ifTrue:[
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1196
	"
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1197
	 get a prototype snapshot record (to be independent of
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1198
	 the actual format ..
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1199
	"
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1200
	str := WriteStream on:String new.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1201
	Class addChangeRecordForSnapshot:'foo' to:str.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1202
	snapshotProto := str contents.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1203
	snapshotPrefix := snapshotProto copyTo:10.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1204
	snapshotNameIndex := snapshotProto findString:'foo'.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1205
    ].
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1206
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1207
    self withCursor:(Cursor execute) do:[
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1208
	|numChanges classes selectors types excla sawExcla
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1209
	 changeNr chunk aParseTree parseTreeChunk
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1210
	 thisClass thisSelector codeChunk codeParser|
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1211
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1212
	numChanges := changePositions size.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1213
	classes := Array new:numChanges.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1214
	selectors := Array new:numChanges.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1215
	types := Array new:numChanges.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1216
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1217
	"starting at the end, get the change class and change selector;
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1218
	 collect all in classes / selectors"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1219
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1220
	changeNr := numChanges.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1221
	excla := aStream class chunkSeparator.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1222
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1223
	[changeNr >= 1] whileTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1224
	    aStream position:(changePositions at:changeNr).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1225
	    sawExcla := aStream peekFor:excla.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1226
	    chunk := aStream nextChunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1227
	    sawExcla ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1228
		"optimize a bit if multiple methods for same category arrive"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1229
		(chunk = parseTreeChunk) ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1230
		    aParseTree := Parser parseExpression:chunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1231
		    parseTreeChunk := chunk
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1232
		].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1233
		(aParseTree notNil 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1234
		and:[(aParseTree ~~ #Error) 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1235
		and:[aParseTree isMessage]]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1236
		    (aParseTree selector == #methodsFor:) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1237
			thisClass := (aParseTree receiver evaluate).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1238
			codeChunk := aStream nextChunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1239
			codeParser := Parser 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1240
					  parseMethodSpecification:codeChunk
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1241
					  in:thisClass
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1242
					  ignoreErrors:true
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1243
					  ignoreWarnings:true.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1244
			codeParser notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1245
			    selectors at:changeNr put:(codeParser selector).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1246
			    classes at:changeNr put:thisClass.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1247
			    types at:changeNr put:#methodsFor
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1248
			]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1249
		    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1250
		]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1251
	    ] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1252
		aParseTree := Parser parseExpression:chunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1253
		parseTreeChunk := chunk.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1254
		(aParseTree notNil 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1255
		and:[(aParseTree ~~ #Error) 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1256
		and:[aParseTree isMessage]]) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1257
		    (aParseTree selector == #removeSelector:) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1258
			selectors at:changeNr put:(aParseTree arg1 value ).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1259
			classes at:changeNr put:(aParseTree receiver evaluate).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1260
			types at:changeNr put:#removeSelector
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1261
		    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1262
		] ifFalse:[
58
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1263
		    CompressSnapshotInfo == true ifTrue:[
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1264
			(chunk startsWith:snapshotPrefix) ifTrue:[
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1265
			    str := chunk readStream position:snapshotNameIndex.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1266
			    fileName := str upTo:(Character space).
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1267
			    "
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1268
			     kludge to allow use of match-check below
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1269
			    "
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1270
			    selectors at:changeNr put:snapshotPrefix.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1271
			    classes at:changeNr put:fileName.
43b7d463a7e5 *** empty log message ***
claus
parents: 57
diff changeset
  1272
			]
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1273
		    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1274
		]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1275
	    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1276
	    changeNr := changeNr - 1
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1277
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1278
	aStream close.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1279
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1280
	"for all changes, look for another class/selector occurence later
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1281
	 in the list and, if there is one, add change number to the delete set"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1282
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1283
	deleteSet := OrderedCollection new.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1284
	changeNr := 1.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1285
	[changeNr < changePositions size] whileTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1286
	    thisClass := classes at:changeNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1287
	    thisSelector := selectors at:changeNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1288
	    searchIndex := changeNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1289
	    anyMore := true.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1290
	    [anyMore] whileTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1291
		searchIndex := classes indexOf:thisClass
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1292
				    startingAt:(searchIndex + 1).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1293
		(searchIndex ~~ 0) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1294
		    ((selectors at:searchIndex) == thisSelector) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1295
			thisClass notNil ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1296
			    deleteSet add:changeNr.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1297
			    anyMore := false
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1298
			]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1299
		    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1300
		] ifFalse:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1301
		    anyMore := false      
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1302
		]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1303
	    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1304
	    changeNr := changeNr + 1
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1305
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1306
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1307
	"finally delete what has been found"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1308
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1309
	(deleteSet size > 0) ifTrue:[
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1310
	    changeListView deselect.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1311
	    index := deleteSet size.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1312
	    [index > 0] whileTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1313
		self silentDeleteChange:(deleteSet at:index).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1314
		index := index - 1
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1315
	    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1316
	    self setChangeList.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1317
	    "
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1318
	     scroll back a bit, if we are left way behind the list
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1319
	    "
49
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1320
	    changeListView firstLineShown > changePositions size ifTrue:[
6fe62433cfa3 *** empty log message ***
claus
parents: 45
diff changeset
  1321
		changeListView makeLineVisible:changePositions size
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1322
	    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1323
	    self clearCodeView
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1324
	]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1325
    ]
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1326
!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1327
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1328
doApplyRest
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1329
    "user wants all changes from changeNr to be applied"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1330
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1331
    self withSelectedChangeDo:[:changeNr |
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1332
	self clearCodeView.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1333
	skipSignal isNil ifTrue:[skipSignal := Signal new].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1334
	changeNr to:(changePositions size) do:[:changeNr |
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1335
	    changeListView selection:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1336
	    self applyChange:changeNr
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1337
	].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1338
	self autoSelect:changePositions size.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1339
    ]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1340
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1341
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1342
doApplyAll
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1343
    "user wants all changes to be applied"
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1344
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1345
    self withCursor:(Cursor execute) do:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1346
	self clearCodeView.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1347
	skipSignal isNil ifTrue:[skipSignal := Signal new].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1348
	1 to:(changePositions size) do:[:changeNr |
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1349
	    changeListView selection:changeNr.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1350
	    self applyChange:changeNr
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1351
	].
57
36e13831b62d *** empty log message ***
claus
parents: 56
diff changeset
  1352
	self autoSelectLast
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1353
    ]
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1354
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1355
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1356
doWriteBack
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1357
    "write back the list onto the changes file"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1358
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1359
    anyChanges ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1360
	self writeBackChanges.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1361
	realized ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1362
	    self readChangesFileInBackground:false.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1363
	    realized ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1364
		self setChangeList
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1365
	    ]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1366
	]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1367
    ]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1368
!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1369
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1370
doDeleteClassRest
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1371
    "delete rest of changes with same class as currently selected change"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1372
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1373
    self withSelectedChangeDo:[:changeNr |
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1374
	| classNameToDelete |
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1375
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1376
	classNameToDelete := self classNameOfChange:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1377
	classNameToDelete notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1378
	    changeListView selection:nil.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1379
	    self silentDeleteChangesFor:classNameToDelete 
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1380
				   from:changeNr
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1381
				     to:(changePositions size).
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1382
	    self setChangeList.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1383
	    self autoSelectOrEnd:changeNr
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1384
	]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1385
    ]
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1386
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1387
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1388
doDeleteClassAll
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1389
    "delete all changes with same class as currently selected change"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1390
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1391
    self withSelectedChangeDo:[:changeNr |
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1392
	| classNameToDelete |
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1393
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1394
	classNameToDelete := self classNameOfChange:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1395
	classNameToDelete notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1396
	    changeListView selection:nil.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1397
	    self silentDeleteChangesFor:classNameToDelete
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1398
				   from:1
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1399
				     to:(changePositions size).
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1400
	    self setChangeList. 
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1401
	    self autoSelectOrEnd:changeNr
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1402
	]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1403
    ]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1404
!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1405
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1406
doApplyClassRest
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1407
    "user wants all changes for this class from changeNr to be applied"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1408
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1409
    self withSelectedChangeDo:[:changeNr |
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1410
	|thisClassName classNameToApply lastChange|
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1411
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1412
	classNameToApply := self classNameOfChange:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1413
	classNameToApply notNil ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1414
	    self clearCodeView.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1415
	    skipSignal isNil ifTrue:[skipSignal := Signal new].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1416
	    changeNr to:(changePositions size) do:[:changeNr |
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1417
		thisClassName := self classNameOfChange:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1418
		thisClassName = classNameToApply ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1419
		    changeListView selection:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1420
		    self applyChange:changeNr.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1421
		    lastChange := changeNr
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1422
		].
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1423
	    ].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1424
	    self autoSelect:lastChange.
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1425
	]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1426
    ]
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1427
! !
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1428
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1429
!ChangesBrowser methodsFor:'initialize / release'!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1430
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1431
initialize
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1432
    |panel v upperFrame buttonPanel|
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1433
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1434
    super initialize.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1435
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1436
    changeFileName := 'changes'.
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1437
    compareChanges := false.
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1438
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1439
    panel := VariableVerticalPanel origin:(0.0 @ 0.0)
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1440
				   corner:(1.0 @ 1.0)
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1441
			      borderWidth:0
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1442
				       in:self.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1443
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1444
    upperFrame := View origin:(0.0 @ 0.0) corner:(1.0 @ 0.3) in:panel.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1445
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1446
    v := ScrollableView for:SelectionInListView in:upperFrame.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1447
    v origin:(0.0 @ 0.0) corner:(0.8 @ 1.0).
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1448
    changeListView := v scrolledView.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1449
    changeListView delegate:self.
98
claus
parents: 93
diff changeset
  1450
    changeListView menuHolder:self; menuPerformer:self; menuMessage:#changeListMenu.
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1451
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1452
    buttonPanel := VerticalPanelView in:upperFrame.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1453
    buttonPanel origin:(0.8 @ 0.0) corner:(1.0 @ 1.0).
105
claus
parents: 103
diff changeset
  1454
    buttonPanel verticalLayout:#topSpace.
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1455
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1456
    compareCheckBox := CheckBox new.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1457
    compareCheckBox label:(resources string:'compare').
93
claus
parents: 92
diff changeset
  1458
    compareCheckBox action:[:val | self compare:val].
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1459
    buttonPanel addSubView:compareCheckBox.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1460
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1461
    v := HVScrollableView for:CodeView miniScrollerH:true miniScrollerV:false in:panel.
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1462
    v origin:(0.0 @ 0.3) corner:(1.0 @ 1.0).
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1463
    codeView := v scrolledView.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1464
    codeView readOnly.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1465
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1466
    anyChanges := false.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1467
    ObjectMemory addDependent:self.   "to get shutdown-update"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1468
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1469
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1470
focusSequence
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1471
    ^ Array with:changeListView with:codeView
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1472
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1473
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1474
realize
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1475
    super realize.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1476
    self readChangesFileInBackground:true.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1477
    self setChangeList.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1478
    changeListView action:[:lineNr | self changeSelection:lineNr].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1479
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1480
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1481
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1482
update:what
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1483
    |box|
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1484
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1485
    (what == #aboutToExit) ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1486
	"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1487
	 smalltalk is about to shut down -
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1488
	 - if change list was modified, ask user and save if requested.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1489
	"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1490
	anyChanges ifTrue:[
105
claus
parents: 103
diff changeset
  1491
	    self raiseDeiconified.
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1492
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1493
	    box := YesNoBox new.
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1494
	    box title:(resources at:'changefile has not been updated from the modified changelist.\\Update before exiting ?') withCRs.
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1495
	    box noText:(resources at:'don''t update').
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1496
	    box okText:(resources at:'update').
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1497
	    box yesAction:[self writeBackChanges] 
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1498
		 noAction:[].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1499
	    box showAtPointer
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1500
	].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1501
	^ self
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1502
    ].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1503
    super update:what
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1504
!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1505
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1506
compare:aBoolean
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1507
    "sent from the compare-toggle"
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1508
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1509
    aBoolean ~~ compareChanges ifTrue:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1510
	compareChanges := aBoolean.
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1511
	compareChanges ifTrue:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1512
	    self doUpdate
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1513
	]
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1514
    ]
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1515
!
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1516
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1517
changeListMenu
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1518
    |labels selectors m|
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1519
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1520
    labels := #(
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1521
		      'apply change'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1522
		      'apply changes to end'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1523
		      'apply changes for this class to end'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1524
		      'apply all changes'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1525
		      '-'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1526
		      'delete'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1527
		      'delete to end'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1528
		      'delete changes for this class to end'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1529
		      'delete all changes for this class'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1530
		      '-'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1531
		      'update'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1532
		      'compress'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1533
		      'compare with current version'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1534
		      'browse class'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1535
		      '-'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1536
		      'make change a patch'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1537
"/                       'update sourcefile from change'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1538
"/                       '-'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1539
		      'save change in file ...'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1540
		      'save changes to end in file ...'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1541
		      'save changes for this class to end in file ...'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1542
		      'save all changes for this class in file ...'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1543
		      '-'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1544
		      'writeback changeFile').
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1545
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1546
    selectors := #(
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1547
		      doApply
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1548
		      doApplyRest
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1549
		      doApplyClassRest
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1550
		      doApplyAll
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1551
		      nil
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1552
		      doDelete
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1553
		      doDeleteRest
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1554
		      doDeleteClassRest
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1555
		      doDeleteClassAll
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1556
		      nil
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1557
		      doUpdate
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1558
		      doCompress
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1559
		      doCompare
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1560
		      doBrowse
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1561
		      nil
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1562
		      doMakePatch
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1563
"/                      doMakePermanent
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1564
"/                      nil
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1565
		      doSave
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1566
		      doSaveRest
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1567
		      doSaveClassRest
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1568
		      doSaveClassAll
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1569
		      nil
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1570
		      doWriteBack
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1571
		).
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1572
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1573
    m := PopUpMenu 
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1574
	    labels:(resources array:labels)
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1575
	    selectors:selectors.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1576
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1577
    changeListView hasSelection ifFalse:[
106
claus
parents: 105
diff changeset
  1578
	m disableAll:#(doApply doApplyClassRest doApplyRest doDelete doDeleteRest doDeleteClassRest
claus
parents: 105
diff changeset
  1579
		       doDeleteClassAll doCompare doMakePatch doSaveChangeInFile doMakePermanent
claus
parents: 105
diff changeset
  1580
		       doSave doSaveRest doSaveClassAll doSaveClassRest doBrowse) 
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1581
    ].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1582
    ^ m
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1583
! !
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1584
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1585
!ChangesBrowser methodsFor:'event handling '!
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1586
81
b3b4d34c5ada *** empty log message ***
claus
parents: 77
diff changeset
  1587
handlesKeyPress:key inView:view
b3b4d34c5ada *** empty log message ***
claus
parents: 77
diff changeset
  1588
    "this method is reached via delegation: are we prepared to handle
b3b4d34c5ada *** empty log message ***
claus
parents: 77
diff changeset
  1589
     a keyPress in some other view ?"
b3b4d34c5ada *** empty log message ***
claus
parents: 77
diff changeset
  1590
b3b4d34c5ada *** empty log message ***
claus
parents: 77
diff changeset
  1591
    view == changeListView ifTrue:[
98
claus
parents: 93
diff changeset
  1592
	(key == #Delete or:[key == #BackSpace]) ifTrue:[^ true].
81
b3b4d34c5ada *** empty log message ***
claus
parents: 77
diff changeset
  1593
    ].
b3b4d34c5ada *** empty log message ***
claus
parents: 77
diff changeset
  1594
    ^ false
b3b4d34c5ada *** empty log message ***
claus
parents: 77
diff changeset
  1595
!
b3b4d34c5ada *** empty log message ***
claus
parents: 77
diff changeset
  1596
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1597
keyPress:key x:x y:y view:view
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1598
    "this method is reached via delegation from the changeListView"
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1599
98
claus
parents: 93
diff changeset
  1600
    (key == #Delete or:[key == #BackSpace]) ifTrue:[
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1601
	self doDelete.
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1602
	^ self
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1603
    ].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1604
    changeListView keyPress:key x:x y:y
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1605
! !
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1606
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1607
!ChangesBrowser methodsFor:'termination'!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1608
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1609
terminate
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1610
    "window manager wants us to go away"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1611
107
claus
parents: 106
diff changeset
  1612
    |action|
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1613
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1614
    anyChanges ifTrue:[
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1615
	action := OptionBox 
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1616
			  request:(resources at:'changefile has not been updated from the modified changelist.\\Update before closing ?') withCRs
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1617
			  label:'ChangesBrowser'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1618
			  form:(WarningBox iconBitmap)
75
f6310cbc93b6 *** empty log message ***
claus
parents: 73
diff changeset
  1619
			  buttonLabels:(resources array:#('abort' 'don''t update' 'update'))
108
claus
parents: 107
diff changeset
  1620
			  values:#(#abort #ignore #save)
claus
parents: 107
diff changeset
  1621
			  default:#save.
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1622
	action == #abort ifTrue:[^ self].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1623
	action  == #save ifTrue:[
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1624
	    self writeBackChanges
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1625
	].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1626
    ].
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1627
    self destroy
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1628
!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1629
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1630
destroy
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1631
    "destroy the receiver; make certain, that boxes are destroyed too"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1632
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1633
    ObjectMemory removeDependent:self.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1634
    super destroy
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1635
!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1636
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1637
saveAndTerminate
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1638
    "update the changes file and quit.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1639
     Dont depend on this being sent, not all window managers
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1640
     send it; instead, they simply destroy the view."
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1641
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1642
    anyChanges ifTrue:[
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1643
	self writeBackChanges.
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1644
    ].
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1645
    self destroy
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1646
! !
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1647
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1648
!ChangesBrowser methodsFor:'help '!
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1649
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1650
helpTextFor:aComponent
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1651
    aComponent == codeView ifTrue:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1652
	^ resources string:'HELP_CODEVIEW'
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1653
    ].
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1654
    aComponent == changeListView ifTrue:[
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1655
	^ resources string:'HELP_CHANGELIST'
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1656
    ].
90
60d0bb749a1c *** empty log message ***
claus
parents: 89
diff changeset
  1657
    ((aComponent == compareCheckBox)
60d0bb749a1c *** empty log message ***
claus
parents: 89
diff changeset
  1658
    or:[aComponent superView == compareCheckBox]) ifTrue:[
89
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1659
	^ resources string:'HELP_CHECK_COMPARE'
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1660
    ].
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1661
    ^ nil
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1662
! !
43ca5e534f5e *** empty log message ***
claus
parents: 81
diff changeset
  1663
93
claus
parents: 92
diff changeset
  1664
!ChangesBrowser methodsFor:'compiler interface'!
claus
parents: 92
diff changeset
  1665
claus
parents: 92
diff changeset
  1666
wantChangeLog
claus
parents: 92
diff changeset
  1667
    "sent by the compiler to ask if a changeLog entry should
claus
parents: 92
diff changeset
  1668
     be written. Return false here."
claus
parents: 92
diff changeset
  1669
claus
parents: 92
diff changeset
  1670
    ^ false
claus
parents: 92
diff changeset
  1671
! !
claus
parents: 92
diff changeset
  1672
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1673
!ChangesBrowser methodsFor:'error handling'!
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1674
92
claus
parents: 90
diff changeset
  1675
correctableError:aString position:relPos to:relEndPos from:aCompiler
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1676
    "compiler notifys us of an error - this should really not happen since
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1677
     changes ought to be correct (did someone edit the changes file ??).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1678
     Show the bad change in the codeView and let codeView hilight the error;
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1679
     no corrections allowed here therefore return false"
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1680
92
claus
parents: 90
diff changeset
  1681
    self error:aString position:relPos to:relEndPos from:aCompiler.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1682
    ^ false
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1683
!
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1684
92
claus
parents: 90
diff changeset
  1685
warning:aString position:relPos to:relEndPos from:aCompiler
51
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1686
    "compiler notifys us of a warning - ignore it"
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1687
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1688
    ^ self
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1689
!
57c1ccc3d7e0 *** empty log message ***
claus
parents: 50
diff changeset
  1690
92
claus
parents: 90
diff changeset
  1691
error:aString position:relPos to:relEndPos from:aCompiler
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1692
    "compiler notifys us of an error - this should really not happen since
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1693
     changes ought to be correct (did someone edit the changes file ??).
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1694
     Show the bad change in the codeView and let codeView hilight the error"
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1695
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1696
    |action|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1697
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1698
    (changeNrProcessed ~~ changeNrShown) ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1699
	self changeSelection:changeNrProcessed
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1700
    ].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1701
    (skipSignal notNil) ifTrue:[
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1702
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1703
	codeView highlightingErrorPosition:relPos to:relEndPos do:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1704
	    |box|
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1705
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1706
	    "
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1707
	     start dialog - make certain cleanup is done
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1708
	    "
73
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1709
	    action := OptionBox 
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1710
			  request:aString
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1711
			  label:'Error'
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1712
			  form:(WarningBox iconBitmap)
e332d9c71624 *** empty log message ***
claus
parents: 68
diff changeset
  1713
			  buttonLabels:#('abort' 'skip' 'continue')
108
claus
parents: 107
diff changeset
  1714
			  values:#(#abort #skip #continue)
claus
parents: 107
diff changeset
  1715
			  default:#continue.
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1716
	].
0
571fd5eee315 Initial revision
claus
parents:
diff changeset
  1717
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1718
	action == #abort ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1719
	    Object abortSignal raise.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1720
	    ^ false
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1721
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1722
	action == #skip ifTrue:[
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1723
	    skipSignal raise.
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1724
	    ^ false
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1725
	].
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1726
	^  false 
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1727
    ].
103
claus
parents: 98
diff changeset
  1728
    ^ codeView error:aString position:relPos to:relEndPos from:aCompiler
45
950b84ba89e6 *** empty log message ***
claus
parents: 37
diff changeset
  1729
! !