ClassDescription.st
author Claus Gittinger <cg@exept.de>
Sat, 11 Nov 1995 15:28:26 +0100
changeset 528 a083413dfbe8
parent 459 744b144ae909
child 620 c7353f86a302
permissions -rw-r--r--
converted version methods from comment-only to returning-a-string
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1993 by Claus Gittinger
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
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
Behavior subclass:#ClassDescription
216
a8abff749575 *** empty log message ***
claus
parents: 200
diff changeset
    14
       instanceVariableNames:'name category instvars primitiveSpec signature'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:''
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
68
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
    20
!ClassDescription class methodsFor:'documentation'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    22
copyright
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    23
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    24
 COPYRIGHT (c) 1993 by Claus Gittinger
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
    25
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    26
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    27
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    28
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    30
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    31
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    32
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    33
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    34
!
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    35
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    36
version
528
a083413dfbe8 converted version methods from comment-only to returning-a-string
Claus Gittinger <cg@exept.de>
parents: 459
diff changeset
    37
    ^ '$Header: /cvs/stx/stx/libbasic/ClassDescription.st,v 1.20 1995-11-11 14:27:50 cg Exp $'
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    38
!
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    39
68
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
    40
documentation
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
    41
"
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
    42
    this class has been added for ST-80 compatibility only.
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
    43
    All class stuff used to be in Behavior and Class - but, to be
356
claus
parents: 328
diff changeset
    44
    able to file in some PD code, it became nescessary to add C'Description
claus
parents: 328
diff changeset
    45
    in between it.
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    46
    ClassDescription adds some descriptive information to the basic
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    47
    Behavior class.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    48
68
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
    49
    Instance variables:
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
    50
308
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
    51
	name            <String>        the classes name
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
    52
	category        <String>        the classes category
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
    53
	instvars        <String>        the names of the instance variables
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
    54
	primitiveSpec   <Array|nil>     describes primitiveIncludes, primitiveFunctions etc.
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
    55
	signature       <SmallInteger>  the classes signature (used to detect obsolete
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
    56
					or changed classes with binaryStorage)
68
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
    57
"
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
    58
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    59
356
claus
parents: 328
diff changeset
    60
!ClassDescription class methodsFor:'instance creation'!
claus
parents: 328
diff changeset
    61
claus
parents: 328
diff changeset
    62
new
claus
parents: 328
diff changeset
    63
    "creates and returns a new class.
claus
parents: 328
diff changeset
    64
     Redefined to give the new class at least some name info"
claus
parents: 328
diff changeset
    65
claus
parents: 328
diff changeset
    66
    |newClass|
claus
parents: 328
diff changeset
    67
claus
parents: 328
diff changeset
    68
    newClass := super new.
claus
parents: 328
diff changeset
    69
    newClass setName:('some' , self name).
claus
parents: 328
diff changeset
    70
    ^ newClass
claus
parents: 328
diff changeset
    71
! !
claus
parents: 328
diff changeset
    72
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    73
!ClassDescription methodsFor:'special accessing'!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    74
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    75
setName:aString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    76
    "set the classes name - be careful, it will be still
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    77
     in the Smalltalk dictionary - under another key.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    78
     This is NOT for general use - see renameTo:"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    79
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    80
    name := aString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    81
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    82
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    83
setInstanceVariableString:aString
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    84
    "set the classes instvarnames string - no recompilation
200
    85
     or updates are done and no changeList records are written.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    86
     This is NOT for general use."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    87
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    88
    instvars := aString.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    89
! !
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    90
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
!ClassDescription methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    92
a27a279701f8 Initial revision
claus
parents:
diff changeset
    93
instanceVariableString
a27a279701f8 Initial revision
claus
parents:
diff changeset
    94
    "return a string of the instance variable names"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    95
a27a279701f8 Initial revision
claus
parents:
diff changeset
    96
    instvars isNil ifTrue:[^ ''].
a27a279701f8 Initial revision
claus
parents:
diff changeset
    97
    ^ instvars
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    98
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    99
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   100
     Point instanceVariableString   
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   101
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
10
claus
parents: 3
diff changeset
   104
instVarNames
claus
parents: 3
diff changeset
   105
    "return a collection of the instance variable name-strings"
