HistoryManager.st
author Claus Gittinger <cg@exept.de>
Thu, 23 Nov 1995 02:58:09 +0100
changeset 87 e0f5b58481a6
parent 82 e306d7662ae8
child 119 1a9c5a761edf
permissions -rw-r--r--
checkin from browser
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
46
claus
parents: 43
diff changeset
     1
"
claus
parents: 43
diff changeset
     2
 COPYRIGHT (c) 1995 by AEG Industry Automation
claus
parents: 43
diff changeset
     3
 COPYRIGHT (c) 1995 by Claus Gittinger
claus
parents: 43
diff changeset
     4
	      All Rights Reserved
claus
parents: 43
diff changeset
     5
claus
parents: 43
diff changeset
     6
 This software is furnished under a license and may be used
claus
parents: 43
diff changeset
     7
 only in accordance with the terms of that license and with the
claus
parents: 43
diff changeset
     8
 inclusion of the above copyright notice.   This software may not
claus
parents: 43
diff changeset
     9
 be provided or otherwise made available to, or used by, any
claus
parents: 43
diff changeset
    10
 other person.  No title to or ownership of the software is
claus
parents: 43
diff changeset
    11
 hereby transferred.
claus
parents: 43
diff changeset
    12
"
claus
parents: 43
diff changeset
    13
41
claus
parents:
diff changeset
    14
Object subclass:#HistoryManager
claus
parents:
diff changeset
    15
	 instanceVariableNames:'historyMode'
claus
parents:
diff changeset
    16
	 classVariableNames:'TheOneAndOnlyInstance'
claus
parents:
diff changeset
    17
	 poolDictionaries:''
claus
parents:
diff changeset
    18
	 category:'System-Changes-History'
claus
parents:
diff changeset
    19
!
claus
parents:
diff changeset
    20
claus
parents:
diff changeset
    21
!HistoryManager class methodsFor:'documentation'!
claus
parents:
diff changeset
    22
46
claus
parents: 43
diff changeset
    23
copyright 
claus
parents: 43
diff changeset
    24
"
claus
parents: 43
diff changeset
    25
 COPYRIGHT (c) 1995 by AEG Industry Automation
claus
parents: 43
diff changeset
    26
 COPYRIGHT (c) 1995 by Claus Gittinger
claus
parents: 43
diff changeset
    27
	      All Rights Reserved
claus
parents: 43
diff changeset
    28
claus
parents: 43
diff changeset
    29
 This software is furnished under a license and may be used
claus
parents: 43
diff changeset
    30
 only in accordance with the terms of that license and with the
claus
parents: 43
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
claus
parents: 43
diff changeset
    32
 be provided or otherwise made available to, or used by, any
claus
parents: 43
diff changeset
    33
 other person.  No title to or ownership of the software is
claus
parents: 43
diff changeset
    34
 hereby transferred.
claus
parents: 43
diff changeset
    35
"
claus
parents: 43
diff changeset
    36
!
claus
parents: 43
diff changeset
    37
41
claus
parents:
diff changeset
    38
documentation
claus
parents:
diff changeset
    39
"
claus
parents:
diff changeset
    40
    This class is part of the 
claus
parents:
diff changeset
    41
	       -----------------------
claus
parents:
diff changeset
    42
		HistoryManagerProject.
claus
parents:
diff changeset
    43
	       -----------------------
claus
parents:
diff changeset
    44
    It is used to create a multi user Smalltalk developers Environemt.
claus
parents:
diff changeset
    45
claus
parents:
diff changeset
    46
    All Methods and Classes in the system get a HistroyLine which contains a timestamp
claus
parents:
diff changeset
    47
    and the name of the Editor. This is acually the UniX loginname.
claus
parents:
diff changeset
    48
    The Manager registers all Classes in the System to get notifications on change.
claus
parents:
diff changeset
    49
46
claus
parents: 43
diff changeset
    50
    Author: Robert Sailer - AEG
41
claus
parents:
diff changeset
    51
"
claus
parents:
diff changeset
    52
!
claus
parents:
diff changeset
    53
claus
parents:
diff changeset
    54
examples
claus
parents:
diff changeset
    55
"
claus
parents:
diff changeset
    56
    HistoryManager new
claus
parents:
diff changeset
    57
