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