claus
parents: 3
diff changeset
   106
claus
parents: 3
diff changeset
   107
    instvars isNil ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   108
	^ OrderedCollection new
10
claus
parents: 3
diff changeset
   109
    ].
claus
parents: 3
diff changeset
   110
    ^ instvars asCollectionOfWords
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   111
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   112
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   113
     Point instVarNames  
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   114
    "
10
claus
parents: 3
diff changeset
   115
!
claus
parents: 3
diff changeset
   116
308
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   117
instanceVariableOffsets
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   118
    "returns a dictionary containing the instance variable index
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   119
     for each instVar name"
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   120
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   121
    |dict index|
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   122
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   123
    index := 0. dict := Dictionary new.
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   124
    self allInstVarNames do:[:nm | index := index + 1. dict at:nm put:index].
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   125
    ^ dict
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   126
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   127
    "
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   128
     Point instanceVariableOffsets 
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   129
     GraphicsContext instanceVariableOffsets 
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   130
    "
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   131
!
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   132
        
10
claus
parents: 3
diff changeset
   133
allInstVarNames
claus
parents: 3
diff changeset
   134
    "return a collection of all the instance variable name-strings
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   135
     this includes all superclass-instance variables.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   136
     Instvars of superclasses come first (i.e. the position matches
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   137
     the instVarAt:-index)."
10
claus
parents: 3
diff changeset
   138
claus
parents: 3
diff changeset
   139
    ^ self addAllInstVarNamesTo:(OrderedCollection new)
claus
parents: 3
diff changeset
   140
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   141
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   142
     Dictionary instVarNames       
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   143
     Dictionary allInstVarNames    
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   144
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   145
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   146
328
claus
parents: 308
diff changeset
   147
instVarOffsetOf:aVariableName
claus
parents: 308
diff changeset
   148
    "return the index (as used in instVarAt:/instVarAt:put:) of a named instance
claus
parents: 308
diff changeset
   149
     variable. The returned number is 1..instSize for valid variable names, nil for
claus
parents: 308
diff changeset
   150
     illegal names."
claus
parents: 308
diff changeset
   151
claus
parents: 308
diff changeset
   152
    ^ self allInstVarNames indexOf:aVariableName ifAbsent:nil
claus
parents: 308
diff changeset
   153
!
claus
parents: 308
diff changeset
   154
claus
parents: 308
diff changeset
   155
instVarAtOffset:index
claus
parents: 308
diff changeset
   156
    "return the name of the instance variable at index"
claus
parents: 308
diff changeset
   157
claus
parents: 308
diff changeset
   158
    ^ self allInstanceVariableNames at:index
claus
parents: 308
diff changeset
   159
!
claus
parents: 308
diff changeset
   160
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   161
name
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   162
    "return the name of the class. In the current implementation,
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   163
     this returns a string, but will be changed to Symbol soon."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   164
a27a279701f8 Initial revision
claus
parents:
diff changeset
   165
    ^ name
a27a279701f8 Initial revision
claus
parents:
diff changeset
   166
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   167
a27a279701f8 Initial revision
claus
parents:
diff changeset
   168
category
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   169
    "return the category of the class. 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   170
     The returned value may be a string or symbol."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   171
a27a279701f8 Initial revision
claus
parents:
diff changeset
   172
    ^ category
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   173
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   174
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   175
     Point category                
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   176
     Dictionary category           
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   177
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   178
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   179
a27a279701f8 Initial revision
claus
parents:
diff changeset
   180
category:aStringOrSymbol
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   181
    "set the category of the class to be the argument, aStringOrSymbol"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   182
249
claus
parents: 216
diff changeset
   183
    aStringOrSymbol isNil ifTrue:[
claus
parents: 216
diff changeset
   184
	category := aStringOrSymbol
claus
parents: 216
diff changeset
   185
    ] ifFalse:[
claus
parents: 216
diff changeset
   186
	category := aStringOrSymbol asSymbol
claus
parents: 216
diff changeset
   187
    ]
328
claus
parents: 308
diff changeset
   188
!
claus
parents: 308
diff changeset
   189
claus
parents: 308
diff changeset
   190