"
claus
parents:
diff changeset
    58
    "Modified: 11.08.1995 / 16:50:47 / robert"
87
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
    59
!
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
    60
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
    61
version
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
    62
    ^ '$Header: /cvs/stx/stx/libbasic3/HistoryManager.st,v 1.12 1995-11-23 01:57:14 cg Exp $'
41
claus
parents:
diff changeset
    63
! !
claus
parents:
diff changeset
    64
claus
parents:
diff changeset
    65
!HistoryManager class methodsFor:'initialization'!
claus
parents:
diff changeset
    66
87
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
    67
initMe
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
    68
    "setup TheOneAndOnlyInstance (if not already present"
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
    69
    ^self new.
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
    70
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
    71
    "Modified: 14.08.1995 / 9:52:40 / robert"
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
    72
!
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
    73
41
claus
parents:
diff changeset
    74
initialize
claus
parents:
diff changeset
    75
    ""
claus
parents:
diff changeset
    76
    ObjectMemory addDependent: self.
claus
parents:
diff changeset
    77
claus
parents:
diff changeset
    78
    "Modified: 14.08.1995 / 9:49:56 / robert"
claus
parents:
diff changeset
    79
! !
claus
parents:
diff changeset
    80
claus
parents:
diff changeset
    81
!HistoryManager class methodsFor:'instance creation'!
claus
parents:
diff changeset
    82
claus
parents:
diff changeset
    83
new
46
claus
parents: 43
diff changeset
    84
    "because there can be only ONE HistoryManager, new must me redefiend"
41
claus
parents:
diff changeset
    85
claus
parents:
diff changeset
    86
    TheOneAndOnlyInstance isNil ifTrue:[
claus
parents:
diff changeset
    87
	TheOneAndOnlyInstance := super new initialize.
claus
parents:
diff changeset
    88
	HistoryLine initialize.
claus
parents:
diff changeset
    89
    ].
claus
parents:
diff changeset
    90
claus
parents:
diff changeset
    91
   ^ TheOneAndOnlyInstance
claus
parents:
diff changeset
    92
claus
parents:
diff changeset
    93
"
claus
parents:
diff changeset
    94
claus
parents:
diff changeset
    95
    HistoryManager new.
claus
parents:
diff changeset
    96
"
claus
parents:
diff changeset
    97
claus
parents:
diff changeset
    98
    "Modified: 11.08.1995 / 17:01:29 / robert"
claus
parents:
diff changeset
    99
! !
claus
parents:
diff changeset
   100
claus
parents:
diff changeset
   101
!HistoryManager class methodsFor:'accessing'!
claus
parents:
diff changeset
   102
claus
parents:
diff changeset
   103
instance
claus
parents:
diff changeset
   104
    "return the class variable"
claus
parents:
diff changeset
   105
claus
parents:
diff changeset
   106
    ^TheOneAndOnlyInstance
claus
parents:
diff changeset
   107
!
claus
parents:
diff changeset
   108
claus
parents:
diff changeset
   109
isActive 
claus
parents:
diff changeset
   110
    ^TheOneAndOnlyInstance notNil
claus
parents:
diff changeset
   111
claus
parents:
diff changeset
   112
    "Modified: 27.8.1995 / 00:32:12 / claus"
claus
parents:
diff changeset
   113
! !
claus
parents:
diff changeset
   114
claus
parents:
diff changeset
   115
!HistoryManager class methodsFor:'activation / deactivation'!
claus
parents:
diff changeset
   116
claus
parents:
diff changeset
   117
activate
claus
parents:
diff changeset
   118
    self new   "/ creating an instance activates me
claus
parents:
diff changeset
   119
!
claus
parents:
diff changeset
   120
claus
parents:
diff changeset
   121
deactivate
claus
parents:
diff changeset
   122
    Smalltalk allClassesDo:[:aClass |
claus
parents:
diff changeset
   123
	aClass removeDependent:TheOneAndOnlyInstance.
claus
parents:
diff changeset
   124
	aClass class removeDependent:TheOneAndOnlyInstance.
claus
parents:
diff changeset
   125
    ].
claus
parents:
diff changeset
   126
    TheOneAndOnlyInstance := nil.
claus
parents:
diff changeset
   127
claus
parents:
diff changeset
   128
"
claus
parents:
diff changeset
   129
    HistoryManager release
