Class.st
author claus
Mon, 21 Nov 1994 17:38:50 +0100
changeset 205 9a8a48263a09
parent 199 d3c10cc4adb6
child 213 3b56a17534fd
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
     3
	       All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
ClassDescription subclass:#Class
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    14
       instanceVariableNames:'classvars comment subclasses classFilename package history'
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    15
       classVariableNames:'UpdatingChanges FileOutErrorSignal'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       category:'Kernel-Classes'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
Class comment:'
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
    21
COPYRIGHT (c) 1989 by Claus Gittinger
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    22
	      All Rights Reserved
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    23
205
9a8a48263a09 *** empty log message ***
claus
parents: 199
diff changeset
    24
$Header: /cvs/stx/stx/libbasic/Class.st,v 1.24 1994-11-21 16:38:50 claus Exp $
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    25
'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    27
!Class class methodsFor:'documentation'!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    28
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    29
copyright
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    30
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    31
 COPYRIGHT (c) 1989 by Claus Gittinger
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    32
	       All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    33
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    34
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    35
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    36
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    37
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    38
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    39
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    40
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    41
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    42
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    43
version
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    44
"
205
9a8a48263a09 *** empty log message ***
claus
parents: 199
diff changeset
    45
$Header: /cvs/stx/stx/libbasic/Class.st,v 1.24 1994-11-21 16:38:50 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    46
"
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    47
!
81dacba7a63a *** empty log message ***
claus
parents: 85
diff changeset
    48
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    49
documentation
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    50
"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    51
    Class adds more functionality to classes; minimum stuff has already
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    52
    been defined in Behavior and ClassDescription; this adds naming, categories etc.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    53
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    54
    Also change management and recompilation is defined here (since the superclasses
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    55
    do not have enough symbolic information to support compilation).
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    56
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    57
    For production code, the stc compiler is planned to (optionally) generate classes 
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    58
    as subclasses of Behavior - to excludes all name, source info etc., 
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    59
    however, normally all classes are subclasses of Class.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    60
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    61
    Instance variables:
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    62
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    63
	classvars       <String>        the names of the class variables
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    64
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    65
	comment         <String>        the classes comment; either a string,
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    66
					a number specifying the offset in classFilename, or nil
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    67
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    68
	subclasses      <Collection>    cached collection of subclasses
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    69
					(currently unused - but will be soon)
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    70
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    71
	classFilename   <String>        the file (or nil) where the classes
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    72
					sources are found 
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    73
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    74
	package         <Symbol>        the package, in which the class was defined
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    75
					(not currently used)
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    76
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    77
	history         <any>           a place for a history string (not currently used)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    78
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    79
    Class variables:
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    80
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    81
	UpdatingChanges <Boolean>       true if the changes-file shall be updated
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    82
					(except during startup and when filing in, this flag
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    83
					 is usually true)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    84
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    85
	FileOutErrorSignal              raised when an error occurs during fileOut
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
    86
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    87
    WARNING: layout known by compiler and runtime system
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    88
"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    89
! !
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    90
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
!Class class methodsFor:'initialization'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    92
a27a279701f8 Initial revision
claus
parents:
diff changeset
    93
initialize
28
4606b818d646 *** empty log message ***
claus
parents: 22
diff changeset
    94
    "the classvariable 'UpdatingChanges' controls if changes are put
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    95
     into the changes-file; normally this variable is set to true, but
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    96
     (for example) during fileIn or when changes are applied, it is set to false
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    97
     to avoid putting too much junk into the changes-file."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    98
     
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
    99
    UpdatingChanges := true.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   100
    FileOutErrorSignal isNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   101
	Object initialize.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   102
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   103
	FileOutErrorSignal := Object errorSignal newSignalMayProceed:false.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   104
	FileOutErrorSignal nameClass:self message:#fileOutErrorSignal.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   105
	FileOutErrorSignal notifierString:'error during fileOut'.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   106
    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   107
! !
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   108
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   109
!Class class methodsFor:'signal access'!
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   110
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   111
fileOutErrorSignal
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   112
    "return the signal raised when an error occurs while fileing out.
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   113
     This is signalled to allow browsers some user feed back in case
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   114
     a fileout fails (for example due to disk-full errors)"
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   115
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   116
    ^ FileOutErrorSignal
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   117
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   118
a27a279701f8 Initial revision
claus
parents:
diff changeset
   119
!Class class methodsFor:'creating new classes'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   120
a27a279701f8 Initial revision
claus
parents:
diff changeset
   121
new
a27a279701f8 Initial revision
claus
parents:
diff changeset
   122
    "creates and returs a new class"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   123
a27a279701f8 Initial revision
claus
parents:
diff changeset
   124
    |newClass|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
    newClass := super new.
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   127
"/    newClass setComment:(self comment) category:(self category).
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   128
    ^ newClass
a27a279701f8 Initial revision
claus
parents:
diff changeset
   129
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   130
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   131
!Class class methodsFor:'enumeration '!
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   132
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   133
allClassesInCategory:aCategory do:aBlock
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   134
    "evaluate aBlock for all classes in aCategory;
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   135
     no specific order is defined."
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   136
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   137
    Smalltalk allBehaviorsDo:[:aClass |
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   138
	aClass isMeta ifFalse:[
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   139
	    (aClass category = aCategory) ifTrue:[
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   140
		aBlock value:aClass
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   141
	    ]
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   142
	].
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   143
    ]
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   144
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   145
    "
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   146
     Class allClassesInCategory:'Kernel-Classes' 
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   147
			     do:[:class |Transcript showCr:class name]
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   148
    "
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   149
!
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   150
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   151
allClassesInCategory:aCategory inOrderDo:aBlock
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   152
    "evaluate aBlock for all classes in aCategory;
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   153
     superclasses come first - then subclasses."
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   154
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   155
    |classes|
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   156
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   157
    classes := OrderedCollection new.
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   158
    Smalltalk allBehaviorsDo:[:aClass |
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   159
	aClass isMeta ifFalse:[
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   160
	    (aClass category = aCategory) ifTrue:[
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   161
		classes add:aClass
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   162
	    ]
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   163
	]
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   164
    ].
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   165
    classes topologicalSort:[:a :b | b isSubclassOf:a].
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   166
    classes do:aBlock
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   167
! !
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
   168
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   169
!Class methodsFor:'subclass creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   170
37
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   171
subclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   172
    "create a new class as a subclass of an existing class (the receiver).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   173
     The subclass will have indexed variables if the receiving-class has."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   174
a27a279701f8 Initial revision
claus
parents:
diff changeset
   175
    self isVariable ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   176
	^ self class
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   177
	    name:t
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   178
	    inEnvironment:Smalltalk
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   179
	    subclassOf:self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   180
	    instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   181
	    variable:false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   182
	    words:true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   183
	    pointers:true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   184
	    classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   185
	    poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   186
	    category:cat
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   187
	    comment:nil
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   188
	    changed:false
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   189
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   190
    self isBytes ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   191
	^ self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   192
	    variableByteSubclass:t
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   193
	    instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   194
	    classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   195
	    poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   196
	    category:cat
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   197
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   198
    self isLongs ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   199
	^ self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   200
	    variableLongSubclass:t
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   201
	    instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   202
	    classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   203
	    poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   204
	    category:cat
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   205
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   206
    self isFloats ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   207
	^ self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   208
	    variableFloatSubclass:t
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   209
	    instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   210
	    classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   211
	    poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   212
	    category:cat
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   213
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   214
    self isDoubles ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   215
	^ self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   216
	    variableDoubleSubclass:t
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   217
	    instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   218
	    classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   219
	    poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   220
	    category:cat
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   221
    ].
2
claus
parents: 1
diff changeset
   222
    self isWords ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   223
	^ self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   224
	    variableWordSubclass:t
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   225
	    instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   226
	    classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   227
	    poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   228
	    category:cat
2
claus
parents: 1
diff changeset
   229
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   230
    ^ self
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   231
	variableSubclass:t
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   232
	instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   233
	classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   234
	poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   235
	category:cat
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   236
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   237
37
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   238
variableSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   239
    "create a new class as a subclass of an existing class (the receiver) 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   240
     in which the subclass has indexable pointer variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   241
a27a279701f8 Initial revision
claus
parents:
diff changeset
   242
    self isVariable ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   243
	self isPointers ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   244
	    ^ self error:
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   245
		'cannot make a variable pointer subclass of a variable non-pointer class'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   246
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   247
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   248
a27a279701f8 Initial revision
claus
parents:
diff changeset
   249
    ^ self class
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   250
	name:t
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   251
	inEnvironment:Smalltalk
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   252
	subclassOf:self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   253
	instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   254
	variable:true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   255
	words:false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   256
	pointers:true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   257
	classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   258
	poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   259
	category:cat
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   260
	comment:nil
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   261
	changed:false
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   262
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   263
37
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   264
variableByteSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   265
    "create a new class as a subclass of an existing class (the receiver) 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   266
     in which the subclass has indexable byte-sized nonpointer variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   267
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
    self isVariable ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   269
	self isBytes ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   270
	    ^ self error:
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   271
		'cannot make a variable byte subclass of a variable non-byte class'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   272
	].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   273
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   274
a27a279701f8 Initial revision
claus
parents:
diff changeset
   275
    ^ self class
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   276
	name:t
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   277
	inEnvironment:Smalltalk
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   278
	subclassOf:self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   279
	instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   280
	variable:true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   281
	words:false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   282
	pointers:false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   283
	classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   284
	poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   285
	category:cat
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   286
	comment:nil
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   287
	changed:false
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   288
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   289
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   290
variableWordSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   291
    "create a new class as a subclass of an existing class (the receiver) 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   292
     in which the subclass has indexable word-sized nonpointer variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   293
