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