claus
parents:
diff changeset
   130
"
claus
parents:
diff changeset
   131
! !
claus
parents:
diff changeset
   132
87
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   133
!HistoryManager class methodsFor:'change and update'!
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   134
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   135
update: what
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   136
    (what == #restarted) ifTrue:[
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   137
	TheOneAndOnlyInstance notNil ifTrue:[
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   138
	    "
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   139
	     smalltalk is about to restart from an Image -
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   140
	    "
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   141
"/            'HistoryManager initialize (via update)' infoPrintNL.
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   142
	    self initMe.
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   143
	]
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   144
    ].
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   145
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   146
    "Modified: 27.8.1995 / 16:33:02 / claus"
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   147
! !
e0f5b58481a6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 82
diff changeset
   148
47
claus
parents: 46
diff changeset
   149
!HistoryManager class methodsFor:'helpers'!
claus
parents: 46
diff changeset
   150
claus
parents: 46
diff changeset
   151
getAllHistoriesFrom:someString
claus
parents: 46
diff changeset
   152
    "returns anArray of HistoryLines"
claus
parents: 46
diff changeset
   153
claus
parents: 46
diff changeset
   154
    |position aReadWriteStream firstFound nextFound  aHistoryString rcOC h|
claus
parents: 46
diff changeset
   155
claus
parents: 46
diff changeset
   156
    "read begining from the end and look there for the first comment character. If there's none return"
claus
parents: 46
diff changeset
   157
claus
parents: 46
diff changeset
   158
    rcOC := OrderedCollection new.
claus
parents: 46
diff changeset
   159
    position := someString size.
claus
parents: 46
diff changeset
   160
    firstFound := false.
claus
parents: 46
diff changeset
   161
    nextFound := false.
claus
parents: 46
diff changeset
   162
claus
parents: 46
diff changeset
   163
    someString reverseDo:[ :aChar|
claus
parents: 46
diff changeset
   164
	position := position - 1.
claus
parents: 46
diff changeset
   165
	aChar = $" ifTrue:[
claus
parents: 46
diff changeset
   166
	    firstFound ifTrue:[
claus
parents: 46
diff changeset
   167
		firstFound := false.
claus
parents: 46
diff changeset
   168
		nextFound := true.
claus
parents: 46
diff changeset
   169
	    ] ifFalse:[
claus
parents: 46
diff changeset
   170
		aReadWriteStream := ReadWriteStream on: String new.
claus
parents: 46
diff changeset
   171
		firstFound := true.
claus
parents: 46
diff changeset
   172
		nextFound := false.
claus
parents: 46
diff changeset
   173
	    ].
claus
parents: 46
diff changeset
   174
	].
claus
parents: 46
diff changeset
   175
	(firstFound and: [nextFound not]) ifTrue:[
claus
parents: 46
diff changeset
   176
	    "now collect all up to the next comment character"
claus
parents: 46
diff changeset
   177
	    aChar = $" ifFalse:[     
claus
parents: 46
diff changeset
   178
		aReadWriteStream nextPut: aChar.
claus
parents: 46
diff changeset
   179
	    ].
claus
parents: 46
diff changeset
   180
	].
claus
parents: 46
diff changeset
   181
	nextFound ifTrue:[
claus
parents: 46
diff changeset
   182
	    "End reached - now try to make a HistoryLine"
claus
parents: 46
diff changeset
   183
	    aHistoryString := (aReadWriteStream contents) reverse.
claus
parents: 46
diff changeset
   184
	    "
claus
parents: 46
diff changeset
   185
		Transcript showCr: aHistoryString.
claus
parents: 46
diff changeset
   186
	    "
claus
parents: 46
diff changeset
   187
	    h := HistoryLine fromString: aHistoryString at: position.
claus
parents: 46
diff changeset
   188
	    h notNil ifTrue:[
claus
parents: 46
diff changeset
   189
		rcOC add:h.
claus
parents: 46
diff changeset
   190
	    ].
claus
parents: 46
diff changeset
   191
"/            (aHistoryString startsWith: 'Modified:') ifTrue:[
claus
parents: 46
diff changeset
   192
"/                "a history line was found - now make a NewInstance of HistoryLine"
claus
parents: 46
diff changeset
   193
"/                rcOC add: ( HistoryLine fromString: aHistoryString at: position).
claus
parents: 46
diff changeset
   194
"/            ].
claus
parents: 46
diff changeset
   195
	    nextFound := false.
claus
parents: 46
diff changeset
   196
	].
