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