organization
claus
parents: 308
diff changeset
   191
    "for ST80 compatibility; 
claus
parents: 308
diff changeset
   192
     read the documentation in ClassOrganizer for more info."
claus
parents: 308
diff changeset
   193
claus
parents: 308
diff changeset
   194
    ^ ClassOrganizer for:self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   195
! !
10
claus
parents: 3
diff changeset
   196
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   197
!ClassDescription methodsFor:'signature checking'!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   198
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   199
signature
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   200
    "return a signature number - this number is useful for a quick
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   201
     check for changed classes, and is done in the binary-object loader, 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   202
     and the dynamic class loader.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   203
     Do NOT change the algorithm here - others may depend on it.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   204
     Also, the algorithm may change - so never interpret the returned value
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   205
     (if at all, use the access #XXXFromSignature: methods)"
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   206
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   207
    |value   "{ Class: SmallInteger }"
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   208
     nameKey "{ Class: SmallInteger }" |
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   209
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   210
    signature notNil ifTrue:[^ signature].
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   211
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   212
    value := self flags bitAnd:(Class maskIndexType).
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   213
    value := (value bitShift:3) + ((self class instSize - Class instSize) bitAnd:7).
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   214
    value := (value bitShift:7) + (self instSize bitAnd:16r7F).
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   215
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   216
    nameKey := 0.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   217
    self allInstVarNames do:[:name |
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   218
	nameKey := nameKey bitShift:1.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   219
	(nameKey bitAnd:16r10000) ~~ 0 ifTrue:[
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   220
	    nameKey := nameKey bitXor:1.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   221
	    nameKey := nameKey bitAnd:16rFFFF.
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   222
	].
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   223
	nameKey := (nameKey + (name at:1) asciiValue) bitAnd:16rFFFF.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   224
    ].
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   225
    value := value + (nameKey bitShift:14).
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   226
    signature := value.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   227
    ^ value
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   228
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   229
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   230
     Array signature
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   231
     ByteArray signature
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   232
     View signature
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   233
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   234
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   235
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   236
instSizeFromSignature:aSignature
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   237
    "for checking class compatibility: return the some number based on
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   238
     the instSize from a signature key (not always the real instSize)."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   239
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   240
    ^ aSignature bitAnd:16r7F
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   241
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   242
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   243
     Class instSizeFromSignature:Point signature.     
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   244
     Class instSizeFromSignature:Association signature.   
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   245
     Class instSizeFromSignature:Dictionary signature.    
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   246
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   247
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   248
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   249
classinstSizeFromSignature:aSignature
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   250
    "for checking class compatibility: return some number based on 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   251
     the classinstSize from a signature key (not always the real classinstsize)."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   252
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   253
    ^ (aSignature bitShift:-7) bitAnd:7
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   254
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   255
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   256
instTypeFromSignature:aSignature
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   257
    "for checking class compatibility: return some number based on
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   258
     the instType (i.e. variableBytes/Pointers etc.) from a signature key."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   259
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   260
    ^ (aSignature bitShift:-10) bitAnd:(Class maskIndexType)
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   261
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   262
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   263
     Class instTypeFromSignature:Object signature.               
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   264
     Class instTypeFromSignature:Array signature.                
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   265
     Class instTypeFromSignature:String signature.               
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   266
     Class instTypeFromSignature:OrderedCollection signature.    
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   267
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   268
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   269
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   270
instNameKeyFromSignature:aSignature
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   271
    "for checking class compatibility: return a number based on the
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   272
     names and order of the instance variables from a signature key."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   273
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   274
    ^ (aSignature bitShift:-14) bitAnd:16rFFFF
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   275
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   276
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   277
     Point instNameKeyFromSignature:Point signature.             
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   278
     Association instNameKeyFromSignature:Association signature.  
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   279
    "
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   280
! !
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   281
10
claus
parents: 3
diff changeset
   282
!ClassDescription methodsFor:'renaming'!
claus
parents: 3
diff changeset
   283
claus
parents: 3
diff changeset
   284
renameTo:newName
293
31df3850e98c *** empty log message ***
claus
parents: 249
diff changeset
   285
    "change the name of the class"
10
claus
parents: 3
diff changeset
   286
293
31df3850e98c *** empty log message ***
claus
parents: 249
diff changeset
   287
    |oldSym|
10
claus
parents: 3
diff changeset
   288
claus
parents: 3
diff changeset
   289
    oldSym := name asSymbol.
claus
parents: 3
diff changeset
   290
    self setName:newName.
claus
parents: 3
diff changeset
   291
claus
parents: 3
diff changeset
   292
    Smalltalk at:oldSym put:nil.
claus
parents: 3
diff changeset
   293
    Smalltalk removeKey:oldSym.             "26.jun 93"
claus
parents: 3
diff changeset
   294
    Smalltalk at:(newName asSymbol) put:self.
claus
parents: 3
diff changeset
   295
! !
claus
parents: 3
diff changeset
   296
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   297
!ClassDescription methodsFor:'printing & storing'!
68
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
   298
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
   299
displayString
293
31df3850e98c *** empty log message ***
claus
parents: 249
diff changeset
   300
    "return a string for display in inspectors"
31df3850e98c *** empty log message ***
claus
parents: 249
diff changeset
   301
31df3850e98c *** empty log message ***
claus
parents: 249
diff changeset
   302
    |nm more|
68
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
   303
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
   304
    category == #obsolete ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   305
	"add obsolete - to make life easier ..."
293
31df3850e98c *** empty log message ***
claus
parents: 249
diff changeset
   306
	more := ' (obsolete)'
68
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
   307
    ].
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   308
    category == #removed ifTrue:[
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   309
	"add removed - to make life easier ..."