claus
parents: 46
diff changeset
   197
    ].
claus
parents: 46
diff changeset
   198
claus
parents: 46
diff changeset
   199
    ^rcOC reverse  "the OrderedCollection with HistoryLines in the right order"
claus
parents: 46
diff changeset
   200
claus
parents: 46
diff changeset
   201
    "Modified: 21.12.1993 / 18:32:30 / M.Noell"
claus
parents: 46
diff changeset
   202
    "Modified: 9.8.1995 / 22:45:30 / R.Sailer"
claus
parents: 46
diff changeset
   203
    "Modified: 8.9.1995 / 17:54:33 / claus"
claus
parents: 46
diff changeset
   204
! !
claus
parents: 46
diff changeset
   205
41
claus
parents:
diff changeset
   206
!HistoryManager methodsFor:'accessing'!
claus
parents:
diff changeset
   207
claus
parents:
diff changeset
   208
historyMode
claus
parents:
diff changeset
   209
    "return historyMode"
claus
parents:
diff changeset
   210
claus
parents:
diff changeset
   211
    ^ historyMode
claus
parents:
diff changeset
   212
claus
parents:
diff changeset
   213
    "Modified: 11.08.1995 / 16:51:56 / robert"
claus
parents:
diff changeset
   214
!
claus
parents:
diff changeset
   215
claus
parents:
diff changeset
   216
historyMode:something
claus
parents:
diff changeset
   217
    "set historyMode"
claus
parents:
diff changeset
   218
claus
parents:
diff changeset
   219
    historyMode := something.
claus
parents:
diff changeset
   220
claus
parents:
diff changeset
   221
    "Modified: 11.08.1995 / 16:52:12 / robert"
claus
parents:
diff changeset
   222
! !
claus
parents:
diff changeset
   223
claus
parents:
diff changeset
   224
!HistoryManager methodsFor:'initialization'!
claus
parents:
diff changeset
   225
claus
parents:
diff changeset
   226
exclude
46
claus
parents: 43
diff changeset
   227
    "public - return an exclusionlist for some smalltalk classes which should not be notified or historisized"
41
claus
parents:
diff changeset
   228
claus
parents:
diff changeset
   229
    | oc |
claus
parents:
diff changeset
   230
        
claus
parents:
diff changeset
   231
    oc := OrderedCollection new.
claus
parents:
diff changeset
   232
    oc add: self.
claus
parents:
diff changeset
   233
claus
parents:
diff changeset
   234
    ^oc
claus
parents:
diff changeset
   235
claus
parents:
diff changeset
   236
    "Modified: 11.08.1995 / 17:02:18 / robert"
claus
parents:
diff changeset
   237
!
claus
parents:
diff changeset
   238
claus
parents:
diff changeset
   239
initialize
46
claus
parents: 43
diff changeset
   240
    "public - make me depend on all smalltalk classes (except the exclusionList)
claus
parents: 43
diff changeset
   241
     to be notified later about changes. This intercepts source installation and allows
claus
parents: 43
diff changeset
   242
     be to patch the source-string with a historyLine."
41
claus
parents:
diff changeset
   243
53
claus
parents: 48
diff changeset
   244
    |exclusionlist|
41
claus
parents:
diff changeset
   245
claus
parents:
diff changeset
   246
    super initialize.
claus
parents:
diff changeset
   247
    historyMode := true.
claus
parents:
diff changeset
   248
    exclusionlist := self exclude.
claus
parents:
diff changeset
   249
claus
parents:
diff changeset
   250
    Smalltalk allClasses do:[:aClass|
claus
parents:
diff changeset
   251
	"all classes should send a notification if changed"
claus
parents:
diff changeset
   252
	"aClass = self " false ifFalse: [
claus
parents:
diff changeset
   253
	    (exclusionlist includes: aClass) ifFalse:[
claus
parents:
diff changeset
   254
		aClass addDependent: self.
claus
parents:
diff changeset
   255
		aClass class addDependent: self.   "for class methods"
claus
parents:
diff changeset
   256
	    ].
claus
parents:
diff changeset
   257
	].
claus
parents:
diff changeset
   258
    ].
