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