a27a279701f8 Initial revision
claus
parents:
diff changeset
   294
    self isVariable ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   295
	self isWords ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   296
	    ^ self error:
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   297
		'cannot make a variable word subclass of a variable non-word class'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   298
	].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   299
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   300
a27a279701f8 Initial revision
claus
parents:
diff changeset
   301
    ^ self class
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   302
	name:t
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   303
	inEnvironment:Smalltalk
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   304
	subclassOf:self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   305
	instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   306
	variable:true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   307
	words:true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   308
	pointers:false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   309
	classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   310
	poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   311
	category:cat
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   312
	comment:nil
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   313
	changed:false
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   314
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   315
37
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   316
variableLongSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   317
    "create a new class as a subclass of an existing class (the receiver) 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   318
     in which the subclass has indexable long-sized nonpointer variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   319
a27a279701f8 Initial revision
claus
parents:
diff changeset
   320
    self isVariable ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   321
	self isLongs ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   322
	    ^ self error:
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   323
		'cannot make a variable long subclass of a variable non-long class'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   324
	].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   325
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   326
a27a279701f8 Initial revision
claus
parents:
diff changeset
   327
    ^ self class
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   328
	name:t
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   329
	inEnvironment:Smalltalk
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   330
	subclassOf:self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   331
	instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   332
	variable:#long 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   333
	words:false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   334
	pointers:false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   335
	classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   336
	poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   337
	category:cat
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   338
	comment:nil
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   339
	changed:false
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   340
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   341
37
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   342
variableFloatSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   343
a27a279701f8 Initial revision
claus
parents:
diff changeset
   344
    "create a new class as a subclass of an existing class (the receiver) 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   345
     in which the subclass has indexable float-sized nonpointer variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   346
a27a279701f8 Initial revision
claus
parents:
diff changeset
   347
    self isVariable ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   348
	self isFloats ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   349
	    ^ self error:
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   350
		'cannot make a variable float subclass of a variable non-float class'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   351
	].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   352
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   353
a27a279701f8 Initial revision
claus
parents:
diff changeset
   354
    ^ self class
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   355
	name:t
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   356
	inEnvironment:Smalltalk
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   357
	subclassOf:self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   358
	instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   359
	variable:#float 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   360
	words:false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   361
	pointers:false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   362
	classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   363
	poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   364
	category:cat
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   365
	comment:nil
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   366
	changed:false
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   367
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   368
37
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   369
variableDoubleSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s category:cat
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   370
a27a279701f8 Initial revision
claus
parents:
diff changeset
   371
    "create a new class as a subclass of an existing class (the receiver) 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   372
     in which the subclass has indexable double-sized nonpointer variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   373
a27a279701f8 Initial revision
claus
parents:
diff changeset
   374
    self isVariable ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   375
	self isDoubles ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   376
	    ^ self error:
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   377
		'cannot make a variable double subclass of a variable non-double class'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   378
	].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   379
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   380
a27a279701f8 Initial revision
claus
parents:
diff changeset
   381
    ^ self class
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   382
	name:t
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   383
	inEnvironment:Smalltalk
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   384
	subclassOf:self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   385
	instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   386
	variable:#double 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   387
	words:false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   388
	pointers:false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   389
	classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   390
	poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   391
	category:cat
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   392
	comment:nil
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   393
	changed:false
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   394
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   395
a27a279701f8 Initial revision
claus
parents:
diff changeset
   396
!Class methodsFor:'ST/V subclass creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   397
37
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   398
subclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   399
    "this method allows fileIn of ST/V classes 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   400
     (which seem to have no category)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   401
a27a279701f8 Initial revision
claus
parents:
diff changeset
   402
    ^ self subclass:t 
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   403
	   instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   404
	   classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   405
	   poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   406
	   category:'ST/V classes'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   407
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   408
37
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   409
variableByteSubclass:t classVariableNames:d poolDictionaries:s
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   410
    "this method allows fileIn of ST/V variable byte classes 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   411
     (which seem to have no category and no instvars)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   412
a27a279701f8 Initial revision
claus
parents:
diff changeset
   413
    ^ self variableByteSubclass:t 
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   414
	   instanceVariableNames:''
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   415
	   classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   416
	   poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   417
	   category:'ST/V classes'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   418
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   419
37
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   420
variableSubclass:t instanceVariableNames:f classVariableNames:d poolDictionaries:s
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
   421
    "this method allows fileIn of ST/V variable pointer classes 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   422
     (which seem to have no category)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   423
a27a279701f8 Initial revision
claus
parents:
diff changeset
   424
    ^ self variableSubclass:t 
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   425
	   instanceVariableNames:f
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   426
	   classVariableNames:d
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   427
	   poolDictionaries:s
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   428
	   category:'ST/V classes'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   429
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   430
a27a279701f8 Initial revision
claus
parents:
diff changeset
   431
!Class methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   432
a27a279701f8 Initial revision
claus
parents:
diff changeset
   433
classVariableString
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   434
    "return a string of the class variables names.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   435
     Only names of class variables defined in this class are in the
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   436
     returned string."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   437
a27a279701f8 Initial revision
claus
parents:
diff changeset
   438
    classvars isNil ifTrue:[^ ''].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   439
    ^ classvars
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   440
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   441
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   442
     Object classVariableString 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   443
     Float classVariableString  
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   444
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   445
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   446
a27a279701f8 Initial revision
claus
parents:
diff changeset
   447
classVarNames
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   448
    "return a collection of the class variable name-strings.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   449
     Only names of class variables defined in this class are included
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   450
     in the returned collection - use allClassVarNames, to get all known names."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   451
10
claus
parents: 5
diff changeset
   452
    classvars isNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   453
	^ OrderedCollection new
10
claus
parents: 5
diff changeset
   454
    ].
claus
parents: 5
diff changeset
   455
    ^ classvars asCollectionOfWords
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   456
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   457
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   458
     Object classVarNames 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   459
     Float classVarNames
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   460
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   461
!
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   462
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   463
classVarAt:aSymbol
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   464
    "return the value of a class variable.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   465
     Currently, this returns nil if there is no such classvar -
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   466
     this may change."
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   467
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   468
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   469
     this hides the (current) implementation of classVariables
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   470
     from the outside world. Currently, classvars are stored in
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   471
     the Smalltalk dictionary with a funny name, since there are
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   472
     no classPools yet.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   473
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   474
    ^ Smalltalk at:(self name , ':' , aSymbol) asSymbol
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   475
!
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   476
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   477
classVarAt:aSymbol put:something
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   478
    "store something in a classvariable.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   479
     Currently this creates a global with a funny name if no such
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   480
     classVar exists - this may change."
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   481
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   482
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   483
     this hides the (current) implementation of classVariables
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   484
     from the outside world. Currently, classvars are stored in
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   485
     the Smalltalk dictionary with a funny name, since there are
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   486
     no classPools yet.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   487
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   488
    Smalltalk at:(self name , ':' , aSymbol) asSymbol put:something.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   489
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   490
a27a279701f8 Initial revision
claus
parents:
diff changeset
   491
allClassVarNames
a27a279701f8 Initial revision
claus
parents:
diff changeset
   492
    "return a collection of all the class variable name-strings
a27a279701f8 Initial revision
claus
parents:
diff changeset
   493
     this includes all superclass-class variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   494
a27a279701f8 Initial revision
claus
parents:
diff changeset
   495
    ^ self addAllClassVarNamesTo:(OrderedCollection new)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   496
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   497
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   498
     Float allClassVarNames
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   499
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   500
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   501
a27a279701f8 Initial revision
claus
parents:
diff changeset
   502