claus
parents:
diff changeset
   259
claus
parents:
diff changeset
   260
    ^self
claus
parents:
diff changeset
   261
claus
parents:
diff changeset
   262
    "Modified: 11.08.1995 / 17:12:51 / robert"
claus
parents:
diff changeset
   263
! !
claus
parents:
diff changeset
   264
claus
parents:
diff changeset
   265
!HistoryManager methodsFor:'updateHistory'!
claus
parents:
diff changeset
   266
claus
parents:
diff changeset
   267
addHistoryTo:someString
claus
parents:
diff changeset
   268
    "private - add a historyLine at end to the sourceCode;
claus
parents:
diff changeset
   269
     check for multiple lines of the same user and merge into one."
claus
parents:
diff changeset
   270
53
claus
parents: 48
diff changeset
   271
    | histLines pos wStream sourceCode previousHistories
47
claus
parents: 46
diff changeset
   272
      newLine |
41
claus
parents:
diff changeset
   273
53
claus
parents: 48
diff changeset
   274
    "Check whether we want a history to be added"    
claus
parents: 48
diff changeset
   275
    historyMode ifFalse:[
claus
parents: 48
diff changeset
   276
	^ someString
claus
parents: 48
diff changeset
   277
    ].
47
claus
parents: 46
diff changeset
   278
    previousHistories := self class getAllHistoriesFrom:someString.
41
claus
parents:
diff changeset
   279
claus
parents:
diff changeset
   280
    "extract source body."
claus
parents:
diff changeset
   281
    previousHistories isEmpty ifTrue: [
claus
parents:
diff changeset
   282
	sourceCode := someString withoutSeparators.
47
claus
parents: 46
diff changeset
   283
	newLine := (HistoryLine newCreated).
41
claus
parents:
diff changeset
   284
    ] ifFalse: [
claus
parents:
diff changeset
   285
	pos := (previousHistories first) firstPositionInSourceCode.
claus
parents:
diff changeset
   286
	sourceCode := (someString copyFrom: 1 to: pos - 1) withoutSeparators.
47
claus
parents: 46
diff changeset
   287
	newLine := (HistoryLine new).
41
claus
parents:
diff changeset
   288
    ].
claus
parents:
diff changeset
   289
claus
parents:
diff changeset
   290
    "add the actual user's historyLine."
47
claus
parents: 46
diff changeset
   291
    previousHistories add:newLine.
41
claus
parents:
diff changeset
   292
claus
parents:
diff changeset
   293
    "Filtering historyLines each user with one entry)."
claus
parents:
diff changeset
   294
    histLines := HistoryLine filterHistoryLines: previousHistories.
claus
parents:
diff changeset
   295
claus
parents:
diff changeset
   296
    "create new body with added historyLine"
claus
parents:
diff changeset
   297
    wStream := WriteStream on: String new.
claus
parents:
diff changeset
   298
    wStream nextPutAll: sourceCode; cr.
claus
parents:
diff changeset
   299
claus
parents:
diff changeset
   300
    "append the historyLines to the source"
claus
parents:
diff changeset
   301
    wStream cr.
claus
parents:
diff changeset
   302
    histLines do: [:hl |
claus
parents:
diff changeset
   303
       wStream nextPutAll:  hl printString; cr.
claus
parents:
diff changeset
   304
    ].
claus
parents:
diff changeset
   305
claus
parents:
diff changeset
   306
    ^wStream contents.
claus
parents:
diff changeset
   307
47
claus
parents: 46
diff changeset
   308
    "Modified: 11.8.1995 / 16:51:50 / robert"
claus
parents: 46
diff changeset
   309
    "Modified: 8.9.1995 / 17:55:38 / claus"
41
claus
parents:
diff changeset
   310
!
claus
parents:
diff changeset
   311
53
claus
parents: 48
diff changeset
   312
addHistoryToHistoryMethodOf:aClass
claus
parents: 48
diff changeset
   313
    |cls historyMethod oldSource newSource|
claus
parents: 48
diff changeset
   314
claus
parents: 48
diff changeset
   315
    aClass isMeta ifFalse:[
claus
parents: 48
diff changeset
   316
	cls := aClass class.
claus
parents: 48
diff changeset
   317
    ] ifTrue:[
claus
parents: 48
diff changeset
   318
	cls := aClass
claus
parents: 48
diff changeset
   319
    ].