293
31df3850e98c *** empty log message ***
claus
parents: 249
diff changeset
   310
	more := ' (removed)'
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   311
    ].
293
31df3850e98c *** empty log message ***
claus
parents: 249
diff changeset
   312
31df3850e98c *** empty log message ***
claus
parents: 249
diff changeset
   313
    nm := self name.
31df3850e98c *** empty log message ***
claus
parents: 249
diff changeset
   314
    more isNil ifTrue:[^ nm].
31df3850e98c *** empty log message ***
claus
parents: 249
diff changeset
   315
    ^ nm , more    
68
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
   316
! !
59faa75185ba *** empty log message ***
claus
parents: 10
diff changeset
   317
10
claus
parents: 3
diff changeset
   318
!ClassDescription methodsFor:'private'!
claus
parents: 3
diff changeset
   319
claus
parents: 3
diff changeset
   320
addAllInstVarNamesTo:aCollection
308
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   321
    "helper for allInstVarNames - add the name-strings of the instance variables
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   322
     and of the inst-vars of all superclasses to the argument, aCollection. 
f04744ef7b5d *** empty log message ***
claus
parents: 293
diff changeset
   323
     Return aCollection."
10
claus
parents: 3
diff changeset
   324
459
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   325
    |superInsts|
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   326
10
claus
parents: 3
diff changeset
   327
    (superclass notNil) ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   328
	superclass addAllInstVarNamesTo:aCollection
10
claus
parents: 3
diff changeset
   329
    ].
claus
parents: 3
diff changeset
   330
    instvars notNil ifTrue:[
155
edd7fc34e104 *** empty log message ***
claus
parents: 92
diff changeset
   331
	aCollection addAll:(instvars asCollectionOfWords).
459
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   332
    ] ifFalse:[
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   333
	"/ mhmh - either someone klduged around, or this is
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   334
	"/ a system running without sourceInfo. Generate
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   335
	"/ synthetic names.
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   336
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   337
	superclass isNil ifTrue:[
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   338
	    superInsts := 0
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   339
	] ifFalse:[
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   340
	    superInsts := superclass instSize
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   341
	].
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   342
	aCollection addAll:((superInsts+1 to:self instSize) 
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   343
				collect:[:index | '* instVar' , index printString , ' *'])
10
claus
parents: 3
diff changeset
   344
    ].
claus
parents: 3
diff changeset
   345
    ^ aCollection
459
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   346
744b144ae909 generate synthetic instvar names (for -sourceInfo)
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   347
    "Modified: 30.10.1995 / 19:46:21 / cg"
10
claus
parents: 3
diff changeset
   348
! !