comment
a27a279701f8 Initial revision
claus
parents:
diff changeset
   503
    "return the comment (aString) of the class"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   504
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   505
    |stream string|
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   506
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   507
    "the comment is either a string, or an integer specifying the
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   508
     position within the classes sourcefile ...
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   509
    "
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   510
    comment isNumber ifTrue:[
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   511
	classFilename notNil ifTrue:[
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   512
	    stream := Smalltalk systemFileStreamFor:('source/' , classFilename).
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   513
	    stream notNil ifTrue:[
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   514
		stream position:comment.
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   515
		string := String readFrom:stream.
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   516
		stream close.
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   517
		^ string
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   518
	    ]
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   519
	]
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   520
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   521
    ^ comment
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   522
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   523
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   524
     Object comment 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   525
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   526
!          
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   527
a27a279701f8 Initial revision
claus
parents:
diff changeset
   528
setComment:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   529
    "set the comment of the class to be the argument, aString;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   530
     do NOT create a change record"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   531
a27a279701f8 Initial revision
claus
parents:
diff changeset
   532
    comment := aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   533
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   534
a27a279701f8 Initial revision
claus
parents:
diff changeset
   535
comment:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   536
    "set the comment of the class to be the argument, aString;
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   537
     create a change record and notify dependents."
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   538
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   539
    |oldComment|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   540
10
claus
parents: 5
diff changeset
   541
    comment ~= aString ifTrue:[
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   542
	oldComment := self comment.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   543
	comment := aString.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   544
	self changed:#comment with:oldComment.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   545
	self addChangeRecordForClassComment:self.
10
claus
parents: 5
diff changeset
   546
    ]
claus
parents: 5
diff changeset
   547
!
claus
parents: 5
diff changeset
   548
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   549
classFilename
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   550
    "return the name of the file from which the class was compiled.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   551
     This is currently NOT used."
10
claus
parents: 5
diff changeset
   552
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   553
    ^ classFilename
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   554
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   555
a27a279701f8 Initial revision
claus
parents:
diff changeset
   556
definition
a27a279701f8 Initial revision
claus
parents:
diff changeset
   557
    "return an expression-string to define myself"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   558
a27a279701f8 Initial revision
claus
parents:
diff changeset
   559
    |s|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   560
a27a279701f8 Initial revision
claus
parents:
diff changeset
   561
    s := WriteStream on:(String new).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   562
    self fileOutDefinitionOn:s.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   563
    ^ s contents
a27a279701f8 Initial revision
claus
parents:
diff changeset
   564
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   565
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   566
     Object definition 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   567
     Point definition  
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   568
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   569
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   570
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   571
source
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   572
    "return the classes full source code"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   573
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   574
    |code aStream|
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   575
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   576
" this is too slow for big classes ...
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   577
    code := String new:1000.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   578
    aStream := WriteStream on:code.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   579
    self fileOutOn:aStream
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   580
"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   581
    aStream := FileStream newFileNamed:'__temp'.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   582
    aStream isNil ifTrue:[
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   583
	self notify:'cannot create temporary file.'.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   584
	^ nil
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   585
    ].
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   586
    self fileOutOn:aStream.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   587
    aStream close.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   588
    aStream := FileStream oldFileNamed:'__temp'.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   589
    aStream isNil ifTrue:[
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   590
	self notify:'oops - cannot reopen temp file'.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   591
	^ nil
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   592
    ].
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   593
    code := aStream contents.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   594
    aStream close.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   595
    OperatingSystem removeFile:'__temp'.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   596
    ^ code
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   597
!
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   598
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   599
sharedPools
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   600
    "ST/X does not (currently) support pools"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   601
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   602
    ^ #()
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   603
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   604
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   605
setComment:com category:categoryStringOrSymbol
a27a279701f8 Initial revision
claus
parents:
diff changeset
   606
    "set the comment and category of the class;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   607
     do NOT create a change record"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   608
a27a279701f8 Initial revision
claus
parents:
diff changeset
   609
    comment := com.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   610
    category := categoryStringOrSymbol asSymbol
a27a279701f8 Initial revision
claus
parents:
diff changeset
   611
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   612
a27a279701f8 Initial revision
claus
parents:
diff changeset
   613
setClassVariableString:aString
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   614
    "set the classes classvarnames string. 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   615
     This is a dangerous (low level) operation, since the 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   616
     classvariables are not really created or updated. Also,
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   617
     NO change record is written."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   618
a27a279701f8 Initial revision
claus
parents:
diff changeset
   619
    classvars := aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   620
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   621
a27a279701f8 Initial revision
claus
parents:
diff changeset
   622
classVariableString:aString
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   623
    "set the classes classvarnames string; 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   624
     Initialize new class variables with nil, clear and remove old ones. 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   625
     No change record is written and no classes are recompiled."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   626
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   627
    |prevVarNames varNames any|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   628
a27a279701f8 Initial revision
claus
parents:
diff changeset
   629
    "ignore for metaclasses except the one"
10
claus
parents: 5
diff changeset
   630
    (self isMeta) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   631
	(self == Metaclass) ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   632
	    ^ self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   633
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   634
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   635
    (classvars = aString) ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   636
	prevVarNames := self classVarNames.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   637
	classvars := aString.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   638
	varNames := self classVarNames.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   639
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   640
	"new ones get initialized to nil;
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   641
	 - old ones are nilled and removed from Smalltalk"
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   642
	any := false.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   643
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   644
	varNames do:[:aName |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   645
	    (prevVarNames includes:aName) ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   646
		"a new one"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   647
		self classVarAt:aName put:nil.
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   648
		any := true.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   649
	    ] ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   650
		prevVarNames remove:aName
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   651
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   652
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   653
	"left overs are gone"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   654
	prevVarNames do:[:aName |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   655
	    self classVarAt:aName put:nil.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   656
	    Smalltalk removeKey:(self name , ':' , aName) asSymbol.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   657
	].
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   658
	any ifTrue:[
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   659
	    Smalltalk changed:#classVariables
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   660
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   661
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   662
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   663
a27a279701f8 Initial revision
claus
parents:
diff changeset
   664
addClassVarName:aString
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   665
    "add a class variable if not already there and initialize it with nil.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   666
     Also write a change record and notify dependents.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   667
     BUG: Currently, no recompilation is done - this will change."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   668
a27a279701f8 Initial revision
claus
parents:
diff changeset
   669
    (self classVarNames includes:aString) ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   670
	self classVariableString:(self classVariableString , ' ' , aString).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   671
	self addChangeRecordForClass:self.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   672
	self changed:#definition.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   673
    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   674
!
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   675
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   676
removeClassVarName:aString
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   677
    "remove a class variable if not already there.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   678
     Also write a change record and notify dependents.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   679
     BUG: Currently, no recompilation is done - this will change."
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   680
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   681
    |names newNames|
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   682
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   683
    names := self classVarNames.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   684
    (names includes:aString) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   685
	newNames := ''.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   686
	names do:[:nm | nm ~= aString ifTrue:[newNames := newNames , nm , ' ']].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   687
	self classVariableString:newNames withoutSpaces.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   688
	self addChangeRecordForClass:self.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   689
	self changed:#definition.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   690
    ]
85
claus
parents: 77
diff changeset
   691
!
claus
parents: 77
diff changeset
   692
claus
parents: 77
diff changeset
   693
renameCategory:oldCategory to:newCategory
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   694
    "rename a category (changes category of those methods).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   695
     Append a change record and notifies dependents."
85
claus
parents: 77
diff changeset
   696
claus
parents: 77
diff changeset
   697
    |any|
claus
parents: 77
diff changeset
   698
claus
parents: 77
diff changeset
   699
    any := false.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   700
    methodArray do:[:aMethod |
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   701
	aMethod category = oldCategory ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   702
	    aMethod category:newCategory.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   703
	    any := true.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   704
	]
85
claus
parents: 77
diff changeset
   705
    ].
claus
parents: 77
diff changeset
   706
    any ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   707
	self addChangeRecordForRenameCategory:oldCategory to:newCategory.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   708
	self changed:#methodCategory.
85
claus
parents: 77
diff changeset
   709
    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   710
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   711
a27a279701f8 Initial revision
claus
parents:
diff changeset
   712
!Class methodsFor:'adding/removing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   713
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   714
addSelector:newSelector withMethod:newMethod
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   715
    "add the method given by 2nd argument under the selector given by
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   716
     1st argument to the methodDictionary. 
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   717
     Append a change record to the changes file and tell dependents."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   718
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   719
    (super addSelector:newSelector withMethod:newMethod) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   720
	self addChangeRecordForMethod:newMethod
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   721
    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   722
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   723
a27a279701f8 Initial revision
claus
parents:
diff changeset
   724
removeSelector:aSelector
a27a279701f8 Initial revision
claus
parents:
diff changeset
   725
    "remove the selector, aSelector and its associated method 
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   726
     from the methodDictionary.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   727
     Append a change record to the changes file and tell dependents."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   728
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   729
    (super removeSelector:aSelector) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   730
	self addChangeRecordForRemoveSelector:aSelector.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   731
	self changed:#methodDictionary with:aSelector.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   732
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   733
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   734
a27a279701f8 Initial revision
claus
parents:
diff changeset
   735
!Class methodsFor:'changes management'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   736
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   737
withoutUpdatingChangesDo:aBlock
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   738
    "turn off change file update while evaluating aBlock.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   739
     This method makes sure, that the update-flag is correctly restored
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   740
     in case of an abort or other error."
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   741
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   742
    |prev|
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   743
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   744
    prev := UpdatingChanges.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   745
    UpdatingChanges := false.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   746
    aBlock valueNowOrOnUnwindDo:[
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   747
	prev ifTrue:[UpdatingChanges := true]
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   748
    ].
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   749
!
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   750
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   751
updateChanges:aBoolean
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   752
    "turn on/off changes management. Return the prior value of the flag."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   753
a27a279701f8 Initial revision
claus
parents:
diff changeset
   754
    |prev|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   755
28
4606b818d646 *** empty log message ***
claus
parents: 22
diff changeset
   756
    prev := UpdatingChanges.
4606b818d646 *** empty log message ***
claus
parents: 22
diff changeset
   757
    UpdatingChanges := aBoolean.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   758
    ^ prev
a27a279701f8 Initial revision
claus
parents:
diff changeset
   759
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   760
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   761
updatingChanges
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   762
    "return true if changes are recorded"
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   763
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   764
    ^ UpdatingChanges
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   765
!
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   766
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   767
changesStream
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   768
    "return a Stream for the changes file - or nil if no update is wanted"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   769
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   770
    |aStream fileName|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   771