claus
parents: 48
diff changeset
   320
    historyMethod := cls compiledMethodAt: #history.
claus
parents: 48
diff changeset
   321
    historyMethod notNil ifTrue:[
claus
parents: 48
diff changeset
   322
	oldSource := historyMethod source.
claus
parents: 48
diff changeset
   323
	oldSource notNil ifTrue:[
68
5f7ac0b5c903 uff - version methods changed to return stings
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
   324
	    newSource := self addHistoryTo:oldSource.
5f7ac0b5c903 uff - version methods changed to return stings
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
   325
	    historyMethod source:newSource.
53
claus
parents: 48
diff changeset
   326
	]
claus
parents: 48
diff changeset
   327
    ]
claus
parents: 48
diff changeset
   328
!
claus
parents: 48
diff changeset
   329
41
claus
parents:
diff changeset
   330
update: something with: someArgument from: changedObject
46
claus
parents: 43
diff changeset
   331
    "public - sent whenever any class changed somehow.
claus
parents: 43
diff changeset
   332
     (something contains aSymbol or nil)"
41
claus
parents:
diff changeset
   333
82
e306d7662ae8 oops - history line was only added to class methods
Claus Gittinger <cg@exept.de>
parents: 80
diff changeset
   334
    | sourceCode aMethod fileInOrRecompiling ignore|
41
claus
parents:
diff changeset
   335
claus
parents:
diff changeset
   336
"/    changedObject == self ifTrue:[  "for development only"
claus
parents:
diff changeset
   337
"/        self halt.
claus
parents:
diff changeset
   338
"/        ^self.
claus
parents:
diff changeset
   339
"/    ].
46
claus
parents: 43
diff changeset
   340
claus
parents: 43
diff changeset
   341
    fileInOrRecompiling := Class updateChangeFileQuerySignal raise. "Class updatingChanges."
41
claus
parents:
diff changeset
   342
53
claus
parents: 48
diff changeset
   343
"/    changedObject isMeta ifTrue:[
43
claus
parents: 42
diff changeset
   344
"/        Transcript showCr: 'metaClass = ',  changedObject printString.
53
claus
parents: 48
diff changeset
   345
"/    ].
41
claus
parents:
diff changeset
   346
claus
parents:
diff changeset
   347
    (changedObject == Smalltalk) & (something == #newClass) ifTrue:[
claus
parents:
diff changeset
   348
	someArgument addDependent: self.
claus
parents:
diff changeset
   349
	someArgument class  addDependent: self.   "for class methods"
claus
parents:
diff changeset
   350
    ].
claus
parents:
diff changeset
   351
claus
parents:
diff changeset
   352
    fileInOrRecompiling ifFalse:[ 
42
claus
parents: 41
diff changeset
   353
"/        Transcript showCr: '* noChange in history'. 
53
claus
parents: 48
diff changeset
   354
	^ self 
claus
parents: 48
diff changeset
   355
    ].
claus
parents: 48
diff changeset
   356
    historyMode ifFalse:[
claus
parents: 48
diff changeset
   357
	^ self
41
claus
parents:
diff changeset
   358
    ].
claus
parents:
diff changeset
   359
claus
parents:
diff changeset
   360
    "
claus
parents:
diff changeset
   361
    Class Variables
claus
parents:
diff changeset
   362
    "
claus
parents:
diff changeset
   363
    (something == #definition) ifTrue:[
53
claus
parents: 48
diff changeset
   364
	"add handling for classes here ..."        
68
5f7ac0b5c903 uff - version methods changed to return stings
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
   365
	"/ self addHistoryToHistoryMethodOf:changedObject.
41
claus
parents:
diff changeset
   366
    ].
claus
parents:
diff changeset
   367
claus
parents:
diff changeset
   368
    "this is a sub item of #definition"    
claus
parents:
diff changeset
   369
    (something == #classVariables) ifTrue:[
claus
parents:
diff changeset
   370
	"
claus
parents:
diff changeset
   371
	Transcript showCr: 'classVariables changed'.
claus
parents:
diff changeset
   372
	"
46
claus
parents: 43
diff changeset
   373
" das geht noch nicht, weil in someArgument nicht die Klasse steht die das betrifft"
68
5f7ac0b5c903 uff - version methods changed to return stings
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
   374
	self addHistoryToHistoryMethodOf:changedObject.
53
claus
parents: 48
diff changeset
   375
	^ self
41
claus
parents:
diff changeset
   376
    ].    
