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