28
4606b818d646 *** empty log message ***
claus
parents: 22
diff changeset
   772
    UpdatingChanges ifTrue:[
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   773
	fileName := ObjectMemory nameForChanges.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   774
	aStream := FileStream oldFileNamed:fileName.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   775
	aStream isNil ifTrue:[
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   776
	    aStream := FileStream newFileNamed:fileName.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   777
	    aStream isNil ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   778
		self warning:'cannot create/update changes file'.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   779
		^ nil
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   780
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   781
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   782
	aStream setToEnd
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   783
    ].
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   784
    ^ aStream
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   785
!
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   786
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   787
sourcesStream
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   788
    "return a stream for the sources file"
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   789
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   790
    |aStream fileName|
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   791
205
9a8a48263a09 *** empty log message ***
claus
parents: 199
diff changeset
   792
    fileName := ObjectMemory nameForSources.
9a8a48263a09 *** empty log message ***
claus
parents: 199
diff changeset
   793
    aStream := FileStream oldFileNamed:fileName.
9a8a48263a09 *** empty log message ***
claus
parents: 199
diff changeset
   794
    aStream isNil ifTrue:[
9a8a48263a09 *** empty log message ***
claus
parents: 199
diff changeset
   795
	aStream := FileStream newFileNamed:fileName.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   796
	aStream isNil ifTrue:[
205
9a8a48263a09 *** empty log message ***
claus
parents: 199
diff changeset
   797
	    Transcript showCr:'cannot update sources file'.
9a8a48263a09 *** empty log message ***
claus
parents: 199
diff changeset
   798
	    ^ nil
9a8a48263a09 *** empty log message ***
claus
parents: 199
diff changeset
   799
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   800
    ].
205
9a8a48263a09 *** empty log message ***
claus
parents: 199
diff changeset
   801
    aStream setToEnd.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   802
    ^ aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   803
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   804
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   805
writingChangeDo:aBlock
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   806
    "common helper to write a change record.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   807
     Opens the changefile and executes aBlock passing the stream
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   808
     as argument. WriteErrors are cought and will lead to a warning.
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   809
     The changefile is not kept open, to force the change to go to disk
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   810
     as soon as possible - thus, in case of a crash, no changes should
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
   811
     be lost due to buffering."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   812
139
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
   813
    |aStream|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   814
a27a279701f8 Initial revision
claus
parents:
diff changeset
   815
    aStream := self changesStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   816
    aStream notNil ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   817
	FileStream writeErrorSignal handle:[:ex |
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   818
	    self warning:('could not update the changes-file\\' , ex errorString) withCRs.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   819
	    ex return
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   820
	] do:[
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   821
	    aBlock value:aStream.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   822
	    aStream cr.
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   823
	].
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   824
	aStream close
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   825
    ]
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   826
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   827
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   828
addChangeRecordForMethod:aMethod to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   829
    "append a method-change-record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   830
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   831
    self fileOutMethod:aMethod on:aStream.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   832
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   833
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   834
addChangeRecordForRemoveSelector:aSelector to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   835
    "append a method-remove-record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   836
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   837
    self printClassNameOn:aStream.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   838
    aStream nextPutAll:(' removeSelector:#' , aSelector).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   839
    aStream nextPut:(aStream class chunkSeparator).
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   840
!
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   841
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   842
addChangeRecordForMethodCategory:aMethod category:newCategory to:aStream
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   843
    "append a methodCategory-change-record to aStream"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   844
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   845
    |selector|
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   846
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   847
    selector := aMethod selector.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   848
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   849
    aStream nextPutAll:'('.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   850
    self printClassNameOn:aStream.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   851
    aStream nextPutAll:(' compiledMethodAt:' , selector storeString).
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   852
    aStream nextPutAll:(') category:' , newCategory storeString).
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   853
    aStream nextPut:(aStream class chunkSeparator).
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   854
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   855
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   856
addChangeRecordForClass:aClass to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   857
    "append a class-definition-record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   858
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   859
    aClass fileOutDefinitionOn:aStream.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   860
    aStream nextPut:(aStream class chunkSeparator).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   861
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   862
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   863
addChangeRecordForClassInstvars:aClass to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   864
    "append a class-instvars-record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   865
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   866
    aClass fileOutClassInstVarDefinitionOn:aStream.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   867
    aStream nextPut:(aStream class chunkSeparator).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   868
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   869
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   870
addChangeRecordForClassComment:aClass to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   871
    "append a class-comment-record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   872
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   873
    aClass fileOutCommentOn:aStream.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   874
    aStream nextPut:(aStream class chunkSeparator).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   875
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   876
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   877
addChangeRecordForClassRename:oldName to:newName to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   878
    "append a class-rename-record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   879
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   880
    aStream nextPutAll:('Smalltalk renameClass:' , oldName , ' to:''' , newName , '''').
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   881
    aStream nextPut:(aStream class chunkSeparator).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   882
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   883
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   884
addChangeRecordForClassRemove:oldName to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   885
    "append a class-remove-record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   886
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   887
    aStream nextPutAll:('Smalltalk removeClass:' , oldName).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   888
    aStream nextPut:(aStream class chunkSeparator).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   889
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   890
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   891
addChangeRecordForRenameCategory:oldCategory to:newCategory to:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   892
    "append a category-rename record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   893
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   894
    self printClassNameOn:aStream.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   895
    aStream nextPutAll:(' renameCategory:' , oldCategory storeString).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   896
    aStream nextPutAll:(' to:' , newCategory storeString).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   897
    aStream nextPut:(aStream class chunkSeparator).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   898
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   899
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   900
addChangeRecordForChangeCategoryTo:aStream
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   901
    "append a category change record to aStream"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   902
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   903
    self printClassNameOn:aStream.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   904
    aStream nextPutAll:(' category:' , category storeString).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   905
    aStream nextPut:(aStream class chunkSeparator).
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   906
!
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   907
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   908
addInfoRecord:aMessage to:aStream
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   909
    "append an info-record (snapshot, class fileOut etc.) to aStream"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   910
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   911
    aStream nextPutAll:('''---- ' , aMessage , ' ',
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   912
			Date today printString , ' ' ,
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   913
			Time now printString ,
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   914
			' ----''').
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   915
    aStream nextPut:(aStream class chunkSeparator).
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   916
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   917
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   918
addChangeRecordForSnapshot:aFileName to:aStream
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   919
    "add a snapshot-record to aStream"
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   920
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   921
    self addInfoRecord:('snapshot ' , aFileName) to:aStream
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   922
!
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   923
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   924
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   925
addChangeRecordForMethod:aMethod
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   926
    "add a method-change-record to the changes file"
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   927
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   928
    self writingChangeDo:[:aStream |
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   929
	self addChangeRecordForMethod:aMethod to:aStream.
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   930
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   931
	"this test allows a smalltalk without Projects/ChangeSets"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   932
	Project notNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   933
	    Project addMethodChange:aMethod in:self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
   934
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   935
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   936
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   937
a27a279701f8 Initial revision
claus
parents:
diff changeset
   938
addChangeRecordForRemoveSelector:aSelector
a27a279701f8 Initial revision
claus
parents:
diff changeset
   939
    "add a method-remove-record to the changes file"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   940
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   941
    self writingChangeDo:[:aStream |
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   942
	self addChangeRecordForRemoveSelector:aSelector to:aStream
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   943
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   944
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   945
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   946
addChangeRecordForMethodCategory:aMethod category:aString
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   947
    "add a methodCategory-change-record to the changes file"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   948
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   949
    self writingChangeDo:[:aStream |
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   950
	self addChangeRecordForMethodCategory:aMethod category:aString to:aStream.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   951
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   952
	"this test allows a smalltalk without Projects/ChangeSets"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   953
	Project notNil ifTrue:[
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   954
	    Project addMethodCategoryChange:aMethod category:aString in:self
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   955
	]
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   956
    ]
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   957
!
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
   958
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   959
addChangeRecordForClass:aClass
a27a279701f8 Initial revision
claus
parents:
diff changeset
   960
    "add a class-definition-record to the changes file"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   961
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   962
    self writingChangeDo:[:aStream |
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   963
	self addChangeRecordForClass:aClass to:aStream
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   964
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   965
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   966
2
claus
parents: 1
diff changeset
   967
addChangeRecordForClassInstvars:aClass
claus
parents: 1
diff changeset
   968
    "add a class-instvars-record to the changes file"
claus
parents: 1
diff changeset
   969
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   970
    self writingChangeDo:[:aStream |
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   971
	self addChangeRecordForClassInstvars:aClass to:aStream
2
claus
parents: 1
diff changeset
   972
    ]
claus
parents: 1
diff changeset
   973
!
claus
parents: 1
diff changeset
   974
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   975
addChangeRecordForClassComment:aClass
a27a279701f8 Initial revision
claus
parents:
diff changeset
   976
    "add a class-comment-record to the changes file"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   977
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   978
    self writingChangeDo:[:aStream |
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   979
	self addChangeRecordForClassComment:aClass to:aStream
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   980
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   981
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   982
10
claus
parents: 5
diff changeset
   983
addChangeRecordForClassRename:oldName to:newName
claus
parents: 5
diff changeset
   984
    "add a class-rename-record to the changes file"
claus
parents: 5
diff changeset
   985
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   986
    self writingChangeDo:[:aStream |
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   987
	self addChangeRecordForClassRename:oldName to:newName to:aStream
10
claus
parents: 5
diff changeset
   988
    ]
claus
parents: 5
diff changeset
   989
!
claus
parents: 5
diff changeset
   990
claus
parents: 5
diff changeset
   991
addChangeRecordForClassRemove:oldName
claus
parents: 5
diff changeset
   992
    "add a class-remove-record to the changes file"
claus
parents: 5
diff changeset
   993
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   994
    self writingChangeDo:[:aStream |
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
   995
	self addChangeRecordForClassRemove:oldName to:aStream
10
claus
parents: 5
diff changeset
   996
    ]
claus
parents: 5
diff changeset
   997
!
claus
parents: 5
diff changeset
   998
85
claus
parents: 77
diff changeset
   999
addChangeRecordForRenameCategory:oldCategory to:newCategory
claus
parents: 77
diff changeset
  1000
    "add a category-rename record to the changes file"
claus
parents: 77
diff changeset
  1001
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1002
    self writingChangeDo:[:aStream |
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1003
	self addChangeRecordForRenameCategory:oldCategory to:newCategory to:aStream.
85
claus
parents: 77
diff changeset
  1004
    ]
claus
parents: 77
diff changeset
  1005
!
claus
parents: 77
diff changeset
  1006
claus
parents: 77
diff changeset
  1007
addChangeRecordForChangeCategory
claus
parents: 77
diff changeset
  1008
    "add a category change record to the changes file"
claus
parents: 77
diff changeset
  1009
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1010
    self writingChangeDo:[:aStream |
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1011
	self addChangeRecordForChangeCategoryTo:aStream.
85
claus
parents: 77
diff changeset
  1012
    ]
claus
parents: 77
diff changeset
  1013
!
claus
parents: 77
diff changeset
  1014
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1015
addInfoRecord:aMessage
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1016
    "add an info-record (snapshot, class fileOut etc.) to the changes file"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1017
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1018
    self writingChangeDo:[:aStream |
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1019
	self addInfoRecord:aMessage to:aStream 
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1020
    ]
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1021
!
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1022
22
847106305963 *** empty log message ***
claus
parents: 10
diff changeset
  1023
addChangeRecordForSnapshot:aFileName
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1024
    "add a snapshot-record to the changes file"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1025
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1026
    self addInfoRecord:('snapshot ' , aFileName) 
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1027
!
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1028
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1029
addChangeRecordForClassFileOut:aClass
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1030
    "append a class-was-filedOut-record to the changes file"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1031
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1032
    self addInfoRecord:('fileOut ' , aClass name) 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1033
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1034
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1035
!Class methodsFor:'compiling'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1036
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1037
compile:code
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1038
    "compile code, aString for this class; if sucessful update method
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1039
     dictionary."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1040
10
claus
parents: 5
diff changeset
  1041
    self compiler compile:code forClass:self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1042
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1043
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1044
compile:code notifying:requestor
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1045
    "compile code, aString for this class; on any error, notify
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1046
     requestor, anObject with the error reason"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1047
10
claus
parents: 5
diff changeset
  1048
    self compiler compile:code forClass:self notifying:requestor
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1049
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1050
2
claus
parents: 1
diff changeset
  1051
recompileMethodsAccessingAny:setOfNames
claus
parents: 1
diff changeset
  1052
    "recompile all methods accessing a variable from setOfNames"
claus
parents: 1
diff changeset
  1053
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1054
    self recompileMethodsAccessingAny:setOfNames orSuper:false 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1055
!
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1056
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1057
recompileMethodsAccessingAny:setOfNames orSuper:superBoolean
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1058
    "recompile all methods accessing a variable from setOfNames,
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1059
     or super (if superBoolean is true)"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1060
2
claus
parents: 1
diff changeset
  1061
    |p|
claus
parents: 1
diff changeset
  1062
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1063
    selectorArray do:[:aSelector |
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1064
	|m|
2
claus
parents: 1
diff changeset
  1065
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1066
	m := self compiledMethodAt:aSelector.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1067
	p := Parser parseMethod:(m source) in:self.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1068
	(p isNil 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1069
	 or:[(p usedVars notNil and:[p usedVars includesAny:setOfNames])
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1070
	 or:[superBoolean and:[p usesSuper]]]) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1071
	    self recompile:aSelector
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1072
	]
2
claus
parents: 1
diff changeset
  1073
    ]
claus
parents: 1
diff changeset
  1074
!
claus
parents: 1
diff changeset
  1075
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1076
recompile:aSelector
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1077
    "recompile the method associated with the argument, aSelector;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1078
     used when a superclass changes instances and we have to recompile
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1079
     subclasses"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1080
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1081
    |cat code|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1082
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1083
    Class withoutUpdatingChangesDo:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1084
	cat := (self compiledMethodAt:aSelector) category.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1085
	code := self sourceCodeAt:aSelector.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1086
	self compiler compile:code forClass:self inCategory:cat
2
claus
parents: 1
diff changeset
  1087
    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1088
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1089
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1090
recompile
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1091
    "recompile all methods
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1092
     used when a class changes instances and therefore all methods
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1093
     have to be recompiled"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1094
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1095
    selectorArray do:[:aSelector |
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1096
	self recompile:aSelector
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1097
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1098
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1099
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1100
recompileAll
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1101
    "recompile this class and all subclasses"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1102
2
claus
parents: 1
diff changeset
  1103
    |classes|
claus
parents: 1
diff changeset
  1104
claus
parents: 1
diff changeset
  1105
    classes := self subclasses.
claus
parents: 1
diff changeset
  1106
    self recompile.
claus
parents: 1
diff changeset
  1107
    classes do:[:aClass |
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1108
	aClass recompileAll
2
claus
parents: 1
diff changeset
  1109
    ]
claus
parents: 1
diff changeset
  1110
!
claus
parents: 1
diff changeset
  1111
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1112
recompileInvalidatedMethods:trap
2
claus
parents: 1
diff changeset
  1113
    "recompile all invalidated methods"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1114
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1115
    |trapCode trapByteCode|
2
claus
parents: 1
diff changeset
  1116
claus
parents: 1
diff changeset
  1117
    trapCode := trap code.
claus
parents: 1
diff changeset
  1118
    trapByteCode := trap byteCode.
claus
parents: 1
diff changeset
  1119
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1120
    selectorArray do:[:aSelector |
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1121
	|m|
2
claus
parents: 1
diff changeset
  1122
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1123
	m := self compiledMethodAt:aSelector.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1124
	((m code == trapCode) and:[m byteCode == trapByteCode]) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1125
	    self recompile:aSelector
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1126
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1127
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1128
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1129
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1130
!Class methodsFor:'queries'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1131
2
claus
parents: 1
diff changeset
  1132
isClass
10
claus
parents: 5
diff changeset
  1133
    "return true, if the receiver is some kind of class 
claus
parents: 5
diff changeset
  1134
     (a real class, not just behavior);
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1135
     true is returned here - the method is redefined from Object.
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1136
     See also Behavior>>isBehavior."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1137
2
claus
parents: 1
diff changeset
  1138
    ^ true
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1139
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1140
    "
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1141
     Point isClass  
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1142
     1 isClass      
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1143
     Behavior new isBehavior  
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1144
     Behavior new isClass       
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1145
     Class new isBehavior    
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1146
     Class new isClass
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1147
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1148
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1149
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1150
categories
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1151
    "Return a Collection of all method-category strings known in class.
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1152
     The returned collection is not sorted by any order."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1153
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1154
    |newList cat|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1155
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1156
    newList := OrderedCollection new.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1157
    methodArray do:[:aMethod |
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1158
	cat := aMethod category.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1159
	newList indexOf:cat ifAbsent:[newList add:cat]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1160
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1161
    ^ newList
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1162
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1163
    "
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1164
     Point categories  
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1165
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1166
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1167
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1168
allCategories
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1169
    "Return a Collection of all method-category strings known in class
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1170
     and all superclasses. The returned collection is not sorted by any order."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1171
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1172
    |coll|
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1173
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1174
    coll := OrderedCollection new.
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1175
    self addAllCategoriesTo:coll.
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1176
    ^ coll
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1177
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1178
    "
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1179
     Point categories  
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1180
     Point allCategories 
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1181
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1182
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1183
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1184
!Class methodsFor:'private'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1185
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1186
addAllClassVarNamesTo:aCollection
10
claus
parents: 5
diff changeset
  1187
    "helper - add the name-strings of the class variables and of the class-vars
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1188
     of all superclasses to the argument, aCollection. Return aCollection"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1189
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1190
    (superclass notNil) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1191
	superclass addAllClassVarNamesTo:aCollection
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1192
    ].
10
claus
parents: 5
diff changeset
  1193
    classvars notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1194
	aCollection addAll:(classvars asCollectionOfWords).
10
claus
parents: 5
diff changeset
  1195
    ].
claus
parents: 5
diff changeset
  1196
    ^ aCollection
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1197
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1198
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1199
addCategoriesTo:aCollection
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1200
    "helper - add categories to the argument, aCollection"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1201
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1202
    methodArray do:[:aMethod |
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1203
	|cat|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1204
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1205
	cat := aMethod category.
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1206
	(aCollection includes:cat) ifFalse:[
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1207
	    aCollection add:cat
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1208
	]
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1209
    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1210
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1211
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1212
addAllCategoriesTo:aCollection
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1213
    "helper - add categories and all superclasses categories
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1214
     to the argument, aCollection"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1215
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1216
    (superclass notNil) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1217
	superclass addAllCategoriesTo:aCollection
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1218
    ].
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1219
    self addCategoriesTo:aCollection
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1220
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1221
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1222
!Class methodsFor:'fileIn interface'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1223
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1224
methodsFor:aCategory
10
claus
parents: 5
diff changeset
  1225
    "return a ClassCategoryReader to read in and compile methods for me.
claus
parents: 5
diff changeset
  1226
     This one actually creates the ClassReader when code is filed-in."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1227
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1228
    ^ ClassCategoryReader class:self category:aCategory
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1229
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1230
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1231
publicMethodsFor:aCategory
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1232
    "this method allows fileIn of ENVY methods 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1233
     (although ST/X currently does NOT support method visibility).
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1234
     Returns a ClassCategoryReader to read in and compile methods for me."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1235
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1236
    ^ self methodsFor:aCategory
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1237
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1238
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1239
privateMethodsFor:aCategory
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1240
    "this method allows fileIn of ENVY methods 
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1241
     (although ST/X currently does NOT really enforce method visibility yet).
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1242
     Returns a ClassCategoryReader to read in and compile methods for me."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1243
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1244
    ^ (self methodsFor:aCategory) privateProtocol
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1245
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1246
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1247
protectedMethodsFor:aCategory
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1248
    "this method allows fileIn of ENVY methods 
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1249
     (although ST/X currently does NOT really enforce method visibility yet).
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1250
     Returns a ClassCategoryReader to read in and compile methods for me."
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1251
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1252
    ^ (self methodsFor:aCategory) protectedProtocol
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1253
!
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1254
137
a8e039dcb872 double exclamation marks
claus
parents: 104
diff changeset
  1255
ignoredMethodsFor:aCategory
a8e039dcb872 double exclamation marks
claus
parents: 104
diff changeset
  1256
    "this is a speciality of ST/X - it allows quick commenting of methods
a8e039dcb872 double exclamation marks
claus
parents: 104
diff changeset
  1257
     from a source-file by replacing the 'methodsFor:' by 'ignoredMethodsFor'.
a8e039dcb872 double exclamation marks
claus
parents: 104
diff changeset
  1258
     Returns a ClassCategoryReader to read in and skip methods."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1259
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1260
    ^ ClassCategoryReader skippingChunks
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1261
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1262
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1263
methods
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1264
    "this method allows fileIn of ST/V methods -
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1265
     return a ClassCategoryReader to read in and compile methods for me."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1266
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1267
    ^ ClassCategoryReader class:self category:'ST/V methods'
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1268
!
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1269
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1270
primitiveDefinitions
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1271
    "this method allows fileIn of classes with primitive code
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1272
     outside of methods - it returns a CCReader which skips the next chunks"
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1273
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1274
    ^ ClassCategoryReader skippingChunks
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1275
!
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1276
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1277
primitiveVariables
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1278
    "this method allows fileIn of classes with primitive code
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1279
     outside of methods - it returns a CCReader which skips the next chunks"
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1280
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1281
    ^ ClassCategoryReader skippingChunks
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1282
!
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1283
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1284
primitiveFunctions
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1285
    "this method allows fileIn of classes with primitive code
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1286
     outside of methods - it returns a CCReader which skips the next chunks"
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1287
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1288
    ^ ClassCategoryReader skippingChunks
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1289
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1290
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1291
!Class methodsFor:'c function interfacing'!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1292
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1293
cInterfaceFunction:selector calling:cFunctionNameString args:argTypeArray returning:returnType
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1294
    "create an interface to an existing (i.e. already linked in) c function.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1295
     The function can be called by sending selector to the receiver class.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1296
     The c-function has the name cFunctionNameString, and expects parameters as specified in
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1297
     argTypeArray. The functions return value has a type as specified by returnType.
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1298
     WARNING: 
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1299
	this interface is EXPERIMENTAL - it may change or even be removed."
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1300
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1301
    StubGenerator isNil ifTrue:[
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1302
	^ self error:'this system does not support dynamic C Interface functions'.
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1303
    ].
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1304
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1305
    StubGenerator 
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1306
	createStubFor:selector 
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1307
	calling:cFunctionNameString 
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1308
	args:argTypeArray 
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1309
	returning:returnType
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1310
	in:self                          
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1311
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1312
    "
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1313
     Object subclass:#CInterface
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1314
	    instanceVariableNames:''
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1315
	    classVariableNames:''
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1316
	    poolDictionaries:''
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1317
	    category:'Examples'.
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1318
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1319
     CInterface cInterfaceFunction:#printfOn:format:withFloat: 
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1320
			   calling:'fprintf' 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1321
			      args:#(ExternalStream String Float) 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1322
			 returning:#SmallInteger.
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1323
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1324
     CInterface printfOn:Stdout format:'this is a float: %g' withFloat:(Float pi). Stdout cr  
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1325
    "
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1326
! !
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1327
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1328
!Class methodsFor:'fileOut'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1329
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1330
fileOutCommentOn:aStream
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1331
    "append an expression on aStream, which defines my comment"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1332
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1333
    |comment|
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1334
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1335
    aStream nextPutAll:name.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1336
    aStream nextPutAll:' comment:'.
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1337
    (comment := self comment) isNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1338
	aStream nextPutAll:''''''
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1339
    ] ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1340
	aStream nextPutAll:(comment storeString)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1341
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1342
    aStream cr
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1343
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1344
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1345
fileOutDefinitionOn:aStream
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1346
    "append an expression on aStream, which defines myself."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1347
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1348
    |isVar line|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1349
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1350
    "take care of nil-superclass"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1351
    superclass isNil ifTrue:[
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1352
"/      previous versions of stc were not able to compile nil-subclasses;
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1353
"/      after 2.10, it can ...
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1354
"/        line := 'Object "nil"'.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1355
	line := 'nil'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1356
    ] ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1357
	line := (superclass name)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1358
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1359
    superclass isNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1360
	isVar := self isVariable
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1361
    ] ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1362
	"I cant remember what this is for ?"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1363
	isVar := (self isVariable and:[superclass isVariable not])
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1364
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1365
    isVar ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1366
	self isBytes ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1367
	    line := line , ' variableByteSubclass:#'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1368
	] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1369
	    self isWords ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1370
		line := line , ' variableWordSubclass:#'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1371
	    ] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1372
		self isLongs ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1373
		    line := line , ' variableLongSubclass:#'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1374
		] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1375
		    self isFloats ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1376
			line := line , ' variableFloatSubclass:#'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1377
		    ] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1378
			self isDoubles ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1379
			    line := line , ' variableDoubleSubclass:#'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1380
			] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1381
			    line := line , ' variableSubclass:#'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1382
			]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1383
		    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1384
		]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1385
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1386
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1387
    ] ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1388
	line := line , ' subclass:#'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1389
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1390
    line := line , name.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1391
    aStream nextPutAll:line.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1392
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1393
    aStream crTab. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1394
    aStream nextPutAll:' instanceVariableNames:'''.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1395
    self printInstVarNamesOn:aStream indent:16.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1396
    aStream nextPutAll:''''.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1397
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1398
    aStream crTab.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1399
    aStream nextPutAll:' classVariableNames:'''.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1400
    self printClassVarNamesOn:aStream indent:16.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1401
    aStream nextPutAll:''''.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1402
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1403
    aStream crTab.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1404
    aStream nextPutAll:' poolDictionaries:'''''.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1405
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1406
    aStream crTab.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1407
    aStream nextPutAll:' category:'.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1408
    category isNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1409
	aStream nextPutAll:''''''
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1410
    ] ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1411
	aStream nextPutAll:(category asString storeString)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1412
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1413
    aStream cr
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1414
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1415
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1416
fileOutClassInstVarDefinitionOn:aStream
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1417
    "append an expression to define my classInstanceVariables on aStream"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1418
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1419
    aStream nextPutAll:(name , ' class instanceVariableNames:''').
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1420
    self class printInstVarNamesOn:aStream indent:8.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1421
    aStream nextPutAll:''''
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1422
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1423
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1424
fileOutCategory:aCategory on:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1425
    "file out all methods belonging to aCategory, aString onto aStream"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1426
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1427
    |nMethods count sep source|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1428
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1429
    methodArray notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1430
	nMethods := 0.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1431
	methodArray do:[:aMethod |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1432
	    (aCategory = aMethod category) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1433
		nMethods := nMethods + 1
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1434
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1435
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1436
	sep := aStream class chunkSeparator.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1437
	(nMethods ~~ 0) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1438
	    aStream nextPut:sep.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1439
	    self printClassNameOn:aStream.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1440
	    aStream nextPutAll:' methodsFor:'''.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1441
	    aCategory notNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1442
		aStream nextPutAll:aCategory
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1443
	    ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1444
	    aStream nextPut:$'. aStream nextPut:sep. aStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1445
	    aStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1446
	    count := 1.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1447
	    methodArray do:[:aMethod |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1448
		(aCategory = aMethod category) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1449
		    source := aMethod source.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1450
		    source isNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1451
			FileOutErrorSignal raiseRequestWith:'no source for method'
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1452
		    ] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1453
			aStream nextChunkPut:(aMethod source).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1454
		    ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1455
		    (count ~~ nMethods) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1456
			aStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1457
			aStream cr
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1458
		    ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1459
		    count := count + 1
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1460
		]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1461
	    ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1462
	    aStream space.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1463
	    aStream nextPut:sep.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1464
	    aStream cr
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1465
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1466
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1467
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1468
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1469
fileOutMethod:aMethod on:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1470
    "file out the method, aMethod onto aStream"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1471
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1472
    |cat sep source|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1473
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1474
    methodArray notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1475
	sep := aStream class chunkSeparator.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1476
	aStream nextPut:sep.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1477
	self printClassNameOn:aStream.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1478
	aStream nextPutAll:' methodsFor:'''.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1479
	cat := aMethod category.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1480
	cat notNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1481
	    aStream nextPutAll:cat
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1482
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1483
	aStream nextPut:$'.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1484
	aStream nextPut:sep.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1485
	aStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1486
	aStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1487
	source := aMethod source.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1488
	source isNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1489
	    FileOutErrorSignal 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1490
		raiseRequestWith:self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1491
		errorString:('no source for method: ' ,
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1492
			     self name , '>>' ,
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1493
			     (self selectorForMethod:aMethod))
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1494
	] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1495
	    aStream nextChunkPut:(aMethod source).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1496
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1497
	aStream space.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1498
	aStream nextPut:sep.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1499
	aStream cr
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1500
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1501
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1502
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1503
fileOutOn:aStream
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1504
    "file out my definition and all methods onto aStream"
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1505
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1506
    |collectionOfCategories copyrightText sep comment|
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1507
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1508
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1509
     if there is a copyright method, add a copyright
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1510
     at the beginning, taking the string from the
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1511
     copyright method.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1512
     We cannot do this unconditionally - that would lead to my copyrights
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1513
     being put on your code ;-).
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1514
     On the other hand: I want every file created by myself to have the
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1515
     copyright string at the beginning be preserved .... even if the
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1516
     code was edited in the browser and filedOut.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1517
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1518
    (self class selectorArray includes:#copyright) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1519
	"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1520
	 get the copyright methods source,
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1521
	 and insert at beginning.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1522
	"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1523
	copyrightText := (self class compiledMethodAt:#copyright) source.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1524
	copyrightText isNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1525
	    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1526
	     no source available - trigger an error
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1527
	    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1528
	    self error:'no source for class ' , name , ' available. Cannot fileOut'.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1529
	    ^ self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1530
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1531
	copyrightText := copyrightText asCollectionOfLines.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1532
	copyrightText := copyrightText copyFrom:2 to:(copyrightText size).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1533
	copyrightText do:[:line | aStream nextPutAll:line. aStream cr.].
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1534
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1535
137
a8e039dcb872 double exclamation marks
claus
parents: 104
diff changeset
  1536
    sep := aStream class chunkSeparator.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1537
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1538
     first, a timestamp
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1539
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1540
    aStream nextPutAll:(Smalltalk timeStamp).
137
a8e039dcb872 double exclamation marks
claus
parents: 104
diff changeset
  1541
    aStream nextPut:sep. 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1542
    aStream cr.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1543
    aStream cr.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1544
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1545
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1546
     then the definition
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1547
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1548
    self fileOutDefinitionOn:aStream.
137
a8e039dcb872 double exclamation marks
claus
parents: 104
diff changeset
  1549
    aStream nextPut:sep. 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1550
    aStream cr.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1551
    aStream cr.
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1552
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1553
     optional classInstanceVariables
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1554
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1555
    self class instanceVariableString isBlank ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1556
	self fileOutClassInstVarDefinitionOn:aStream.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1557
	aStream nextPut:sep. 
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1558
	aStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1559
	aStream cr
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1560
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1561
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1562
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1563
     a comment - if any
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1564
    "
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1565
    (comment := self comment) notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1566
	aStream nextPutAll:name.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1567
	aStream nextPutAll:' comment:'.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1568
	aStream nextPutAll:(comment storeString).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1569
	aStream nextPut:sep.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1570
	aStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1571
	aStream cr
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1572
    ].
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1573
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1574
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1575
     methods from all categories in metaclass
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1576
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1577
    collectionOfCategories := self class categories.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1578
    collectionOfCategories notNil ifTrue:[
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1579
	"
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1580
	 documentation first (if any)
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1581
	"
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1582
	(collectionOfCategories includes:'documentation') ifTrue:[
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1583
	    self class fileOutCategory:'documentation' on:aStream.
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1584
	    aStream cr.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1585
	].
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1586
	"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1587
	 initialization next (if any)
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1588
	"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1589
	(collectionOfCategories includes:'initialization') ifTrue:[
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1590
	    self class fileOutCategory:'initialization' on:aStream.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1591
	    aStream cr.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1592
	].
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1593
	"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1594
	 instance creation next (if any)
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1595
	"
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1596
	(collectionOfCategories includes:'instance creation') ifTrue:[
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1597
	    self class fileOutCategory:'instance creation ' on:aStream.
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1598
	    aStream cr.
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1599
	].
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1600
	collectionOfCategories do:[:aCategory |
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1601
	    ((aCategory ~= 'documentation')
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1602
	    and:[(aCategory ~= 'initialization')
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1603
	    and:[aCategory ~= 'instance creation']]) ifTrue:[
168
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1604
		self class fileOutCategory:aCategory on:aStream.
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1605
		aStream cr
3c7266ecf04c new comments, support private & protected code
claus
parents: 155
diff changeset
  1606
	    ]
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1607
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1608
    ].
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1609
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1610
     methods from all categories in myself
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1611
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1612
    collectionOfCategories := self categories.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1613
    collectionOfCategories notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1614
	collectionOfCategories do:[:aCategory |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1615
	    self fileOutCategory:aCategory on:aStream.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1616
	    aStream cr
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1617
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1618
    ].
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1619
    "
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1620
     optionally an initialize message
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  1621
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1622
    (self class implements:#initialize) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1623
	aStream nextPutAll:(name , ' initialize').
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1624
	aStream nextPut:sep.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1625
	aStream cr
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1626
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1627
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1628
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1629
fileOutCategory:aCategory
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1630
    "create a file 'class-category.st' consisting of all methods in aCategory.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1631
     If the current project is not nil, create the file in the projects
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1632
     directory."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1633
139
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  1634
    |aStream fileName|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1635
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1636
    fileName := name , '-' , aCategory , '.st'.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1637
    fileName replaceAll:(Character space) by:$_.
139
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  1638
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  1639
    "
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  1640
     this test allows a smalltalk to be built without Projects/ChangeSets
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  1641
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1642
    Project notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1643
	fileName := Project currentProjectDirectory , fileName.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1644
    ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1645
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1646
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1647
     if file exists, save original in a .sav file
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1648
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1649
    fileName asFilename exists ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1650
	fileName asFilename copyTo:(fileName , '.sav')
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1651
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1652
    aStream := FileStream newFileNamed:fileName.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1653
    aStream isNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1654
	^ FileOutErrorSignal raiseRequestWith:fileName
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1655
				  errorString:('cannot create file:', fileName)
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1656
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1657
    self fileOutCategory:aCategory on:aStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1658
    aStream close
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1659
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1660
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1661
fileOutMethod:aMethod
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1662
    "create a file 'class-method.st' consisting of the method, aMethod.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1663
     If the current project is not nil, create the file in the projects
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1664
     directory."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1665
139
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  1666
    |aStream fileName selector|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1667
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1668
    selector := self selectorForMethod:aMethod.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1669
    selector notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1670
	fileName := name , '-' , selector, '.st'.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1671
	fileName replaceAll:$: by:$_.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1672
	"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1673
	 this test allows a smalltalk to be built without Projects/ChangeSets
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1674
	"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1675
	Project notNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1676
	    fileName := Project currentProjectDirectory , fileName.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1677
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1678
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1679
	"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1680
	 if file exists, save original in a .sav file
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1681
	"
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1682
	fileName asFilename exists ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1683
	    fileName asFilename copyTo:(fileName , '.sav')
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1684
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1685
	aStream := FileStream newFileNamed:fileName.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1686
	aStream isNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1687
	    ^ FileOutErrorSignal raiseRequestWith:fileName
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1688
				      errorString:('cannot create file:', fileName)
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1689
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1690
	self fileOutMethod:aMethod on:aStream.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1691
	aStream close
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1692
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1693
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1694
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1695
fileOut
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1696
    "create a file 'class.st' consisting of all methods in myself.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1697
     If the current project is not nil, create the file in the projects
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1698
     directory. Care is taken, to not clobber any existing file in
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1699
     case of errors (for example: disk full). Also, since the classes
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1700
     methods need a valid sourcefile, the current sourceFile cannot be rewritten,
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1701
     but must be kept around until the fileOut is finished."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1702
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1703
    |aStream baseName dirName fileName newFileName needRename|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1704
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1705
    baseName := (Smalltalk fileNameForClass:self name).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1706
    fileName := baseName , '.st'.
139
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  1707
    "
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  1708
     this test allows a smalltalk to be built without Projects/ChangeSets
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  1709
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1710
    Project notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1711
	dirName := Project currentProjectDirectory
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1712
    ] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1713
	dirName := ''
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1714
    ].
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1715
    fileName := dirName , fileName.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1716
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1717
     if file exists, copy the existing to a .sav-file,
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1718
     create the new file as XXX.new-file,
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1719
     and, if that worked rename afterwards ...
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1720
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1721
    fileName asFilename exists ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1722
	fileName asFilename copyTo:('/tmp/' , baseName , '.sav').
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1723
	newFileName := dirName , baseName , '.new'.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1724
	needRename := true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1725
    ] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1726
	newFileName := fileName.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1727
	needRename := false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1728
    ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1729
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1730
    aStream := FileStream newFileNamed:newFileName.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1731
    aStream isNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1732
	^ FileOutErrorSignal raiseRequestWith:newFileName
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1733
				  errorString:('cannot create file:', newFileName)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1734
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1735
    self fileOutOn:aStream.
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1736
    aStream close.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1737
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1738
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1739
     finally, replace the old-file
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1740
     be careful, if the old one is a symbolic link; in this case,
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1741
     we have to do a copy ...
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1742
    "
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1743
    needRename ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1744
	newFileName asFilename copyTo:fileName.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1745
	newFileName asFilename delete
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1746
    ].
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1747
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1748
    "
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1749
     add a change record; that way, administration is much easier,
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1750
     since we can see in that changeBrowser, which changes have 
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1751
     already found their way into a sourceFile and which must be
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1752
     applied again
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1753
    "
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1754
    self addChangeRecordForClassFileOut:self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1755
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1756
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1757
fileOutIn:aFileDirectory
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1758
    "create a file 'class.st' consisting of all methods in self in