claus
parents:
diff changeset
   377
claus
parents:
diff changeset
   378
    "
claus
parents:
diff changeset
   379
    New Class creation
claus
parents:
diff changeset
   380
    "
claus
parents:
diff changeset
   381
    ((changedObject == Smalltalk)and:[ (something == #newClass)]) ifTrue:[
claus
parents:
diff changeset
   382
	" self in die Dependents eintragen damit die notification bei den Methoden kommt."
claus
parents:
diff changeset
   383
	someArgument addDependent: self.
claus
parents:
diff changeset
   384
	someArgument history: (self addHistoryTo:String new).  "append historyString for new class"
claus
parents:
diff changeset
   385
    ].
claus
parents:
diff changeset
   386
claus
parents:
diff changeset
   387
    "
claus
parents:
diff changeset
   388
    Instance Handling
claus
parents:
diff changeset
   389
    "
claus
parents:
diff changeset
   390
    changedObject isBehavior ifTrue:[
claus
parents:
diff changeset
   391
	something = #methodDictionary ifTrue:[
claus
parents:
diff changeset
   392
	    "SourceString der Methode holen"
claus
parents:
diff changeset
   393
	    sourceCode := changedObject sourceCodeAt: someArgument.
claus
parents:
diff changeset
   394
	    sourceCode isNil ifTrue:[
claus
parents:
diff changeset
   395
		"method has been deleted"
43
claus
parents: 42
diff changeset
   396
"/                Transcript showCr: 'method has been deleted'.
41
claus
parents:
diff changeset
   397
	    ] ifFalse:[
claus
parents:
diff changeset
   398
		aMethod := changedObject compiledMethodAt: someArgument.
82
e306d7662ae8 oops - history line was only added to class methods
Claus Gittinger <cg@exept.de>
parents: 80
diff changeset
   399
		(changedObject isMeta not
e306d7662ae8 oops - history line was only added to class methods
Claus Gittinger <cg@exept.de>
parents: 80
diff changeset
   400
		or:[aMethod category ~= 'documentation']) ifTrue:[
e306d7662ae8 oops - history line was only added to class methods
Claus Gittinger <cg@exept.de>
parents: 80
diff changeset
   401
		    sourceCode := self addHistoryTo:sourceCode.
e306d7662ae8 oops - history line was only added to class methods
Claus Gittinger <cg@exept.de>
parents: 80
diff changeset
   402
		    aMethod source: sourceCode.
43
claus
parents: 42
diff changeset
   403
"/                Transcript showCr: 'history updated / added'.
80
3c1fb4187d73 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 79
diff changeset
   404
		]
41
claus
parents:
diff changeset
   405
	    ].
claus
parents:
diff changeset
   406
	    ^self
claus
parents:
diff changeset
   407
	]. 
claus
parents:
diff changeset
   408
claus
parents:
diff changeset
   409
	something == #comment ifTrue:[
claus
parents:
diff changeset
   410
	    "in someArgument steht jetzt der alte kommentar"
53
claus
parents: 48
diff changeset
   411
	    ^ self.
41
claus
parents:
diff changeset
   412
	] ifFalse:[
claus
parents:
diff changeset
   413
	    "it is a class definition"
43
claus
parents: 42
diff changeset
   414
"/            Transcript show: 'Class definition: ', changedObject printString;cr.
68
5f7ac0b5c903 uff - version methods changed to return stings
Claus Gittinger <cg@exept.de>
parents: 53
diff changeset
   415
	    self addHistoryToHistoryMethodOf:changedObject.
41
claus
parents:
diff changeset
   416
	].
claus
parents:
diff changeset
   417
    ].
claus
parents:
diff changeset
   418
claus
parents:
diff changeset
   419
    ^self
claus
parents:
diff changeset
   420
43
claus
parents: 42
diff changeset
   421
    "Modified: 27.8.1995 / 02:14:43 / claus"
41
claus
parents:
diff changeset
   422
! !
claus
parents:
diff changeset
   423
claus
parents:
diff changeset
   424
HistoryManager initialize!