139
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  1759
     directory aFileDirectory (ignoring any directory setting in
199
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1760
     the current porject). 
d3c10cc4adb6 more change records
claus
parents: 193
diff changeset
  1761
     This is not logged in that change file (should it be ?)."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1762
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1763
    |aStream fileName|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1764
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1765
    fileName := (Smalltalk fileNameForClass:self name) , '.st'.
139
19ccaf2031c8 project changeSet interface
claus
parents: 137
diff changeset
  1766
    aStream := FileStream newFileNamed:fileName in:aFileDirectory.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1767
    aStream isNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1768
	^ self error:('cannot create source file:', fileName)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1769
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1770
    self fileOutOn:aStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1771
    aStream close
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1772
! !
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1773
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1774
!Class methodsFor:'printOut'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1775
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1776
printClassNameOn:aStream
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1777
    "helper for fileOut - print my name if I am not a Metaclass;
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1778
     otherwise my name without -class followed by space-class"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1779
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1780
    self isMeta ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1781
	aStream nextPutAll:(name copyTo:(name size - 5)).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1782
	aStream nextPutAll:' class'
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1783
    ] ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1784
	name printOn:aStream
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1785
    ]
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1786
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1787
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1788
printNameArray:anArray on:aStream indent:indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1789
    "print an array of strings separated by spaces; when the stream
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1790
     defines a lineLength, break when this limit is reached; indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1791
     every line; used to printOut instanve variable names"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1792
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1793
    |thisName nextName arraySize lenMax pos mustBreak line spaces|
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1794
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1795
    arraySize := anArray size.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1796
    arraySize ~~ 0 ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1797
	pos := indent.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1798
	lenMax := aStream lineLength.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1799
	thisName := anArray at:1.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1800
	line := ''.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1801
	1 to:arraySize do:[:index |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1802
	    line := line , thisName.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1803
	    pos := pos + thisName size.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1804
	    (index == arraySize) ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1805
		nextName := anArray at:(index + 1).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1806
		mustBreak := false.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1807
		(lenMax > 0) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1808
		    ((pos + nextName size) > lenMax) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1809
			mustBreak := true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1810
		    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1811
		].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1812
		mustBreak ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1813
		    aStream nextPutAll:line.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1814
		    aStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1815
		    spaces isNil ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1816
			spaces := String new:indent
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1817
		    ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1818
		    line := spaces.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1819
		    pos := indent
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1820
		] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1821
		    line := line , ' '.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1822
		    pos := pos + 1
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1823
		].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1824
		thisName := nextName
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1825
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1826
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1827
	aStream nextPutAll:line
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1828
    ]
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1829
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1830
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1831
printClassVarNamesOn:aStream indent:indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1832
    "print the class variable names indented and breaking at line end"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1833
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1834
    self printNameArray:(self classVarNames) on:aStream indent:indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1835
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1836
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1837
printInstVarNamesOn:aStream indent:indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1838
    "print the instance variable names indented and breaking at line end"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1839
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1840
    self printNameArray:(self instVarNames) on:aStream indent:indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1841
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1842
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1843
printHierarchyOn:aStream
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1844
    "print my class hierarchy on aStream"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1845
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1846
    self printHierarchyAnswerIndentOn:aStream
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1847
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1848
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1849
printHierarchyAnswerIndentOn:aStream
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1850
    "print my class hierarchy on aStream - return indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1851
     recursively calls itself to print superclass and use returned indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1852
     for my description - used in the browser"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1853
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1854
    |indent|
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1855
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1856
    indent := 0.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1857
    (superclass notNil) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1858
	indent := (superclass printHierarchyAnswerIndentOn:aStream) + 2
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1859
    ].
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1860
    aStream spaces:indent.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1861
    aStream nextPutAll:name.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1862
    aStream nextPutAll:' ('.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1863
    self printInstVarNamesOn:aStream indent:(indent + name size + 2).
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1864
    aStream nextPutAll:')'.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1865
    aStream cr.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1866
    ^ indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1867
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1868
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1869
printFullHierarchyOn:aStream indent:indent
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1870
    "print myself and all subclasses on aStream.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1871
     recursively calls itself to print subclasses. 
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1872
     Can be used to print hierarchy on the printer."
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1873
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1874
    aStream spaces:indent.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1875
    aStream bold.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1876
    aStream nextPutAll:name.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1877
    aStream normal.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1878
    aStream nextPutAll:' ('.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1879
    self printInstVarNamesOn:aStream indent:(indent + name size + 2).
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1880
    aStream nextPutAll:')'.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1881
    aStream cr.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1882
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1883
    (self subclasses sort:[:a :b | a name < b name]) do:[:aSubclass |
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1884
	aSubclass printFullHierarchyOn:aStream indent:(indent + 2)
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1885
    ]
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1886
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1887
    "|printStream|
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1888
     printStream := Printer new.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1889
     Object printFullHierarchyOn:printStream indent:0.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1890
     printStream close"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1891
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1892
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1893
printOutDefinitionOn:aPrintStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1894
    "print out my definition"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1895
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1896
    |comment|
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1897
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1898
    aPrintStream nextPutAll:'class                '.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1899
    aPrintStream bold.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1900
    aPrintStream nextPutAll:name.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1901
    aPrintStream normal.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1902
    aPrintStream cr. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1903
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1904
    aPrintStream nextPutAll:'superclass           '.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1905
    superclass isNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1906
	aPrintStream nextPutAll:'Object'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1907
    ] ifFalse:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1908
	aPrintStream nextPutAll:(superclass name)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1909
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1910
    aPrintStream cr. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1911
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1912
    aPrintStream nextPutAll:'instance Variables   '.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1913
    self printInstVarNamesOn:aPrintStream indent:21.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1914
    aPrintStream cr. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1915
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1916
    aPrintStream nextPutAll:'class Variables      '.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1917
    self printClassVarNamesOn:aPrintStream indent:21.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1918
    aPrintStream cr.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1919
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1920
    category notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1921
	aPrintStream nextPutAll:'category             '.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1922
	aPrintStream nextPutAll:(category printString).
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1923
	aPrintStream cr
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1924
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1925
193
5f2ace36fc07 more comment changes
claus
parents: 168
diff changeset
  1926
    (comment := self comment) notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1927
	aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1928
	aPrintStream nextPutAll:'comment:'.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1929
	aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1930
	aPrintStream italic.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1931
	aPrintStream nextPutAll:comment.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1932
	aPrintStream normal.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1933
	aPrintStream cr
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1934
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1935
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1936
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1937
printOutSourceProtocol:aMethod on:aPrintStream
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1938
    "given the source in aString, print the methods message specification
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1939
     and any method comments - without source; used to generate documentation
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1940
     pages"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1941
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1942
    |text|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1943
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1944
    text := aMethod source asText.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1945
    (text size < 1) ifTrue:[^self].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1946
    aPrintStream bold.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1947
    aPrintStream nextPutAll:(text at:1).
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1948
    aPrintStream cr.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1949
    (text size >= 2) ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1950
	aPrintStream italic.
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1951
	aPrintStream spaces:((text at:2) indexOfNonSeparatorStartingAt:1).
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1952
	aPrintStream nextPutAll:aMethod comment.
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1953
	aPrintStream cr.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1954
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1955
    aPrintStream normal
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1956
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1957
    "
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1958
      Float printOutProtocolOn:Stdout 
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  1959
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1960
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1961
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1962
printOutSource:aString on:aPrintStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1963
    "print out a source-string; the message-specification is printed bold,
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1964
     comments are printed italic"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1965
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1966
    |text textIndex textSize line lineIndex lineSize inComment aCharacter|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1967
    text := aString asText.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1968
    aPrintStream bold.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1969
    aPrintStream nextPutAll:(text at:1).
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1970
    aPrintStream normal.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1971
    aPrintStream cr.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1972
    inComment := false.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1973
    textSize := text size.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1974
    textIndex := 2.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1975
    [textIndex <= textSize] whileTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1976
	line := text at:textIndex.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1977
	((line occurrencesOf:Character doubleQuote) == 0) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1978
	    aPrintStream nextPutAll:line
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1979
	] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1980
	    lineSize := line size.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1981
	    lineIndex := 1.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1982
	    [lineIndex <= lineSize] whileTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1983
		aCharacter := line at:lineIndex.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1984
		(aCharacter == Character doubleQuote) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1985
		    inComment ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1986
			aPrintStream normal.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1987
			aPrintStream nextPut:aCharacter.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1988
			inComment := false
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1989
		    ] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1990
			aPrintStream nextPut:aCharacter.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1991
			aPrintStream italic.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1992
			inComment := true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1993
		    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1994
		] ifFalse:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1995
		    aPrintStream nextPut:aCharacter
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1996
		].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1997
		lineIndex := lineIndex + 1
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1998
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  1999
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2000
	aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2001
	textIndex := textIndex + 1
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2002
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2003
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2004
    
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2005
printOutCategory:aCategory on:aPrintStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2006
    "print out all methods in aCategory on aPrintStream should be a PrintStream"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2007
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2008
    |any|
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2009
    methodArray notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2010
	any := false.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2011
	methodArray do:[:aMethod |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2012
	    (aCategory = aMethod category) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2013
		any := true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2014
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2015
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2016
	any ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2017
	     aPrintStream italic.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2018
	     aPrintStream nextPutAll:aCategory.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2019
	     aPrintStream normal.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2020
	     aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2021
	     aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2022
	     methodArray do:[:aMethod |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2023
		 (aCategory = aMethod category) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2024
		     self printOutSource:(aMethod source) on:aPrintStream.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2025
		     aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2026
		     aPrintStream cr
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2027
		 ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2028
	     ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2029
	     aPrintStream cr
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2030
	 ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2031
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2032
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2033
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2034
printOutOn:aPrintStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2035
    "print out all methods on aPrintStream which should be a printStream"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2036
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2037
    |collectionOfCategories|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2038
    self printOutDefinitionOn:aPrintStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2039
    aPrintStream cr.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2040
    collectionOfCategories := self class categories.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2041
    collectionOfCategories notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2042
	aPrintStream nextPutAll:'class protocol'.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2043
	aPrintStream cr. aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2044
	collectionOfCategories do:[:aCategory |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2045
	    self class printOutCategory:aCategory on:aPrintStream
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2046
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2047
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2048
    collectionOfCategories := self categories.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2049
    collectionOfCategories notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2050
	aPrintStream nextPutAll:'instance protocol'.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2051
	aPrintStream cr. aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2052
	collectionOfCategories do:[:aCategory |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2053
	    self printOutCategory:aCategory on:aPrintStream
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2054
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2055
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2056
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2057
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2058
printOutCategoryProtocol:aCategory on:aPrintStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2059
    |any|
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  2060
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
  2061
    methodArray notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2062
	any := false.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2063
	methodArray do:[:aMethod |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2064
	    (aCategory = aMethod category) ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2065
		any := true
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2066
	    ]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2067
	].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2068
	any ifTrue:[
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2069
	    aPrintStream italic.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2070
	    aPrintStream nextPutAll:aCategory.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2071
	    aPrintStream normal.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2072
	    aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2073
	    aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2074
	    methodArray do:[:aMethod |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2075
		(aCategory = aMethod category) ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 153
diff changeset
  2076
		    self printOutSourceProtocol:aMethod
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2077
					     on:aPrintStream.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2078
		    aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2079
		    aPrintStream cr
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2080
		]
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2081
	    ].
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2082
	    aPrintStream cr
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2083
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2084
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2085
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2086
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2087
printOutProtocolOn:aPrintStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2088
    |collectionOfCategories|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2089
    self printOutDefinitionOn:aPrintStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2090
    aPrintStream cr.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2091
    collectionOfCategories := self class categories.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2092
    collectionOfCategories notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2093
	aPrintStream nextPutAll:'class protocol'.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2094
	aPrintStream cr. aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2095
	collectionOfCategories do:[:aCategory |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2096
	    self class printOutCategoryProtocol:aCategory on:aPrintStream
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2097
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2098
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2099
    collectionOfCategories := self categories.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2100
    collectionOfCategories notNil ifTrue:[
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2101
	aPrintStream nextPutAll:'instance protocol'.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2102
	aPrintStream cr. aPrintStream cr.
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2103
	collectionOfCategories do:[:aCategory |
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2104
	    self printOutCategoryProtocol:aCategory on:aPrintStream
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2105
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2106
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2107
! !
2
claus
parents: 1
diff changeset
  2108
claus
parents: 1
diff changeset
  2109
!Class methodsFor: 'binary storage'!
claus
parents: 1
diff changeset
  2110
claus
parents: 1
diff changeset
  2111
addGlobalsTo: globalDictionary manager: manager
claus
parents: 1
diff changeset
  2112
"
claus
parents: 1
diff changeset
  2113
    classPool == nil ifFalse: [
153
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2114
	classPool associationsDo: [:assoc|
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2115
	    globalDictionary at: assoc put: self
22f4c4bcc93f *** empty log message ***
claus
parents: 139
diff changeset
  2116
	]
2
claus
parents: 1
diff changeset
  2117
    ]
claus
parents: 1
diff changeset
  2118
"
claus
parents: 1
diff changeset
  2119
!
claus
parents: 1
diff changeset
  2120
claus
parents: 1
diff changeset
  2121
storeBinaryDefinitionOf: anAssociation on: stream manager: manager
37
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
  2122
    "not usable at the moment - there are no classpools currently"
d9a302eaa3ef *** empty log message ***
claus
parents: 28
diff changeset
  2123
2
claus
parents: 1
diff changeset
  2124
    | string |
claus
parents: 1
diff changeset
  2125
claus
parents: 1
diff changeset
  2126
    string := self name, ' classPool at: ', anAssociation key storeString.
claus
parents: 1
diff changeset
  2127
    stream nextNumber: 2 put: string size.
claus
parents: 1
diff changeset
  2128
    string do: [:char| stream nextPut: char asciiValue]
claus
parents: 1
diff changeset
  2129
! !