Behavior.st
author Claus Gittinger <cg@exept.de>
Mon, 23 Oct 1995 17:55:03 +0100
changeset 443 fae13c0f1512
parent 442 65a11cda5e9e
child 457 41c73cbee305
permissions -rw-r--r--
.
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) 1988 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
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
Object subclass:#Behavior
357
claus
parents: 356
diff changeset
    14
       instanceVariableNames:'superclass flags selectorArray methodArray
claus
parents: 356
diff changeset
    15
			      otherSuperclasses instSize'
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
    16
       classVariableNames:'SubclassInfo'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
       category:'Kernel-Classes'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
Behavior comment:'
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
    22
COPYRIGHT (c) 1988 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
    23
	      All Rights Reserved
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
    24
442
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
    25
$Header: /cvs/stx/stx/libbasic/Behavior.st,v 1.49 1995-10-23 16:50:42 cg Exp $
47
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
    26
'!
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
    27
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
    28
!Behavior class methodsFor:'documentation'!
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
    29
88
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    30
copyright
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    31
"
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    32
 COPYRIGHT (c) 1988 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
    33
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    34
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    35
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    36
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    37
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    38
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    39
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    40
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    41
"
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    42
!
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    43
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    44
version
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    45
"
442
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
    46
$Header: /cvs/stx/stx/libbasic/Behavior.st,v 1.49 1995-10-23 16:50:42 cg Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    47
"
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    48
!
81dacba7a63a *** empty log message ***
claus
parents: 82
diff changeset
    49
47
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
    50
documentation
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
    51
"
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    52
    Every class in the system inherits from Behavior (via Class, ClassDescription);
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    53
    so here is where most of the class messages end up being implemented.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    54
    (to answer a FAQ: 'Point basicNew' will be done here :-)
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    55
356
claus
parents: 345
diff changeset
    56
    Beginners should keep in mind, that all classes are instances (of subclasses)
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
    57
    of Behavior, therefore you will find the above mentioned 'basicNew:' method 
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
    58
    under the 'instance'-methods of Behavior - NOT under the class methods 
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
    59
    ('Behavior new' will create and return a new class, while sending 'new' to 
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
    60
    any instance of Behavior (i.e. any class) will return an instance of that class).
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    61
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    62
    Behavior provides minimum support for all classes - additional stuff is
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    63
    found in ClassDescription and Class. Behaviors provides all mechanisms needed
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    64
    to create instances, and send messages to those. However, Behavior does not provide 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    65
    all the (symbolic) information needed to compile methods for a class or to get
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
    66
    useful information in inspectors.
47
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
    67
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    68
    In contrast to other ST implementations, the methods have been separated
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    69
    from the selectors (there is no Dictionary, but two separate Arrays)
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    70
    - this avoids the need for knowledge about Dictionaries in the runtime library (VM)
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    71
    (lookup and search in these is seldom anyway, so the added benefit from using a 
356
claus
parents: 345
diff changeset
    72
     hashed dictionary is almost void). 
claus
parents: 345
diff changeset
    73
    For ST-80 compatibility, this will be replaced by a single instance of
362
claus
parents: 360
diff changeset
    74
    MethodDictionary (which will NOT be a true dictionary, but an Array with
356
claus
parents: 345
diff changeset
    75
    alternating selector/method entries).
claus
parents: 345
diff changeset
    76
    To be prepared for this change, please do NOT directly use the methodArray 
claus
parents: 345
diff changeset
    77
    and selectorArray instVars.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    78
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    79
    Instance variables:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    80
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
    81
	superclass        <Class>           the receivers superclass
356
claus
parents: 345
diff changeset
    82
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
    83
	otherSuperclasses <Array of Class>  experimental: other superclasses
356
claus
parents: 345
diff changeset
    84
					    a hook for experimental multiple inheritance
claus
parents: 345
diff changeset
    85
					    implementations
claus
parents: 345
diff changeset
    86
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
    87
	selectorArray     <Array of Symbol> the selectors for which inst-methods are defined here
356
claus
parents: 345
diff changeset
    88
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
    89
	methodArray       <Array of Method> the inst-methods corresponding to the selectors
356
claus
parents: 345
diff changeset
    90
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
    91
	instSize          <SmallInteger>    the number of instance variables
356
claus
parents: 345
diff changeset
    92
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
    93
	flags             <SmallInteger>    special flag bits coded in a number
356
claus
parents: 345
diff changeset
    94
					    not for application use
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    95
81
e02c66a7296f *** empty log message ***
claus
parents: 77
diff changeset
    96
    flag bits (see stc.h):
47
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
    97
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
    98
    NOTICE: layout known by compiler and runtime system; be careful when changing
47
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
    99
"
356
claus
parents: 345
diff changeset
   100
!
claus
parents: 345
diff changeset
   101
claus
parents: 345
diff changeset
   102
virtualMachineRelationship 
claus
parents: 345
diff changeset
   103
"
357
claus
parents: 356
diff changeset
   104
    NOTICE: 
claus
parents: 356
diff changeset
   105
	the stuff described below may not be available on other
claus
parents: 356
diff changeset
   106
	Smalltalk implementations; be aware that these error mechanisms
claus
parents: 356
diff changeset
   107
	are ST/X specials and applications using these (tricks) may
claus
parents: 356
diff changeset
   108
	not be portable to other systems.
claus
parents: 356
diff changeset
   109
claus
parents: 356
diff changeset
   110
    WARNING: 
claus
parents: 356
diff changeset
   111
	do not try the examples below on (some) other smalltalk systems;
claus
parents: 356
diff changeset
   112
	it has been reported, that some crash badly when doing this .... ;-)
claus
parents: 356
diff changeset
   113
356
claus
parents: 345
diff changeset
   114
    Instances of Behavior and subclasses (i.e. in sloppy words: classes)
claus
parents: 345
diff changeset
   115
    play a special role w.r.t. the VM. Only objects whose class-slot is marked
claus
parents: 345
diff changeset
   116
    as being behaviorLike (in the flag-instvar) are considered to be classLike
claus
parents: 345
diff changeset
   117
    and a message lookup will be done for it in the well known way.
claus
parents: 345
diff changeset
   118
    Thus, if an object has a class for which its class does NOT have
362
claus
parents: 360
diff changeset
   119
    this flag bit set, the VM will trigger an error on a message send.
356
claus
parents: 345
diff changeset
   120
claus
parents: 345
diff changeset
   121
    Why is this so:
claus
parents: 345
diff changeset
   122
claus
parents: 345
diff changeset
   123
    the above lets every object play the role of a class,
claus
parents: 345
diff changeset
   124
    which has been flagged as behaviorLike in its class's flag.
claus
parents: 345
diff changeset
   125
    Thus, you can create arbitrary new classLike objects and have the VM 
claus
parents: 345
diff changeset
   126
    play with them.
claus
parents: 345
diff changeset
   127
    This may offer the flexibility to create a totally different object scheme
362
claus
parents: 360
diff changeset
   128
    on top of ST/X (for example: Self like objects) where any object can play
claus
parents: 360
diff changeset
   129
    a classRole for another object.
356
claus
parents: 345
diff changeset
   130
357
claus
parents: 356
diff changeset
   131
    However, the VM trusts the isBehaviorLike flag - if it is set for some
362
claus
parents: 360
diff changeset
   132
    object, it expects the object selector and methodDictionaries to be found
claus
parents: 360
diff changeset
   133
    at the instance positions as defined here.
claus
parents: 360
diff changeset
   134
    (i.e. instanceVariables with contents and semantic corresponding to
claus
parents: 360
diff changeset
   135
	superclass flags selectorArray methodArray
claus
parents: 360
diff changeset
   136
     must be present and have the same instVar-index as here).
claus
parents: 360
diff changeset
   137
356
claus
parents: 345
diff changeset
   138
    The VM (and the system) may crash badly, if this is not the case.
362
claus
parents: 360
diff changeset
   139
356
claus
parents: 345
diff changeset
   140
    Since every class in the system derives from Behavior, the flag setting
357
claus
parents: 356
diff changeset
   141
    (and instance variable layout) is correct for all 'normal' classes.
claus
parents: 356
diff changeset
   142
    If you experiment by creating new behaviorLike objects, please take
claus
parents: 356
diff changeset
   143
    care of this flag. If you want to use the VM's lookup function, the
claus
parents: 356
diff changeset
   144
    instVars  'superclass', 'selectorArray' and 'methodArray' are required
claus
parents: 356
diff changeset
   145
    and have to be at the same instVar index.
362
claus
parents: 360
diff changeset
   146
    (we suggest, you subclass Behavior, to make certain)
357
claus
parents: 356
diff changeset
   147
claus
parents: 356
diff changeset
   148
    You do not have to care about the above details if you are a 'normal'
claus
parents: 356
diff changeset
   149
    ST-programmer, though.
claus
parents: 356
diff changeset
   150
356
claus
parents: 345
diff changeset
   151
claus
parents: 345
diff changeset
   152
    Examples (only of theoretical interrest):
claus
parents: 345
diff changeset
   153
	take away the behaviorLike-flag from a class.
claus
parents: 345
diff changeset
   154
	-> The instances will not understand any messages, since the VM will
claus
parents: 345
diff changeset
   155
	   not recognize its class as being a class ...
claus
parents: 345
diff changeset
   156
claus
parents: 345
diff changeset
   157
	|newMeta notRecognizedAsClass someInstance|
claus
parents: 345
diff changeset
   158
claus
parents: 345
diff changeset
   159
	newMeta := Metaclass new.
claus
parents: 345
diff changeset
   160
	newMeta flags:0.
claus
parents: 345
diff changeset
   161
claus
parents: 345
diff changeset
   162
	notRecognizedAsClass := newMeta new.
claus
parents: 345
diff changeset
   163
claus
parents: 345
diff changeset
   164
	someInstance := notRecognizedAsClass new.
claus
parents: 345
diff changeset
   165
	someInstance perform:#isNil
claus
parents: 345
diff changeset
   166
357
claus
parents: 356
diff changeset
   167
claus
parents: 356
diff changeset
   168
    Of course, this is an exception which can be handled ...:
claus
parents: 356
diff changeset
   169
    Example:
claus
parents: 356
diff changeset
   170
claus
parents: 356
diff changeset
   171
	|newMeta notRecognizedAsClass someInstance|
claus
parents: 356
diff changeset
   172
claus
parents: 356
diff changeset
   173
	newMeta := Metaclass new.
claus
parents: 356
diff changeset
   174
	newMeta flags:0.
claus
parents: 356
diff changeset
   175
claus
parents: 356
diff changeset
   176
	notRecognizedAsClass := newMeta new.
claus
parents: 356
diff changeset
   177
claus
parents: 356
diff changeset
   178
	someInstance := notRecognizedAsClass new.
claus
parents: 356
diff changeset
   179
	Object errorSignal handle:[:ex |
claus
parents: 356
diff changeset
   180
	    ex return
claus
parents: 356
diff changeset
   181
	] do:[
claus
parents: 356
diff changeset
   182
	    someInstance perform:#isNil
claus
parents: 356
diff changeset
   183
	]
claus
parents: 356
diff changeset
   184
claus
parents: 356
diff changeset
   185
claus
parents: 356
diff changeset
   186
    likewise, a doesNotUnderstand-notUnderstood can be handled:
claus
parents: 356
diff changeset
   187
    Example:
claus
parents: 356
diff changeset
   188
claus
parents: 356
diff changeset
   189
	|newMeta funnyClass someInstance|
claus
parents: 356
diff changeset
   190
claus
parents: 356
diff changeset
   191
	newMeta := Metaclass new.
claus
parents: 356
diff changeset
   192
claus
parents: 356
diff changeset
   193
	funnyClass := newMeta new.
claus
parents: 356
diff changeset
   194
	funnyClass setSuperclass:nil.
claus
parents: 356
diff changeset
   195
claus
parents: 356
diff changeset
   196
	someInstance := funnyClass new.
claus
parents: 356
diff changeset
   197
	Object errorSignal handle:[:ex |
claus
parents: 356
diff changeset
   198
	     ex return
claus
parents: 356
diff changeset
   199
	] do:[
claus
parents: 356
diff changeset
   200
	    someInstance perform:#isNil
claus
parents: 356
diff changeset
   201
	]
claus
parents: 356
diff changeset
   202
claus
parents: 356
diff changeset
   203
362
claus
parents: 360
diff changeset
   204
    more examples, which try to trick the VM ;-):
357
claus
parents: 356
diff changeset
   205
	badly playing around with a classes internals ...
claus
parents: 356
diff changeset
   206
claus
parents: 356
diff changeset
   207
	|newClass someInstance|
claus
parents: 356
diff changeset
   208
claus
parents: 356
diff changeset
   209
	newClass := Class new.
claus
parents: 356
diff changeset
   210
	newClass setSelectorArray:nil.
claus
parents: 356
diff changeset
   211
	someInstance := newClass new.
claus
parents: 356
diff changeset
   212
	someInstance inspect
claus
parents: 356
diff changeset
   213
claus
parents: 356
diff changeset
   214
claus
parents: 356
diff changeset
   215
	|newClass someInstance|
claus
parents: 356
diff changeset
   216
claus
parents: 356
diff changeset
   217
	newClass := Class new.
claus
parents: 356
diff changeset
   218
	newClass setSuperclass:nil.
claus
parents: 356
diff changeset
   219
	someInstance := newClass new.
claus
parents: 356
diff changeset
   220
	someInstance inspect
claus
parents: 356
diff changeset
   221
claus
parents: 356
diff changeset
   222
claus
parents: 356
diff changeset
   223
	|newClass someInstance|
claus
parents: 356
diff changeset
   224
claus
parents: 356
diff changeset
   225
	newClass := Class new.
claus
parents: 356
diff changeset
   226
	newClass setSuperclass:newClass.
claus
parents: 356
diff changeset
   227
	someInstance := newClass new.
claus
parents: 356
diff changeset
   228
	someInstance inspect
claus
parents: 356
diff changeset
   229
claus
parents: 356
diff changeset
   230
claus
parents: 356
diff changeset
   231
	|newClass someInstance|
claus
parents: 356
diff changeset
   232
claus
parents: 356
diff changeset
   233
	newClass := Class new.
claus
parents: 356
diff changeset
   234
	newClass setSuperclass:1.
claus
parents: 356
diff changeset
   235
	someInstance := newClass new.
claus
parents: 356
diff changeset
   236
	someInstance inspect
claus
parents: 356
diff changeset
   237
claus
parents: 356
diff changeset
   238
356
claus
parents: 345
diff changeset
   239
    Example:
claus
parents: 345
diff changeset
   240
	creating totally anonymous classes:
claus
parents: 345
diff changeset
   241
claus
parents: 345
diff changeset
   242
	|newClass someInstance|
claus
parents: 345
diff changeset
   243
claus
parents: 345
diff changeset
   244
	newClass := Class new.
claus
parents: 345
diff changeset
   245
	someInstance := newClass new.
claus
parents: 345
diff changeset
   246
	someInstance inspect
claus
parents: 345
diff changeset
   247
357
claus
parents: 356
diff changeset
   248
356
claus
parents: 345
diff changeset
   249
    Example:
357
claus
parents: 356
diff changeset
   250
	creating totally anonymous metaclasses:
356
claus
parents: 345
diff changeset
   251
claus
parents: 345
diff changeset
   252
	|newMeta newClass someInstance|
claus
parents: 345
diff changeset
   253
claus
parents: 345
diff changeset
   254
	newMeta := Metaclass new.
claus
parents: 345
diff changeset
   255
	newClass := newMeta new.
claus
parents: 345
diff changeset
   256
	someInstance := newClass new.
claus
parents: 345
diff changeset
   257
	someInstance inspect
357
claus
parents: 356
diff changeset
   258
claus
parents: 356
diff changeset
   259
    PS: if you experiment with new behaviorLike objects, you may want 
claus
parents: 356
diff changeset
   260
	to turn off the VM's debugPrintouts
claus
parents: 356
diff changeset
   261
	with: 
claus
parents: 356
diff changeset
   262
		'Smalltalk debugPrinting:false'
claus
parents: 356
diff changeset
   263
	and: 
claus
parents: 356
diff changeset
   264
		'Smalltalk infoPrinting:false'
356
claus
parents: 345
diff changeset
   265
"
47
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
   266
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   267
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   268
!Behavior class methodsFor:'queries'!
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   269
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   270
isBuiltInClass
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   271
    "this class is known by the run-time-system"
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   272
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   273
    ^ true
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   274
! !
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   275
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   276
!Behavior class methodsFor:'creating new classes'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   277
a27a279701f8 Initial revision
claus
parents:
diff changeset
   278
new
356
claus
parents: 345
diff changeset
   279
    "creates and return a new behavior (which is like a class,
claus
parents: 345
diff changeset
   280
     but without the symbolic & name information).
claus
parents: 345
diff changeset
   281
     Not for normal applications.
claus
parents: 345
diff changeset
   282
     Sending the returned behavior the #new message gives you
claus
parents: 345
diff changeset
   283
     an instance if it.
claus
parents: 345
diff changeset
   284
claus
parents: 345
diff changeset
   285
     Notice: the returned class is given a superclass of Object;
claus
parents: 345
diff changeset
   286
     this allows for its new instances to be inspected and the like."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   287
a27a279701f8 Initial revision
claus
parents:
diff changeset
   288
    |newClass|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   289
a27a279701f8 Initial revision
claus
parents:
diff changeset
   290
    newClass := self basicNew.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   291
    newClass setSuperclass:Object
345
claus
parents: 343
diff changeset
   292
		 selectors:#() "/ (Array new:0)
claus
parents: 343
diff changeset
   293
		   methods:#() "/ (Array new:0)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   294
		  instSize:0
345
claus
parents: 343
diff changeset
   295
		     flags:(self flagBehavior).
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   296
    ^ newClass
356
claus
parents: 345
diff changeset
   297
claus
parents: 345
diff changeset
   298
    "
claus
parents: 345
diff changeset
   299
     Behavior new               <- a new behavior
claus
parents: 345
diff changeset
   300
     Behavior new new           <- an instance of it
claus
parents: 345
diff changeset
   301
     ClassDescription new       <- a new classDescription
claus
parents: 345
diff changeset
   302
     ClassDescription new new   <- an instance of it
claus
parents: 345
diff changeset
   303
     Class new                  <- a new class
claus
parents: 345
diff changeset
   304
     Class new new              <- an instance of it
claus
parents: 345
diff changeset
   305
     Metaclass new              <- a new metaclass
claus
parents: 345
diff changeset
   306
     Metaclass new new          <- an instance (i.e. a class) of it
claus
parents: 345
diff changeset
   307
     Metaclass new new new      <- an instance of this new class
claus
parents: 345
diff changeset
   308
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   309
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   310
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   311
!Behavior class methodsFor:'private '!
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   312
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   313
subclassInfo
357
claus
parents: 356
diff changeset
   314
    |d|
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   315
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   316
    SubclassInfo notNil ifTrue:[^ SubclassInfo].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   317
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   318
    d := IdentityDictionary new.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   319
    Smalltalk allClassesDo:[:aClass |
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   320
	|superCls|
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   321
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   322
	aClass isMeta not ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   323
	    superCls := aClass superclass.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   324
	    superCls notNil ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   325
		(d includesKey: superCls) ifFalse:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   326
		    d at:superCls put:(Set with:aClass).
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   327
		] ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   328
		    (d at:superCls ) add:aClass
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   329
		]
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   330
	    ]
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   331
	].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   332
    ].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   333
    SubclassInfo := d.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   334
    ^ d
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   335
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   336
    "
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   337
     Class subclassInfo
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   338
    "
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   339
!
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   340
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   341
flushSubclassInfo
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   342
    SubclassInfo := nil.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   343
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   344
    "
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   345
     Class flushSubclassInfo
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   346
    "
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   347
! !
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   348
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   349
!Behavior methodsFor:'initialization'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   350
a27a279701f8 Initial revision
claus
parents:
diff changeset
   351
initialize
442
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   352
    "initialize is sent to a class either during startup,
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   353
     (for all statically compiled-in classes) or after a class
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   354
     has been loaded into the system (either bytecodes or machinecode).
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   355
     The default action here is to do nothing."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   356
a27a279701f8 Initial revision
claus
parents:
diff changeset
   357
    ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   358
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   359
328
claus
parents: 325
diff changeset
   360
postAutoload
442
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   361
    "postAutoload is sent to a class after it has been autoloaded.
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   362
     This gives it a chance to arrange for automatic unloading to be done
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   363
     after a while ...
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   364
     This is NOT sent to statically compiled in or explicitely filedIn
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   365
     classes.
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   366
     The default action here is to do nothing."
328
claus
parents: 325
diff changeset
   367
claus
parents: 325
diff changeset
   368
    ^ self
claus
parents: 325
diff changeset
   369
!
claus
parents: 325
diff changeset
   370
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   371
reinitialize
442
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   372
    "reinitialize is sent to a class when an image has been restarted.
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   373
     I.e. when the system is restarted.
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   374
     This gives classes a chance to flush any device dependent or otherwise
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   375
     obsolete data which may be a leftover from the previous live.
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   376
     The default action here is to do nothing."
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   377
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   378
    ^ self
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   379
!
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   380
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   381
deinitialize
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   382
    "deinitialize is sent to a class before it is physically unloaded.
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   383
     This is only done with classes which have been loaded in from a binary
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   384
     file. Classes may release any primitive memory or other stuff which is
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   385
     not visible to smalltalk (for example, release internal memory).
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
   386
     The default action here is to do nothing."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   387
a27a279701f8 Initial revision
claus
parents:
diff changeset
   388
    ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   389
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   390
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   391
!Behavior methodsFor:'copying'!
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   392
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   393
deepCopy
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   394
    "return a deep copy of the receiver
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   395
     - return the receiver here - time will show if this is ok"
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   396
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   397
    ^ self
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   398
!
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   399
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   400
deepCopyUsing:aDictionary
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   401
    "return a deep copy of the receiver
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   402
     - return the receiver here - time will show if this is ok"
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   403
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   404
    ^ self
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   405
!
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   406
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   407
simpleDeepCopy
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   408
    "return a deep copy of the receiver
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   409
     - return the receiver here - time will show if this is ok"
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   410
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   411
    ^ self
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   412
! !
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   413
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   414
!Behavior methodsFor:'creating an instance of myself'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   415
a27a279701f8 Initial revision
claus
parents:
diff changeset
   416
uninitializedNew
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   417
    "create an instance of myself with uninitialized contents.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   418
     For all classes except ByteArray, this is the same as new."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   419
a27a279701f8 Initial revision
claus
parents:
diff changeset
   420
    ^ self basicNew
a27a279701f8 Initial revision
claus
parents:
diff changeset
   421
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   422
a27a279701f8 Initial revision
claus
parents:
diff changeset
   423
uninitializedNew:anInteger
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   424
    "create an instance of myself with uninitialized contents.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
   425
     For all classes except ByteArray, this is the same as new."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   426
a27a279701f8 Initial revision
claus
parents:
diff changeset
   427
    ^ self basicNew:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   428
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   429
127
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   430
niceBasicNew:anInteger
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   431
    "same as basicNew:anInteger, but tries to avoid long pauses
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   432
     due to garbage collection. This method checks to see if
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   433
     allocation is possible without a pause, and does a background
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   434
     incremental garbage collect first if there is not enough memory
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   435
     available at the moment for fast allocation. 
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   436
     This is useful in low-priority background processes which like to 
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   437
     avoid disturbing any higher priority foreground process while allocating
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   438
     big amounts of memory. Of course, using this method only makes
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   439
     sense for big or huge objects (say > 200k).
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   440
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   441
     EXPERIMENTAL: this is a non-standard interface and should only 
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   442
     be used for special applications. There is no guarantee, that this
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   443
     method will be available in future ST/X releases."
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   444
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   445
    |size|
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   446
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   447
    size := self sizeOfInst:anInteger.
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   448
    (ObjectMemory checkForFastNew:size) ifFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   449
	"
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   450
	 incrementally collect garbage
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   451
	"
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   452
	ObjectMemory incrementalGC.
127
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   453
    ].
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   454
    ^ self basicNew:anInteger
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   455
!
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   456
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   457
new
a27a279701f8 Initial revision
claus
parents:
diff changeset
   458
    "return an instance of myself without indexed variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   459
a27a279701f8 Initial revision
claus
parents:
diff changeset
   460
    ^ self basicNew
a27a279701f8 Initial revision
claus
parents:
diff changeset
   461
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   462
a27a279701f8 Initial revision
claus
parents:
diff changeset
   463
new:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   464
    "return an instance of myself with anInteger indexed variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   465
a27a279701f8 Initial revision
claus
parents:
diff changeset
   466
    ^ self basicNew:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   467
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   468
a27a279701f8 Initial revision
claus
parents:
diff changeset
   469
basicNew
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 47
diff changeset
   470
    "return an instance of myself without indexed variables.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   471
     If the receiver-class has indexed instvars, the new object will have
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   472
     a basicSize of zero - 
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   473
     i.e. 'aClass basicNew' is equivalent to 'aClass basicNew:0'.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 47
diff changeset
   474
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   475
     ** Do not redefine this method in any class **"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   476
a27a279701f8 Initial revision
claus
parents:
diff changeset
   477
%{  /* NOCONTEXT */
81
e02c66a7296f *** empty log message ***
claus
parents: 77
diff changeset
   478
    REGISTER OBJ newobj;
e02c66a7296f *** empty log message ***
claus
parents: 77
diff changeset
   479
    REGISTER char *nextPtr;
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   480
    unsigned int instsize;
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   481
    REGISTER unsigned int nInstVars;
369
claus
parents: 362
diff changeset
   482
    extern OBJ __new();
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   483
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 47
diff changeset
   484
    /*
369
claus
parents: 362
diff changeset
   485
     * the following ugly code is nothing more than a __new() followed
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 47
diff changeset
   486
     * by a nilling of the new instance.
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   487
     * Unrolled for a bit more speed since this is one of the central object 
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   488
     * allocation methods in the system
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 47
diff changeset
   489
     */
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   490
    nInstVars = _intVal(_INST(instSize));
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   491
    instsize = OHDR_SIZE + __OBJS2BYTES__(nInstVars);
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 47
diff changeset
   492
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
   493
    newobj = (OBJ) newNextPtr;
81
e02c66a7296f *** empty log message ***
claus
parents: 77
diff changeset
   494
    nextPtr = ((char *)newobj) + instsize;
e02c66a7296f *** empty log message ***
claus
parents: 77
diff changeset
   495
e02c66a7296f *** empty log message ***
claus
parents: 77
diff changeset
   496
    /*
e02c66a7296f *** empty log message ***
claus
parents: 77
diff changeset
   497
     * dont argue about the goto and the arrangement below - it saves 
e02c66a7296f *** empty log message ***
claus
parents: 77
diff changeset
   498
     * an extra nil-compare and branch in the common case ...
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   499
     * (i.e. if no GC is needed, we fall through without a branch)
81
e02c66a7296f *** empty log message ***
claus
parents: 77
diff changeset
   500
     */
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   501
    if (nextPtr < newEndPtr) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   502
	_objPtr(newobj)->o_size = instsize;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   503
	/* o_allFlags(newobj) = 0;              */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   504
	/* _objPtr(newobj)->o_space = newSpace; */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   505
	o_setAllFlags(newobj, newSpace);
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   506
#ifdef ALIGN4
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   507
	newNextPtr = nextPtr;
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   508
#else
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   509
	if (instsize & (ALIGN-1)) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   510
	    newNextPtr = (char *)newobj + (instsize & ~(ALIGN-1)) + ALIGN;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   511
	} else {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   512
	    newNextPtr = nextPtr;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   513
	}
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   514
#endif
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   515
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   516
ok:
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   517
	_InstPtr(newobj)->o_class = self;
369
claus
parents: 362
diff changeset
   518
	__qSTORE(newobj, self);
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   519
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   520
	if (nInstVars) {
357
claus
parents: 356
diff changeset
   521
#if defined(FAST_OBJECT_MEMSET4) || defined(FAST_MEMSET4)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   522
	    memset4(_InstPtr(newobj)->i_instvars, nil, nInstVars);
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   523
#else
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   524
	    REGISTER OBJ *op;
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   525
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   526
	    op = _InstPtr(newobj)->i_instvars;
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   527
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   528
# if !defined(NEGATIVE_ADDRESSES)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   529
	    /*
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   530
	     * knowing that nil is 0
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   531
	     */
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   532
#  if defined(FAST_OBJECT_MEMSET_DOUBLES_UNROLLED)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   533
	    if (nInstVars > 8) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   534
		*op++ = nil;    /* for alignment */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   535
		nInstVars--;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   536
		while (nInstVars >= 8) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   537
		    *(double *)op = 0.0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   538
		    ((double *)op)[1] = 0.0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   539
		    ((double *)op)[2] = 0.0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   540
		    ((double *)op)[3] = 0.0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   541
		    op += 8;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   542
		    nInstVars -= 8;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   543
		}
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   544
	    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   545
	    while (nInstVars != 0) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   546
		*op++ = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   547
		nInstVars--;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   548
	    }
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   549
#  else
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   550
#   if defined(FAST_OBJECT_MEMSET_LONGLONG_UNROLLED)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   551
	    if (nInstVars > 8) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   552
		*op++ = nil;    /* for alignment */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   553
		nInstVars--;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   554
		while (nInstVars >= 8) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   555
		    *(long long *)op = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   556
		    ((long long *)op)[1] = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   557
		    ((long long *)op)[2] = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   558
		    ((long long *)op)[3] = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   559
		    op += 8;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   560
		    nInstVars -= 8;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   561
		}
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   562
	    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   563
	    while (nInstVars != 0) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   564
		*op++ = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   565
		nInstVars--;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   566
	    }
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   567
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   568
#   else
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   569
#    if defined(FAST_OBJECT_MEMSET_WORDS_UNROLLED)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   570
	    while (nInstVars >= 8) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   571
		*op = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   572
		*(op+1) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   573
		*(op+2) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   574
		*(op+3) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   575
		*(op+4) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   576
		*(op+5) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   577
		*(op+6) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   578
		*(op+7) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   579
		op += 8;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   580
		nInstVars -= 8;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   581
	    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   582
	    while (nInstVars != 0) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   583
		*op++ = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   584
		nInstVars--;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   585
	    }
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   586
#    else
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   587
#     if defined(FAST_MEMSET)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   588
	    memset(_InstPtr(newobj)->i_instvars, 0, instsize-OHDR_SIZE);
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   589
#     else
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   590
	    do {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   591
		*op++ = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   592
		nInstVars--;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   593
	    } while (nInstVars != 0);
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   594
#     endif
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   595
#    endif
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   596
#   endif
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   597
#  endif
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   598
# else /* nil could be ~~ 0 */
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   599
	    while (nInstVars >= 8) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   600
		*op = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   601
		*(op+1) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   602
		*(op+2) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   603
		*(op+3) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   604
		*(op+4) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   605
		*(op+5) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   606
		*(op+6) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   607
		*(op+7) = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   608
		op += 8;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   609
		nInstVars -= 8;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   610
	    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   611
	    while (nInstVars != 0) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   612
		*op++ = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   613
		nInstVars--;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   614
	    }
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   615
# endif
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   616
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   617
	}
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   618
	RETURN ( newobj );
81
e02c66a7296f *** empty log message ***
claus
parents: 77
diff changeset
   619
    }
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 47
diff changeset
   620
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   621
    /*
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   622
     * the slow case - a GC will occur
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   623
     */
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   624
    PROTECT_CONTEXT
369
claus
parents: 362
diff changeset
   625
    newobj = __new(instsize);
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   626
    UNPROTECT_CONTEXT
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   627
    if (newobj != nil) goto ok;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   628
%}
2
claus
parents: 1
diff changeset
   629
.
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   630
    "
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   631
     memory allocation failed.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   632
     When we arrive here, there was no memory, even after
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
   633
     a garbage collect. 
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
   634
     This means, that the VM wanted to get some more memory from the 
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
   635
     Operatingsystem, which was not kind enough to give it.
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
   636
     Bad luck - you should increase the swap space on your machine.
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   637
    "
127
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
   638
    ^ ObjectMemory allocationFailureSignal raise.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   639
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   640
a27a279701f8 Initial revision
claus
parents:
diff changeset
   641
basicNew:anInteger
a27a279701f8 Initial revision
claus
parents:
diff changeset
   642
    "return an instance of myself with anInteger indexed variables.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   643
     If the receiver-class has no indexed instvars, this is only allowed
a27a279701f8 Initial revision
claus
parents:
diff changeset
   644
     if the argument, anInteger is zero.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   645
     ** Do not redefine this method in any class **"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   646
a27a279701f8 Initial revision
claus
parents:
diff changeset
   647
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   648
a27a279701f8 Initial revision
claus
parents:
diff changeset
   649
    OBJ newobj;
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   650
    unsigned INT instsize, nInstVars;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   651
    INT nindexedinstvars;
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   652
    unsigned INT flags;
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   653
#if ! defined(FAST_ARRAY_MEMSET) || defined(NEGATIVE_ADDRESSES)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   654
    REGISTER char *cp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   655
    short *sp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   656
    long *lp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   657
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   658
    REGISTER OBJ *op;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   659
    float *fp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   660
    double *dp;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   661
249
claus
parents: 216
diff changeset
   662
    if (__isSmallInteger(anInteger)) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   663
	nindexedinstvars = _intVal(anInteger);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   664
	if (nindexedinstvars >= 0) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   665
	    nInstVars = _intVal(_INST(instSize));
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   666
	    flags = _intVal(_INST(flags)) & ARRAYMASK;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   667
	    switch (flags) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   668
		case BYTEARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   669
		    instsize = OHDR_SIZE + nindexedinstvars;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   670
		    if (nInstVars == 0) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   671
			if (_CanDoQuickNew(instsize)) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   672
			    /*
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   673
			     * the most common case
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   674
			     */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   675
			    _qCheckedNew(newobj, instsize);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   676
			    _InstPtr(newobj)->o_class = self;
357
claus
parents: 356
diff changeset
   677
#if defined(FAST_ARRAY_MEMSET4) || defined(FAST_MEMSET4)
359
claus
parents: 357
diff changeset
   678
			    nInstVars = nindexedinstvars >> 2;
claus
parents: 357
diff changeset
   679
			    if (nindexedinstvars & 3) nInstVars++;
claus
parents: 357
diff changeset
   680
			    memset4(_InstPtr(newobj)->i_instvars, 0, nInstVars);
357
claus
parents: 356
diff changeset
   681
#else
claus
parents: 356
diff changeset
   682
# if defined(FAST_ARRAY_MEMSET) && ! defined(NEGATIVE_ADDRESSES)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   683
			    memset(_InstPtr(newobj)->i_instvars, 0, nindexedinstvars);
357
claus
parents: 356
diff changeset
   684
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   685
			    cp = (char *)_InstPtr(newobj)->i_instvars;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   686
			    while (nindexedinstvars >= sizeof(long)) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   687
				*(long *)cp = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   688
				cp += sizeof(long);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   689
				nindexedinstvars -= sizeof(long);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   690
			    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   691
			    while (nindexedinstvars--)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   692
				*cp++ = '\0';
357
claus
parents: 356
diff changeset
   693
# endif
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   694
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   695
			    RETURN ( newobj );
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   696
			}
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   697
		    } else {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   698
			instsize += __OBJS2BYTES__(nInstVars);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   699
		    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   700
		    PROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   701
		    _qNew(newobj, instsize, SENDER);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   702
		    UNPROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   703
		    if (newobj == nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   704
			break;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   705
		    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   706
		    _InstPtr(newobj)->o_class = self;
369
claus
parents: 362
diff changeset
   707
		    __qSTORE(newobj, self);
claus
parents: 362
diff changeset
   708
357
claus
parents: 356
diff changeset
   709
#if defined(FAST_ARRAY_MEMSET4) || defined(FAST_MEMSET4)
claus
parents: 356
diff changeset
   710
		    nInstVars = (instsize-OHDR_SIZE) >> 2;
claus
parents: 356
diff changeset
   711
		    if (instsize & 3) nInstVars++;
claus
parents: 356
diff changeset
   712
		    memset4(_InstPtr(newobj)->i_instvars, 0, nInstVars);
claus
parents: 356
diff changeset
   713
#else
claus
parents: 356
diff changeset
   714
# if defined(FAST_ARRAY_MEMSET) && ! defined(NEGATIVE_ADDRESSES)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   715
		    /*
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   716
		     * knowing that nil is 0
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   717
		     */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   718
		    memset(_InstPtr(newobj)->i_instvars, 0, instsize-OHDR_SIZE);
357
claus
parents: 356
diff changeset
   719
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   720
		    op = _InstPtr(newobj)->i_instvars;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   721
		    while (nInstVars--)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   722
			*op++ = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   723
		    cp = (char *)op;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   724
		    while (nindexedinstvars >= sizeof(long)) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   725
			*(long *)cp = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   726
			cp += sizeof(long);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   727
			nindexedinstvars -= sizeof(long);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   728
		    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   729
		    while (nindexedinstvars--)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   730
			*cp++ = '\0';
357
claus
parents: 356
diff changeset
   731
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   732
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   733
		    RETURN ( newobj );
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   734
		    break;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   735
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   736
		case WORDARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   737
		    instsize = OHDR_SIZE + 
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   738
			       __OBJS2BYTES__(nInstVars) + 
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   739
			       nindexedinstvars * sizeof(short);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   740
		    PROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   741
		    _qNew(newobj, instsize, SENDER);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   742
		    UNPROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   743
		    if (newobj == nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   744
			break;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   745
		    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   746
		    _InstPtr(newobj)->o_class = self;
369
claus
parents: 362
diff changeset
   747
		    __qSTORE(newobj, self);
claus
parents: 362
diff changeset
   748
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   749
#if defined(FAST_ARRAY_MEMSET) && ! defined(NEGATIVE_ADDRESSES)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   750
		    /*
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   751
		     * knowing that nil is 0
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   752
		     */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   753
		    memset(_InstPtr(newobj)->i_instvars, 0, instsize - OHDR_SIZE);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   754
#else
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   755
		    op = _InstPtr(newobj)->i_instvars;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   756
		    while (nInstVars--)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   757
			*op++ = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   758
		    sp = (short *)op;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   759
		    while (nindexedinstvars--)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   760
			*sp++ = 0;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   761
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   762
		    RETURN ( newobj );
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   763
		    break;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   764
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   765
	       case LONGARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   766
		    instsize = OHDR_SIZE + 
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   767
			       __OBJS2BYTES__(nInstVars) + 
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   768
			       nindexedinstvars * sizeof(long);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   769
		    PROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   770
		    _qAlignedNew(newobj, instsize, SENDER);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   771
		    UNPROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   772
		    if (newobj == nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   773
			break;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   774
		    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   775
		    _InstPtr(newobj)->o_class = self;
369
claus
parents: 362
diff changeset
   776
		    __qSTORE(newobj, self);
claus
parents: 362
diff changeset
   777
357
claus
parents: 356
diff changeset
   778
#if defined(FAST_ARRAY_MEMSET4) || defined(FAST_MEMSET4)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   779
		    /*
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   780
		     * knowing that nil is 0
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   781
		     */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   782
		    memset4(_InstPtr(newobj)->i_instvars, 0, nInstVars + nindexedinstvars);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   783
#else
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   784
# if defined(FAST_ARRAY_MEMSET) && ! defined(NEGATIVE_ADDRESSES)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   785
		    /*
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   786
		     * knowing that nil is 0
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   787
		     */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   788
		    memset(_InstPtr(newobj)->i_instvars, 0, instsize - OHDR_SIZE);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   789
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   790
		    op = _InstPtr(newobj)->i_instvars;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   791
		    while (nInstVars--)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   792
			*op++ = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   793
		    lp = (long *)op;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   794
		    while (nindexedinstvars--)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   795
			*lp++ = 0;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   796
# endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   797
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   798
		    RETURN ( newobj );
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   799
		    break;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   800
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   801
	       case FLOATARRAY:
325
claus
parents: 323
diff changeset
   802
		    instsize = sizeof(struct __floatArray) + 
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   803
			       __OBJS2BYTES__(nInstVars) + 
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   804
			       (nindexedinstvars - 1) * sizeof(float);
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 47
diff changeset
   805
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   806
		    PROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   807
		    _qNew(newobj, instsize, SENDER);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   808
		    UNPROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   809
		    if (newobj == nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   810
			break;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   811
		    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   812
		    _InstPtr(newobj)->o_class = self;
369
claus
parents: 362
diff changeset
   813
		    __qSTORE(newobj, self);
claus
parents: 362
diff changeset
   814
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   815
		    op = _InstPtr(newobj)->i_instvars;
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   816
# if defined(mips) /* knowin that float 0.0 is all-zeros */
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   817
		    memset(_InstPtr(newobj)->i_instvars, 0, instsize - OHDR_SIZE);
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   818
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   819
		    while (nInstVars--)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   820
			*op++ = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   821
		    fp = (float *)op;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   822
		    while (nindexedinstvars--)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   823
			*fp++ = 0.0;
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   824
# endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   825
		    RETURN ( newobj );
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   826
		    break;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   827
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   828
	       case DOUBLEARRAY:
325
claus
parents: 323
diff changeset
   829
		    instsize = sizeof(struct __doubleArray) + 
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   830
			       __OBJS2BYTES__(nInstVars) + 
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   831
			       (nindexedinstvars - 1) * sizeof(double);
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 47
diff changeset
   832
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   833
		    PROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   834
		    _qAlignedNew(newobj, instsize, SENDER);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   835
		    UNPROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   836
		    if (newobj == nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   837
			break;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   838
		    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   839
		    _InstPtr(newobj)->o_class = self;
369
claus
parents: 362
diff changeset
   840
		    __qSTORE(newobj, self);
claus
parents: 362
diff changeset
   841
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   842
		    op = _InstPtr(newobj)->i_instvars;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   843
		    while (nInstVars--)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   844
			*op++ = nil;
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 47
diff changeset
   845
#ifdef NEED_DOUBLE_ALIGN
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   846
		    /*
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   847
		     * care for double alignment
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   848
		     */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   849
		    if ((INT)op & (ALIGN-1)) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   850
			*op++ = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   851
		    }
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 47
diff changeset
   852
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   853
		    dp = (double *)op;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   854
		    while (nindexedinstvars--)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   855
			*dp++ = 0.0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   856
		    RETURN ( newobj );
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   857
		    break;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   858
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   859
		case WKPOINTERARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   860
		case POINTERARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   861
		    nInstVars += nindexedinstvars;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   862
		    instsize = OHDR_SIZE + __OBJS2BYTES__(nInstVars);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   863
		    PROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   864
		    _qAlignedNew(newobj, instsize, SENDER);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   865
		    UNPROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   866
		    if (newobj == nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   867
			break;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   868
		    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   869
		    _InstPtr(newobj)->o_class = self;
369
claus
parents: 362
diff changeset
   870
		    __qSTORE(newobj, self);
claus
parents: 362
diff changeset
   871
357
claus
parents: 356
diff changeset
   872
#if defined(FAST_ARRAY_MEMSET4) || defined(FAST_MEMSET4)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   873
		    memset4(_InstPtr(newobj)->i_instvars, nil, nInstVars);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   874
#else
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   875
# if !defined(NEGATIVE_ADDRESSES)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   876
		    /*
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   877
		     * knowing that nil is 0
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   878
		     */
360
claus
parents: 359
diff changeset
   879
#ifdef XXmips
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   880
# undef FAST_ARRAY_MEMSET_DOUBLES_UNROLLED
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   881
# undef FAST_ARRAY_MEMSET_LONGLONG_UNROLLED
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
   882
/* seems to be slightly faster */
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   883
# define FAST_ARRAY_MEMSET
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   884
#endif
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   885
#ifdef sparc
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   886
# define FAST_ARRAY_MEMSET_DOUBLES_UNROLLED
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   887
#endif
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
   888
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   889
#  if defined(FAST_ARRAY_MEMSET_DOUBLES_UNROLLED)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   890
		    op = _InstPtr(newobj)->i_instvars;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   891
		    if (nInstVars > 8) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   892
			*op++ = nil;    /* for alignment */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   893
			nInstVars--;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   894
			while (nInstVars >= 8) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   895
			    *(double *)op = 0.0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   896
			    ((double *)op)[1] = 0.0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   897
			    ((double *)op)[2] = 0.0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   898
			    ((double *)op)[3] = 0.0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   899
			    op += 8;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   900
			    nInstVars -= 8;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   901
			}
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   902
		    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   903
		    while (nInstVars) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   904
			*op++ = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   905
			nInstVars--;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   906
		    }
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   907
#  else
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   908
#   if defined(FAST_ARRAY_MEMSET_LONGLONG_UNROLLED)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   909
		    op = _InstPtr(newobj)->i_instvars;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   910
		    if (nInstVars > 8) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   911
			*op++ = nil;    /* for alignment */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   912
			nInstVars--;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   913
			while (nInstVars >= 8) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   914
			    *(long long *)op = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   915
			    ((long long *)op)[1] = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   916
			    ((long long *)op)[2] = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   917
			    ((long long *)op)[3] = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   918
			    op += 8;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   919
			    nInstVars -= 8;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   920
			}
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   921
		    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   922
		    while (nInstVars) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   923
			*op++ = 0;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   924
			nInstVars--;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   925
		    }
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   926
#   else
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   927
#    if defined(FAST_ARRAY_MEMSET)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   928
		    memset(_InstPtr(newobj)->i_instvars, 0, instsize - OHDR_SIZE);
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   929
#    else
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   930
		    op = _InstPtr(newobj)->i_instvars;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   931
		    while (nInstVars--)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   932
			*op++ = nil;
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
   933
#    endif
82
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   934
#   endif
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   935
#  endif
0147b4f725ae *** empty log message ***
claus
parents: 81
diff changeset
   936
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   937
		    op = _InstPtr(newobj)->i_instvars;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   938
		    while (nInstVars--)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   939
			*op++ = nil;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   940
# endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   941
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   942
		    RETURN ( newobj );
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   943
		    break;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   944
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   945
		default:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   946
		    /*
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   947
		     * new:n for non-variable classes only allowed if
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   948
		     * n == 0
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   949
		     */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   950
		    if (nindexedinstvars == 0) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   951
			instsize = OHDR_SIZE + __OBJS2BYTES__(nInstVars);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   952
			PROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   953
			_qAlignedNew(newobj, instsize, SENDER);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   954
			UNPROTECT_CONTEXT
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   955
			if (newobj == nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   956
			    break;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   957
			}
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   958
			_InstPtr(newobj)->o_class = self;
369
claus
parents: 362
diff changeset
   959
			__qSTORE(newobj, self);
claus
parents: 362
diff changeset
   960
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   961
			if (nInstVars) {
357
claus
parents: 356
diff changeset
   962
#if defined(FAST_OBJECT_MEMSET4) || defined(FAST_MEMSET4)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   963
			    memset4(_InstPtr(newobj)->i_instvars, nil, nInstVars);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   964
#else
a27a279701f8 Initial revision
claus
parents:
diff changeset
   965
# if defined(FAST_MEMSET) && ! defined(NEGATIVE_ADDRESSES)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   966
			    /*
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   967
			     * knowing that nil is 0
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   968
			     */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   969
			    memset(_InstPtr(newobj)->i_instvars, 0, instsize - OHDR_SIZE);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   970
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   971
			    op = _InstPtr(newobj)->i_instvars;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   972
			    do {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   973
				*op++ = nil;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   974
			    } while (--nInstVars);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   975
# endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   976
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   977
			}
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   978
			RETURN ( newobj );
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   979
		    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   980
		    break;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   981
	    }
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   982
	}
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   983
    }
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   984
%}.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   985
    "
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   986
     arrive here if something went wrong ...
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   987
     figure out what it was
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   988
    "
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   989
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   990
    (anInteger isMemberOf:SmallInteger) ifFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   991
	"
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   992
	 the argument is either not an integer,
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   993
	 or a LargeInteger (which means that its definitely too big)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   994
	"
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   995
	self error:'argument to new: must be Integer'.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   996
	^ nil
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   997
    ].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
   998
    (anInteger < 0) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
   999
	"
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1000
	 the argument is negative,
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1001
	"
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1002
	self error:'bad (negative) argument to new:'.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1003
	^ nil
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1004
    ].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1005
    self isVariable ifFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1006
	"
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1007
	 this class does not have any indexed instance variables
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1008
	"
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1009
	self error:'class has no indexed instvars - cannot create with new:'.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1010
	^ nil
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1011
    ].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1012
    "
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1013
     memory allocation failed.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1014
     When we arrive here, there was no memory, even after
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
  1015
     a garbage collect. 
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
  1016
     This means, that the VM wanted to get some more memory from the 
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
  1017
     Operatingsystem, which was not kind enough to give it.
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
  1018
     Bad luck - you should increase the swap space on your machine.
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1019
    "
127
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1020
    ^ ObjectMemory allocationFailureSignal raise.
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1021
!
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1022
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1023
readFrom:aStream
43
00ca34676cbf *** empty log message ***
claus
parents: 25
diff changeset
  1024
    "read an objects printed representation from the argument, aStream 
00ca34676cbf *** empty log message ***
claus
parents: 25
diff changeset
  1025
     and return it. 
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1026
     The read object must be a kind of myself if its not, an error is raised.
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1027
     This is the reverse operation to 'storeOn:'.
43
00ca34676cbf *** empty log message ***
claus
parents: 25
diff changeset
  1028
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1029
     WARNING: storeOn: does not handle circular references and multiple 
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1030
	      references to the same object.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1031
	      Use #storeBinary:/readBinaryFrom: for this."
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1032
345
claus
parents: 343
diff changeset
  1033
    ^ self readFrom:aStream onError:[self error:'expected: ' , self name]
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1034
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1035
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1036
     |s|
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1037
     s := WriteStream on:String new.
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1038
     #(1 2 3 4) storeOn:s.
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1039
     Object readFrom:(ReadStream on:s contents)  
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1040
    "
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1041
!
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1042
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1043
readFrom:aStream onError:exceptionBlock
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1044
    "read an objects printed representation from the argument, aStream 
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1045
     and return it (i.e. the stream should contain some representation of
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1046
     the object which was created using #storeOn:). 
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1047
     The read object must be a kind of myself if its not, the value of
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1048
     exceptionBlock is returned.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1049
     To get any object, use 'Object readFrom:...',
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1050
     To get any number, use 'Number readFrom:...' and so on.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1051
     This is the reverse operation to 'storeOn:'.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1052
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1053
     WARNING: storeOn: does not handle circular references and multiple 
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1054
	      references to the same object.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1055
	      Use #storeBinary:/readBinaryFrom: for this."
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1056
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1057
    |newObject|
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1058
340
claus
parents: 331
diff changeset
  1059
    ErrorSignal handle:[:ex |
claus
parents: 331
diff changeset
  1060
	ex return
claus
parents: 331
diff changeset
  1061
    ] do:[
345
claus
parents: 343
diff changeset
  1062
	newObject := self evaluatorClass evaluate:aStream.
340
claus
parents: 331
diff changeset
  1063
    ].
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1064
    (newObject isKindOf:self) ifFalse:[^ exceptionBlock value].
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1065
    ^ newObject
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1066
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1067
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1068
     |s|
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1069
     s := WriteStream on:String new.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1070
     #(1 2 3 4) storeOn:s.
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1071
     Transcript showCr:(
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1072
	Array readFrom:(ReadStream on:s contents) onError:'not an Array'
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1073
     )
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1074
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1075
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1076
     |s|
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1077
     s := WriteStream on:String new.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1078
     #[1 2 3 4] storeOn:s.
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1079
     Transcript showCr:(
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1080
	 Array readFrom:(ReadStream on:s contents) onError:'not an Array'
345
claus
parents: 343
diff changeset
  1081
     )
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1082
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1083
!
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1084
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1085
readFromString:aString
275
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
  1086
    "create an object from its printed representation.
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
  1087
     For most classes, the string is expected to be in a format created by
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
  1088
     storeOn: or storeString; however, some (Time, Date) expect a user
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
  1089
     readable string here.
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
  1090
     See comments in Behavior>>readFromString:onError:,
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
  1091
     Behavior>>readFrom: and Behavior>>readFrom:onError:"
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  1092
345
claus
parents: 343
diff changeset
  1093
    ^ self readFromString:aString onError:[self error:'expected: ' , self name]
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1094
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1095
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1096
     Integer readFromString:'12345678901234567890' 
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1097
     Point readFromString:'1@2'  
345
claus
parents: 343
diff changeset
  1098
     Point readFromString:'1'  
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1099
    "
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1100
!
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1101
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1102
readFromString:aString onError:exceptionBlock
275
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
  1103
    "create an object from its printed representation.
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
  1104
     Here, the string is expected to be in a format created by
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
  1105
     storeOn: or storeString; however, some classes (Time, Date) may redefine
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
  1106
     it to expect a user readable string here.
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1107
     See comments in Behavior>>readFrom: and Behavior>>readFrom:onError:"
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1108
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1109
    ^ self readFrom:(ReadStream on:aString) onError:exceptionBlock
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1110
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1111
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1112
     Integer readFromString:'12345678901234567890' 
275
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
  1113
     Integer readFromString:'abc' 
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
  1114
     Integer readFromString:'abc' onError:0
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1115
     Point readFromString:'1@2'  
345
claus
parents: 343
diff changeset
  1116
     Point readFromString:'0'   
275
a76029ddaa98 *** empty log message ***
claus
parents: 249
diff changeset
  1117
     Point readFromString:'0' onError:[0@0]  
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  1118
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1119
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1120
10
claus
parents: 5
diff changeset
  1121
!Behavior methodsFor:'autoload check'!
claus
parents: 5
diff changeset
  1122
claus
parents: 5
diff changeset
  1123
isLoaded
claus
parents: 5
diff changeset
  1124
    "return true, if the class has been loaded; 
claus
parents: 5
diff changeset
  1125
     redefined in Autoload; see comment there"
claus
parents: 5
diff changeset
  1126
claus
parents: 5
diff changeset
  1127
    ^ true
claus
parents: 5
diff changeset
  1128
!
claus
parents: 5
diff changeset
  1129
claus
parents: 5
diff changeset
  1130
autoload
claus
parents: 5
diff changeset
  1131
    "force autoloading - do nothing here; 
claus
parents: 5
diff changeset
  1132
     redefined in Autoload; see comment there"
claus
parents: 5
diff changeset
  1133
claus
parents: 5
diff changeset
  1134
    ^ self
claus
parents: 5
diff changeset
  1135
! !
claus
parents: 5
diff changeset
  1136
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1137
!Behavior methodsFor:'snapshots'!
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1138
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1139
preSnapshot
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1140
    "sent by ObjectMemory, before a snapshot is written.
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1141
     Nothing done here."
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1142
!
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1143
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1144
postSnapshot
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1145
    "sent by ObjectMemory, after a snapshot has been written.
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1146
     Nothing done here."
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1147
! !
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1148
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1149
!Behavior class methodsFor:'flag bit constants'!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1150
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1151
flagNotIndexed
356
claus
parents: 345
diff changeset
  1152
    "return the flag code for non-indexed instances.
claus
parents: 345
diff changeset
  1153
     You have to mask the flag value with indexMask when comparing
claus
parents: 345
diff changeset
  1154
     it with flagNotIndexed."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1155
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1156
    ^ 0
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1157
! 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1158
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1159
flagBytes
356
claus
parents: 345
diff changeset
  1160
    "return the flag code for byte-valued indexed instances.
claus
parents: 345
diff changeset
  1161
     You have to mask the flag value with indexMask when comparing
claus
parents: 345
diff changeset
  1162
     it with flagBytes."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1163
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1164
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1165
    /* this is defined as a primitive to get defines from stc.h */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1166
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1167
    RETURN ( _MKSMALLINT(BYTEARRAY) );
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1168
%}
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1169
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1170
     Behavior flagBytes    
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1171
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1172
! 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1173
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1174
flagWords
356
claus
parents: 345
diff changeset
  1175
    "return the flag code for word-valued indexed instances (i.e. 2-byte).
claus
parents: 345
diff changeset
  1176
     You have to mask the flag value with indexMask when comparing
claus
parents: 345
diff changeset
  1177
     it with flagWords."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1178
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1179
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1180
    /* this is defined as a primitive to get defines from stc.h */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1181
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1182
    RETURN ( _MKSMALLINT(WORDARRAY) );
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1183
%}
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1184
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1185
     Behavior flagWords    
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1186
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1187
! 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1188
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1189
flagLongs
356
claus
parents: 345
diff changeset
  1190
    "return the flag code for long-valued indexed instances (i.e. 4-byte).
claus
parents: 345
diff changeset
  1191
     You have to mask the flag value with indexMask when comparing
claus
parents: 345
diff changeset
  1192
     it with flagLongs."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1193
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1194
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1195
    /* this is defined as a primitive to get defines from stc.h */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1196
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1197
    RETURN ( _MKSMALLINT(LONGARRAY) );
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1198
%}
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1199
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1200
     Behavior flagLongs    
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1201
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1202
! 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1203
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1204
flagFloats
356
claus
parents: 345
diff changeset
  1205
    "return the flag code for float-valued indexed instances (i.e. 4-byte reals).
claus
parents: 345
diff changeset
  1206
     You have to mask the flag value with indexMask when comparing
claus
parents: 345
diff changeset
  1207
     it with flagFloats."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1208
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1209
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1210
    /* this is defined as a primitive to get defines from stc.h */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1211
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1212
    RETURN ( _MKSMALLINT(FLOATARRAY) );
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1213
%}
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1214
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1215
     Behavior flagFloats    
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1216
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1217
! 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1218
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1219
flagDoubles
356
claus
parents: 345
diff changeset
  1220
    "return the flag code for double-valued indexed instances (i.e. 8-byte reals).
claus
parents: 345
diff changeset
  1221
     You have to mask the flag value with indexMask when comparing
claus
parents: 345
diff changeset
  1222
     it with flagDoubles."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1223
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1224
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1225
    /* this is defined as a primitive to get defines from stc.h */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1226
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1227
    RETURN ( _MKSMALLINT(DOUBLEARRAY) );
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1228
%}
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1229
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1230
     Behavior flagDoubles    
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1231
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1232
! 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1233
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1234
flagPointers
356
claus
parents: 345
diff changeset
  1235
    "return the flag code for pointer indexed instances (i.e. Array of object).
claus
parents: 345
diff changeset
  1236
     You have to mask the flag value with indexMask when comparing
claus
parents: 345
diff changeset
  1237
     it with flagPointers."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1238
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1239
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1240
    /* this is defined as a primitive to get defines from stc.h */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1241
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1242
    RETURN ( _MKSMALLINT(POINTERARRAY) );
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1243
%}
293
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1244
    "
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1245
     Behavior flagPointers    
31df3850e98c *** empty log message ***
claus
parents: 283
diff changeset
  1246
    "
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1247
! 
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1248
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1249
flagWeakPointers
356
claus
parents: 345
diff changeset
  1250
    "return the flag code for weak pointer indexed instances (i.e. WeakArray).
claus
parents: 345
diff changeset
  1251
     You have to mask the flag value with indexMask when comparing
claus
parents: 345
diff changeset
  1252
     it with flagWeakPointers."
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1253
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1254
%{  /* NOCONTEXT */
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1255
    /* this is defined as a primitive to get defines from stc.h */
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1256
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1257
    RETURN ( _MKSMALLINT(WKPOINTERARRAY) );
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1258
%}
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1259
! 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1260
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1261
maskIndexType
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1262
    "return a mask to extract all index-type bits"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1263
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1264
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1265
    /* this is defined as a primitive to get defines from stc.h */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1266
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1267
    RETURN ( _MKSMALLINT(ARRAYMASK) );
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1268
%}
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1269
! 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1270
345
claus
parents: 343
diff changeset
  1271
flagBehavior
356
claus
parents: 345
diff changeset
  1272
    "return the flag code which marks Behavior-like instances.
claus
parents: 345
diff changeset
  1273
     You have to check this single bit in the flag value when
claus
parents: 345
diff changeset
  1274
     checking for behaviors."
345
claus
parents: 343
diff changeset
  1275
claus
parents: 343
diff changeset
  1276
%{  /* NOCONTEXT */
claus
parents: 343
diff changeset
  1277
    /* this is defined as a primitive to get defines from stc.h */
claus
parents: 343
diff changeset
  1278
claus
parents: 343
diff changeset
  1279
    RETURN ( _MKSMALLINT(BEHAVIOR_INSTS) );
claus
parents: 343
diff changeset
  1280
%}
356
claus
parents: 345
diff changeset
  1281
claus
parents: 345
diff changeset
  1282
    "consistency check:
claus
parents: 345
diff changeset
  1283
     all class-entries must be behaviors;
claus
parents: 345
diff changeset
  1284
     all behaviors must be flagged so (in its class's flags)
claus
parents: 345
diff changeset
  1285
     (otherwise, VM will bark)
claus
parents: 345
diff changeset
  1286
     all non-behaviors may not be flagged
claus
parents: 345
diff changeset
  1287
claus
parents: 345
diff changeset
  1288
     |bit|
claus
parents: 345
diff changeset
  1289
     bit := Class flagBehavior.
claus
parents: 345
diff changeset
  1290
claus
parents: 345
diff changeset
  1291
     ObjectMemory allObjectsDo:[:o|
claus
parents: 345
diff changeset
  1292
       o isBehavior ifTrue:[
claus
parents: 345
diff changeset
  1293
	 (o class flags bitTest:bit) ifFalse:[
claus
parents: 345
diff changeset
  1294
	     self halt
claus
parents: 345
diff changeset
  1295
	 ].
claus
parents: 345
diff changeset
  1296
       ] ifFalse:[
claus
parents: 345
diff changeset
  1297
	 (o class flags bitTest:bit) ifTrue:[
claus
parents: 345
diff changeset
  1298
	     self halt
claus
parents: 345
diff changeset
  1299
	 ].
claus
parents: 345
diff changeset
  1300
       ].
claus
parents: 345
diff changeset
  1301
       o class isBehavior ifFalse:[
claus
parents: 345
diff changeset
  1302
	 self halt
claus
parents: 345
diff changeset
  1303
       ] ifTrue:[
claus
parents: 345
diff changeset
  1304
	 (o class class flags bitTest:bit) ifFalse:[
claus
parents: 345
diff changeset
  1305
	     self halt
claus
parents: 345
diff changeset
  1306
	 ]
claus
parents: 345
diff changeset
  1307
       ]
claus
parents: 345
diff changeset
  1308
     ]
claus
parents: 345
diff changeset
  1309
    "
345
claus
parents: 343
diff changeset
  1310
! 
claus
parents: 343
diff changeset
  1311
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1312
flagBlock
356
claus
parents: 345
diff changeset
  1313
    "return the flag code which marks Block-like instances.
claus
parents: 345
diff changeset
  1314
     You have to check this single bit in the flag value when
claus
parents: 345
diff changeset
  1315
     checking for blocks."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1316
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1317
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1318
    /* this is defined as a primitive to get defines from stc.h */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1319
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1320
    RETURN ( _MKSMALLINT(BLOCK_INSTS) );
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1321
%}
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1322
! 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1323
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1324
flagMethod
356
claus
parents: 345
diff changeset
  1325
    "return the flag code which marks Method-like instances.
claus
parents: 345
diff changeset
  1326
     You have to check this single bit in the flag value when
claus
parents: 345
diff changeset
  1327
     checking for methods."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1328
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1329
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1330
    /* this is defined as a primitive to get defines from stc.h */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1331
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1332
    RETURN ( _MKSMALLINT(METHOD_INSTS) );
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1333
%}
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1334
! 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1335
357
claus
parents: 356
diff changeset
  1336
flagNonObjectInst
claus
parents: 356
diff changeset
  1337
    "return the flag code which marks instances which have a
362
claus
parents: 360
diff changeset
  1338
     non-object instance variable (in slot 1).
357
claus
parents: 356
diff changeset
  1339
     (these are ignored by the garbage collector)"
claus
parents: 356
diff changeset
  1340
claus
parents: 356
diff changeset
  1341
%{  /* NOCONTEXT */
claus
parents: 356
diff changeset
  1342
    /* this is defined as a primitive to get defines from stc.h */
claus
parents: 356
diff changeset
  1343
claus
parents: 356
diff changeset
  1344
    RETURN ( _MKSMALLINT(NONOBJECT_INSTS) );
claus
parents: 356
diff changeset
  1345
%}
claus
parents: 356
diff changeset
  1346
!
claus
parents: 356
diff changeset
  1347
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1348
flagContext
356
claus
parents: 345
diff changeset
  1349
    "return the flag code which marks Context-like instances.
claus
parents: 345
diff changeset
  1350
     You have to check this single bit in the flag value when
claus
parents: 345
diff changeset
  1351
     checking for contexts."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1352
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1353
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1354
    /* this is defined as a primitive to get defines from stc.h */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1355
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1356
    RETURN ( _MKSMALLINT(CONTEXT_INSTS) );
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1357
%}
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1358
! 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1359
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1360
flagBlockContext
356
claus
parents: 345
diff changeset
  1361
    "return the flag code which marks BlockContext-like instances.
claus
parents: 345
diff changeset
  1362
     You have to check this single bit in the flag value when
claus
parents: 345
diff changeset
  1363
     checking for blockContexts."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1364
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1365
%{  /* NOCONTEXT */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1366
    /* this is defined as a primitive to get defines from stc.h */
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1367
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1368
    RETURN ( _MKSMALLINT(BCONTEXT_INSTS) );
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1369
%}
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1370
! 
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1371
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1372
flagFloat
356
claus
parents: 345
diff changeset
  1373
    "return the flag code which marks Float-like instances.
claus
parents: 345
diff changeset
  1374
     You have to check this single bit in the flag value when
claus
parents: 345
diff changeset
  1375
     checking for floats."
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1376
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1377
%{  /* NOCONTEXT */
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1378
    /* this is defined as a primitive to get defines from stc.h */
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1379
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1380
    RETURN ( _MKSMALLINT(FLOAT_INSTS) );
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1381
%}
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1382
! 
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1383
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1384
flagSymbol
356
claus
parents: 345
diff changeset
  1385
    "return the flag code which marks Symbol-like instances.
claus
parents: 345
diff changeset
  1386
     You have to check this single bit in the flag value when
claus
parents: 345
diff changeset
  1387
     checking for symbols."
92
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1388
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1389
%{  /* NOCONTEXT */
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1390
    /* this is defined as a primitive to get defines from stc.h */
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1391
0c73b48551ac *** empty log message ***
claus
parents: 91
diff changeset
  1392
    RETURN ( _MKSMALLINT(SYMBOL_INSTS) );
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1393
%}
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1394
! !
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1395
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1396
!Behavior methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1397
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1398
name
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1399
    "although behaviors have no name, we return something
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1400
     useful here - there are many places (inspectors) where
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1401
     a classes name is asked for.
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1402
     Implementing this message here allows anonymous classes
151
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  1403
     and instances of them to be inspected."
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1404
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1405
    ^ 'someBehavior'
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1406
!
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1407
356
claus
parents: 345
diff changeset
  1408
displayString
claus
parents: 345
diff changeset
  1409
    "although behaviors have no name, we return something
claus
parents: 345
diff changeset
  1410
     useful here - there are many places (inspectors) where
claus
parents: 345
diff changeset
  1411
     a classes name is asked for.
claus
parents: 345
diff changeset
  1412
     Implementing this message here allows instances of anonymous classes
claus
parents: 345
diff changeset
  1413
     to show a reasonable name."
claus
parents: 345
diff changeset
  1414
claus
parents: 345
diff changeset
  1415
    ^ 'someBehavior'
claus
parents: 345
diff changeset
  1416
!
claus
parents: 345
diff changeset
  1417
claus
parents: 345
diff changeset
  1418
category
claus
parents: 345
diff changeset
  1419
    "return the category of the class. 
claus
parents: 345
diff changeset
  1420
     Returning nil here, since Behavior does not define a category
claus
parents: 345
diff changeset
  1421
     (only ClassDescriptions do)."
claus
parents: 345
diff changeset
  1422
claus
parents: 345
diff changeset
  1423
    ^ nil
claus
parents: 345
diff changeset
  1424
claus
parents: 345
diff changeset
  1425
    "
claus
parents: 345
diff changeset
  1426
     Point category                
claus
parents: 345
diff changeset
  1427
     Behavior new category           
claus
parents: 345
diff changeset
  1428
    "
claus
parents: 345
diff changeset
  1429
!
claus
parents: 345
diff changeset
  1430
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1431
superclass
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1432
    "return the receivers superclass"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1433
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1434
    ^ superclass
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1435
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1436
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1437
selectorArray 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1438
    "return the receivers selector array.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1439
     Notice: this is not compatible with ST-80."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1440
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1441
    ^ selectorArray
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1442
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1443
362
claus
parents: 360
diff changeset
  1444
selectors
claus
parents: 360
diff changeset
  1445
    "return the receivers selector array.
claus
parents: 360
diff changeset
  1446
     Notice: this may not compatible with ST-80.
claus
parents: 360
diff changeset
  1447
     (should we return a Set ?)"
claus
parents: 360
diff changeset
  1448
claus
parents: 360
diff changeset
  1449
    ^ selectorArray asOrderedCollection
claus
parents: 360
diff changeset
  1450
!
claus
parents: 360
diff changeset
  1451
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1452
methodArray
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1453
    "return the receivers method array.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1454
     Notice: this is not compatible with ST-80."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1455
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1456
    ^ methodArray
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1457
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1458
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1459
methodDictionary
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1460
    "return the receivers method dictionary. 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  1461
     Since no dictionary is actually present, create one for ST-80 compatibility."
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1462
345
claus
parents: 343
diff changeset
  1463
    |dict n "{ Class: SmallInteger }"|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1464
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1465
    dict := IdentityDictionary new.
345
claus
parents: 343
diff changeset
  1466
    n := selectorArray size.
claus
parents: 343
diff changeset
  1467
    1 to:n do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1468
	dict at:(selectorArray at:index) put:(methodArray at:index)
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1469
    ].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1470
    ^ dict
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1471
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1472
362
claus
parents: 360
diff changeset
  1473
implicit_methodDict 
claus
parents: 360
diff changeset
  1474
    "ST-80 compatibility.
claus
parents: 360
diff changeset
  1475
     This allows subclasses to assume there is an instance variable
claus
parents: 360
diff changeset
  1476
     named methodDict."
claus
parents: 360
diff changeset
  1477
claus
parents: 360
diff changeset
  1478
    ^ self methodDictionary
claus
parents: 360
diff changeset
  1479
!
claus
parents: 360
diff changeset
  1480
claus
parents: 360
diff changeset
  1481
implicit_methodDict:aDictionary 
claus
parents: 360
diff changeset
  1482
    "ST-80 compatibility.
claus
parents: 360
diff changeset
  1483
     This allows subclasses to assume there is an instance variable
claus
parents: 360
diff changeset
  1484
     named methodDict."
claus
parents: 360
diff changeset
  1485
claus
parents: 360
diff changeset
  1486
    ^ self error:'not allowed to set the methodDictionary'
claus
parents: 360
diff changeset
  1487
!
claus
parents: 360
diff changeset
  1488
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1489
instSize
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1490
    "return the number of instance variables of the receiver.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1491
     This includes all superclass instance variables."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1492
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1493
    ^ instSize
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1494
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1495
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1496
flags
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1497
    "return the receivers flag bits"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1498
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1499
    ^ flags
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1500
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1501
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1502
superclass:aClass
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1503
    "set the superclass - this actually creates a new class,
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1504
     recompiling all methods for the new one. The receiving class stays
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1505
     around anonymous to allow existing instances some life.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1506
     This may change in the future (adjusting existing instances)"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1507
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  1508
    SubclassInfo := nil.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  1509
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1510
    "must flush caches since lookup chain changes"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1511
    ObjectMemory flushCaches.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1512
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1513
"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1514
    superclass := aClass
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1515
"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1516
    "for correct recompilation, just create a new class ..."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1517
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1518
    aClass subclass:(self name)
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1519
	   instanceVariableNames:(self instanceVariableString)
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1520
	   classVariableNames:(self classVariableString)
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1521
	   poolDictionaries:''
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1522
	   category:self category
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1523
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1524
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1525
addSuperclass:aClass
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1526
    "EXPERIMENTAL MI support: add aClass to the set of classes, from which instances
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1527
     inherit protocol."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1528
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1529
    "first, check if the class is abstract - 
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1530
     allows abstract mixins are allowed in the current implementation"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1531
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1532
    aClass instSize == 0 ifFalse:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1533
	self error:'only abstract mixins allowed'.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1534
	^ self
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1535
    ].
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1536
    otherSuperclasses isNil ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1537
	otherSuperclasses := Array with:aClass
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1538
    ] ifFalse:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1539
	otherSuperclasses := otherSuperclasses copyWith:aClass
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1540
    ].
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  1541
    SubclassInfo := nil.
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1542
    ObjectMemory flushCaches
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1543
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1544
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1545
removeSuperclass:aClass
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1546
    "EXPERIMENTAL MI support: remove aClass from the set of classes, from which instances
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1547
     inherit protocol."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1548
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1549
    otherSuperclasses notNil ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1550
	otherSuperclasses := otherSuperclasses copyWithout:aClass.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1551
	otherSuperclasses isEmpty ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1552
	    otherSuperclasses := nil
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1553
	].
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  1554
	SubclassInfo := nil.
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1555
	ObjectMemory flushCaches
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1556
    ].
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1557
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1558
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1559
selectors:newSelectors methods:newMethods
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1560
    "set both selector array and method array of the receiver,
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1561
     and flush caches"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1562
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1563
    ObjectMemory flushCaches.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1564
    selectorArray := newSelectors.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1565
    methodArray := newMethods
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1566
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1567
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1568
addSelector:newSelector withMethod:newMethod
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1569
    "add the method given by 2nd argument under the selector given by
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1570
     1st argument to the methodDictionary. Flush all caches."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1571
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1572
    |nargs|
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1573
249
claus
parents: 216
diff changeset
  1574
    (self primAddSelector:newSelector withMethod:newMethod) ifFalse:[^ false].
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1575
    self changed:#methodDictionary with:newSelector.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1576
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1577
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1578
     if I have no subclasses, all we have to flush is cached
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1579
     data for myself ... (actually, in any case all that needs
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1580
     to be flushed is info for myself and all of my subclasses)
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1581
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1582
"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1583
    problem: this is slower; since looking for all subclasses is (currently)
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1584
	     a bit slow :-(
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1585
	     We need the hasSubclasses-info bit in Behavior; now
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1586
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1587
    self withAllSubclassesDo:[:aClass |
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1588
	ObjectMemory flushInlineCachesFor:aClass withArgs:nargs.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1589
	ObjectMemory flushMethodCacheFor:aClass
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1590
    ].
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1591
"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1592
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1593
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1594
     actually, we would do better with less flushing ...
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1595
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1596
    nargs := newSelector numArgs.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1597
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1598
    ObjectMemory flushMethodCache.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1599
    ObjectMemory flushInlineCachesWithArgs:nargs.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1600
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1601
    ^ true
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1602
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1603
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1604
addSelector:newSelector withLazyMethod:newMethod
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1605
    "add the method given by 2nd argument under the selector given by
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1606
     1st argument to the methodDictionary. Since it does not flush
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1607
     any caches, this is only allowed for lazy methods."
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1608
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1609
    newMethod isLazyMethod ifFalse:[
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1610
	self error:'operation only allowed for lazy methods'.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1611
	^ false
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1612
    ].
362
claus
parents: 360
diff changeset
  1613
    "/ oops: we must flush, if this method already exists ...
claus
parents: 360
diff changeset
  1614
    (selectorArray includes:newSelector) ifTrue:[
claus
parents: 360
diff changeset
  1615
	ObjectMemory flushCaches
claus
parents: 360
diff changeset
  1616
    ].
249
claus
parents: 216
diff changeset
  1617
    (self primAddSelector:newSelector withMethod:newMethod) ifTrue:[
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1618
	self changed:#methodDictionary with:newSelector.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1619
	^ true
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1620
    ].
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1621
    ^ false
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1622
!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1623
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1624
removeSelector:aSelector
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1625
    "remove the selector, aSelector and its associated method 
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1626
     from the methodDictionary"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1627
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1628
    |index oldSelectorArray oldMethodArray newSelectorArray newMethodArray|
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1629
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1630
    index := selectorArray identityIndexOf:aSelector startingAt:1.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1631
    (index == 0) ifTrue:[^ false].
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1632
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1633
    newSelectorArray := selectorArray copyWithoutIndex:index.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1634
    newMethodArray := methodArray copyWithoutIndex:index.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1635
    oldSelectorArray := selectorArray.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1636
    oldMethodArray := methodArray.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1637
    selectorArray := newSelectorArray.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1638
    methodArray := newMethodArray.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1639
"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1640
    [
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1641
	|nargs|
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1642
	nargs := aSelector numArgs.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1643
	ObjectMemory flushMethodCache.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1644
	ObjectMemory flushInlineCachesWithArgs:nargs.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1645
    ] value
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1646
"
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1647
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1648
     actually, we would do better with less flushing ...
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1649
    "
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1650
    ObjectMemory flushCaches.
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1651
    ^ true
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1652
! !
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1653
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1654
!Behavior methodsFor:'queries'!
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1655
127
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1656
sizeOfInst:n
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1657
    "return the number of bytes required for an instance of
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1658
     myself with n indexed instance variables. The argument n 
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1659
     should be zero for classes without indexed instance variables.
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1660
     See Behavior>>niceNew: for an application of this."
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  1661
127
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1662
    |nInstvars|
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1663
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1664
    nInstvars := self instSize.
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1665
%{
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1666
    int nBytes;
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1667
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1668
    nBytes = _intVal(nInstvars) * sizeof(OBJ) + OHDR_SIZE; 
249
claus
parents: 216
diff changeset
  1669
    if (__isSmallInteger(n)) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1670
	int nIndex;
127
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1671
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1672
	nIndex = _intVal(n);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1673
	switch (_intVal(_INST(flags)) & ARRAYMASK) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1674
	    case BYTEARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1675
		nBytes += nIndex;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1676
		if (nBytes & (ALIGN - 1)) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1677
		    nBytes = (nBytes & ~(ALIGN - 1)) + ALIGN;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1678
		}
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1679
		break;
127
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1680
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1681
	    case WORDARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1682
		nBytes += nIndex * sizeof(short);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1683
		if (nBytes & (ALIGN - 1)) {
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1684
		    nBytes = (nBytes & ~(ALIGN - 1)) + ALIGN;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1685
		}
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1686
		break;
127
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1687
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1688
	    case LONGARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1689
		nBytes += nIndex * sizeof(long);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1690
		break;
127
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1691
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1692
	    case FLOATARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1693
		nBytes += nIndex * sizeof(float);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1694
		break;
127
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1695
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1696
	    case DOUBLEARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1697
		nBytes += nIndex * sizeof(double);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1698
		break;
127
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1699
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1700
	    default:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1701
		nBytes += nIndex * sizeof(OBJ);
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1702
		break;
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1703
	}
127
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1704
    }
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1705
    RETURN (_MKSMALLINT(nBytes));
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1706
%}
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1707
!
6625c77d890f added sizeOfInst:
claus
parents: 92
diff changeset
  1708
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1709
isVariable
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1710
    "return true, if instances have indexed instance variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1711
362
claus
parents: 360
diff changeset
  1712
    "this could also be defined as:
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1713
	^ (flags bitAnd:(Behavior maskIndexType)) ~~ 0
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1714
     "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1715
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1716
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1717
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1718
    RETURN ( (_intVal(_INST(flags)) & ARRAYMASK) ? true : false ); 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1719
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1720
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1721
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1722
isFixed
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1723
    "return true, if instances do not have indexed instance variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1724
362
claus
parents: 360
diff changeset
  1725
    "this could also be defined as:
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1726
	^ self isVariable not
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1727
    "
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1728
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1729
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1730
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1731
    RETURN ( (_intVal(_INST(flags)) & ARRAYMASK) ? false : true ); 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1732
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1733
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1734
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1735
isBits
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1736
    "return true, if instances have indexed byte or short instance variables.
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1737
     Ignore long, float and double arrays, since ST-80 code using isBits are probably
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1738
     not prepared to handle them correctly."
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1739
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1740
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1741
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1742
    REGISTER int flags;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1743
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1744
    RETURN ( (((flags = (_intVal(_INST(flags)) & ARRAYMASK)) == BYTEARRAY)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1745
	     || (flags == WORDARRAY)) ? true : false ); 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1746
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1747
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1748
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1749
isBytes
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1750
    "return true, if instances have indexed byte instance variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1751
362
claus
parents: 360
diff changeset
  1752
    "this could also be defined as:
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1753
	^ (flags bitAnd:(Behavior maskIndexType)) == Behavior flagBytes
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1754
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1755
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1756
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1757
    RETURN ( ((_intVal(_INST(flags)) & ARRAYMASK) == BYTEARRAY) ? true : false ); 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1758
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1759
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1760
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1761
isWords
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1762
    "return true, if instances have indexed short instance variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1763
362
claus
parents: 360
diff changeset
  1764
    "this could also be defined as:
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1765
	^ (flags bitAnd:(Behavior maskIndexType)) == Behavior flagWords
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1766
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1767
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1768
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1769
    RETURN ( ((_intVal(_INST(flags)) & ARRAYMASK) == WORDARRAY) ? true : false ); 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1770
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1771
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1772
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1773
isLongs
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1774
    "return true, if instances have indexed long instance variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1775
362
claus
parents: 360
diff changeset
  1776
    "this could also be defined as:
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1777
	^ (flags bitAnd:(Behavior maskIndexType)) == Behavior flagLongs
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1778
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1779
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1780
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1781
    RETURN ( ((_intVal(_INST(flags)) & ARRAYMASK) == LONGARRAY) ? true : false ); 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1782
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1783
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1784
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1785
isFloats
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1786
    "return true, if instances have indexed float instance variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1787
362
claus
parents: 360
diff changeset
  1788
    "this could also be defined as:
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1789
	^ (flags bitAnd:(Behavior maskIndexType)) == Behavior flagFloats
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1790
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1791
%{  /* NOCONTEXT */
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1792
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1793
    RETURN ( ((_intVal(_INST(flags)) & ARRAYMASK) == FLOATARRAY) ? true : false ); 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1794
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1795
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1796
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1797
isDoubles
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1798
    "return true, if instances have indexed double instance variables"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1799
362
claus
parents: 360
diff changeset
  1800
    "this could also be defined as:
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1801
	^ (flags bitAnd:(Behavior maskIndexType)) == Behavior flagDoubles
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1802
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1803
%{  /* NOCONTEXT */
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1804
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1805
    RETURN ( ((_intVal(_INST(flags)) & ARRAYMASK) == DOUBLEARRAY) ? true : false ); 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1806
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1807
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1808
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1809
isPointers
2
claus
parents: 1
diff changeset
  1810
    "return true, if instances have pointer instance variables 
claus
parents: 1
diff changeset
  1811
     i.e. are either non-indexed or have indexed pointer variables"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1812
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1813
    "QUESTION: should we ignore WeakPointers ?"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1814
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1815
%{  /* NOCONTEXT */
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1816
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1817
    REGISTER int flags;
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1818
2
claus
parents: 1
diff changeset
  1819
    flags = _intVal(_INST(flags)) & ARRAYMASK;
claus
parents: 1
diff changeset
  1820
    switch (flags) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1821
	default:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1822
	    /* normal objects */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1823
	    RETURN ( true );
2
claus
parents: 1
diff changeset
  1824
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1825
	case BYTEARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1826
	case WORDARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1827
	case LONGARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1828
	case FLOATARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1829
	case DOUBLEARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1830
	    RETURN (false );
2
claus
parents: 1
diff changeset
  1831
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1832
	case WKPOINTERARRAY:
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1833
	    /* what about those ? */
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1834
	    RETURN (true );
2
claus
parents: 1
diff changeset
  1835
    }
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1836
%}
2
claus
parents: 1
diff changeset
  1837
!
claus
parents: 1
diff changeset
  1838
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1839
isBehavior
47
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
  1840
    "return true, if the receiver is describing another objects behavior,
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1841
     i.e. is a class. Defined to avoid the need to use isKindOf:"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1842
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1843
    ^ true
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1844
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1845
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1846
     True isBehavior   
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1847
     true isBehavior
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1848
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1849
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1850
47
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
  1851
canBeSubclassed
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
  1852
    "return true, if its allowed to create subclasses of the receiver.
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
  1853
     This method is redefined in SmallInteger and UndefinedObject, since
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1854
     instances are detected by their pointer-fields, i.e. they do not have
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1855
     a class entry (you dont have to understand this :-)"
47
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
  1856
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
  1857
    ^ true
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
  1858
!
93f17a1b452c *** empty log message ***
claus
parents: 45
diff changeset
  1859
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1860
hasMultipleSuperclasses
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1861
    "Return true, if this class inherits from other classes 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1862
     (beside its primary superclass). 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1863
     This method is a preparation for a future multiple inheritance extension 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1864
     - currently it is not supported by the VM"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1865
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1866
    ^ otherSuperclasses notNil
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1867
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1868
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1869
superclasses
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1870
    "return a collection of the receivers immediate superclasses.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1871
     This method is a preparation for a future multiple inheritance extension 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1872
     - currently it is not supported by the VM"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1873
345
claus
parents: 343
diff changeset
  1874
    |a|
claus
parents: 343
diff changeset
  1875
claus
parents: 343
diff changeset
  1876
    a := Array with:superclass.
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1877
    otherSuperclasses notNil ifTrue:[
345
claus
parents: 343
diff changeset
  1878
	^ a , otherSuperclasses
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  1879
    ].
345
claus
parents: 343
diff changeset
  1880
    ^ a
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1881
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1882
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1883
     String superclasses  
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1884
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1885
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1886
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1887
allSuperclasses
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1888
    "return a collection of the receivers accumulated superclasses"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1889
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1890
    |aCollection theSuperClass|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1891
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1892
    theSuperClass := superclass.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1893
    theSuperClass notNil ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1894
	aCollection := OrderedCollection new.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1895
	[theSuperClass notNil] whileTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1896
	    aCollection add:theSuperClass.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1897
	    theSuperClass := theSuperClass superclass
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1898
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1899
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1900
    ^ aCollection
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1901
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1902
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1903
     String allSuperclasses 
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1904
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1905
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1906
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1907
withAllSuperclasses
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1908
    "return a collection containing the receiver and all
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1909
     of the receivers accumulated superclasses"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1910
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1911
    |aCollection theSuperClass|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1912
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1913
    aCollection := OrderedCollection with:self.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1914
    theSuperClass := superclass.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1915
    [theSuperClass notNil] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1916
	aCollection add:theSuperClass.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1917
	theSuperClass := theSuperClass superclass
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1918
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1919
    ^ aCollection
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1920
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1921
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1922
     String withAllSuperclasses 
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1923
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1924
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1925
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1926
subclasses
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1927
    "return a collection of the direct subclasses of the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1928
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1929
    |newColl|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1930
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  1931
    SubclassInfo notNil ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  1932
	newColl := SubclassInfo at:self ifAbsent:nil.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  1933
	newColl notNil ifTrue:[^ newColl asOrderedCollection]
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  1934
    ].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  1935
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1936
    newColl := OrderedCollection new.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1937
    self subclassesDo:[:aClass |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1938
	newColl add:aClass
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1939
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1940
    ^ newColl
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1941
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1942
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1943
     Collection subclasses
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1944
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1945
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1946
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1947
allSubclasses
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1948
    "return a collection of all subclasses (direct AND indirect) of
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1949
     the receiver. There will be no specific order, in which entries
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1950
     are returned."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1951
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1952
    |newColl|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1953
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1954
    newColl := OrderedCollection new.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1955
    self allSubclassesDo:[:aClass |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1956
	newColl add:aClass
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1957
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1958
    ^ newColl
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1959
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1960
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1961
     Collection allSubclasses
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1962
    "
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1963
!
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1964
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1965
allSubclassesInOrder
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1966
    "return a collection of all subclasses (direct AND indirect) of
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1967
     the receiver. Higher level subclasses will come before lower ones."
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1968
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1969
    |newColl|
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1970
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1971
    newColl := OrderedCollection new.
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1972
    self allSubclassesInOrderDo:[:aClass |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1973
	newColl add:aClass
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1974
    ].
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1975
    ^ newColl
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1976
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1977
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1978
     Collection allSubclassesInOrder
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1979
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1980
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1981
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1982
withAllSubclasses
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1983
    "return a collection containing the receiver and 
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1984
     all subclasses (direct AND indirect) of the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1985
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1986
    |newColl|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1987
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1988
    newColl := OrderedCollection with:self.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1989
    self allSubclassesDo:[:aClass |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  1990
	newColl add:aClass
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1991
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1992
    ^ newColl
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  1993
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1994
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1995
     Collection withAllSubclasses
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  1996
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1997
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1998
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1999
isSubclassOf:aClass
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2000
    "return true, if I am a subclass of the argument, aClass"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2001
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2002
    |theClass|
2
claus
parents: 1
diff changeset
  2003
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2004
    theClass := superclass.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2005
    [theClass notNil] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2006
	(theClass == aClass) ifTrue:[^ true].
375
claus
parents: 369
diff changeset
  2007
%{
claus
parents: 369
diff changeset
  2008
	if (__isBehaviorLike(theClass)) {
claus
parents: 369
diff changeset
  2009
	    theClass = __ClassInstPtr(theClass)->c_superclass;
claus
parents: 369
diff changeset
  2010
	} else {
claus
parents: 369
diff changeset
  2011
	    theClass = nil;
claus
parents: 369
diff changeset
  2012
	}
claus
parents: 369
diff changeset
  2013
%}.
claus
parents: 369
diff changeset
  2014
"/        theClass := theClass superclass.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2015
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2016
    ^ false
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2017
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2018
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2019
     String isSubclassOf:Collection  
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2020
     LinkedList isSubclassOf:Array   
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2021
     1 isSubclassOf:Number              <- will fail since 1 is no class
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2022
    "     
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2023
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2024
151
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2025
allInstVarNames
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2026
    "return a collection of all the instance variable name-strings
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2027
     this includes all superclass-instance variables.
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2028
     Since Behavior has no idea of instvar-names, return an empty collection
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2029
     here. Redefined in ClassDescription."
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2030
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2031
    ^ #()
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2032
!
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2033
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2034
allClassVarNames
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2035
    "return a collection of all the class variable name-strings
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2036
     this includes all superclass-class variables.
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2037
     Since Behavior has no idea of classvar-names, return an empty collection
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2038
     here. Redefined in ClassDescription."
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2039
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2040
    ^ #()
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2041
!
07c448be12b6 *** empty log message ***
claus
parents: 127
diff changeset
  2042
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2043
allInstances
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2044
    "return a collection of all my instances"
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2045
362
claus
parents: 360
diff changeset
  2046
    "Read the documentation on why there seem to be no
claus
parents: 360
diff changeset
  2047
     instances of SmallInteger and UndefinedObject"
claus
parents: 360
diff changeset
  2048
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2049
    |coll|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2050
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
  2051
    coll := OrderedCollection new:100.
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2052
    self allInstancesDo:[:anObject |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2053
	coll add:anObject
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2054
    ].
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2055
    ^ coll 
25
e34a6267c79b *** empty log message ***
claus
parents: 11
diff changeset
  2056
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2057
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2058
     ScrollBar allInstances
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2059
    "
25
e34a6267c79b *** empty log message ***
claus
parents: 11
diff changeset
  2060
!
e34a6267c79b *** empty log message ***
claus
parents: 11
diff changeset
  2061
328
claus
parents: 325
diff changeset
  2062
allSubInstances
25
e34a6267c79b *** empty log message ***
claus
parents: 11
diff changeset
  2063
    "return a collection of all instances of myself and 
328
claus
parents: 325
diff changeset
  2064
     instances of all subclasses of myself."
25
e34a6267c79b *** empty log message ***
claus
parents: 11
diff changeset
  2065
e34a6267c79b *** empty log message ***
claus
parents: 11
diff changeset
  2066
    |coll|
e34a6267c79b *** empty log message ***
claus
parents: 11
diff changeset
  2067
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
  2068
    coll := OrderedCollection new:100.
331
claus
parents: 328
diff changeset
  2069
    self allSubInstancesDo:[:anObject |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2070
	(anObject isKindOf:self) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2071
	    coll add:anObject
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2072
	]
25
e34a6267c79b *** empty log message ***
claus
parents: 11
diff changeset
  2073
    ].
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2074
    ^ coll 
25
e34a6267c79b *** empty log message ***
claus
parents: 11
diff changeset
  2075
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2076
    "
328
claus
parents: 325
diff changeset
  2077
     View allSubInstances
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2078
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2079
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2080
328
claus
parents: 325
diff changeset
  2081
allDerivedInstances
claus
parents: 325
diff changeset
  2082
    "return a collection of all instances of myself and 
claus
parents: 325
diff changeset
  2083
     instances of all subclasses of myself.
claus
parents: 325
diff changeset
  2084
     This method is going to be removed for protocol compatibility with
claus
parents: 325
diff changeset
  2085
     other STs; use allSubInstances"
claus
parents: 325
diff changeset
  2086
345
claus
parents: 343
diff changeset
  2087
    self obsoleteMethodWarning:'please use #allSubInstances'.
328
claus
parents: 325
diff changeset
  2088
    ^ self allSubInstances
claus
parents: 325
diff changeset
  2089
!
claus
parents: 325
diff changeset
  2090
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2091
hasInstances
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2092
    "return true, if there are any instances of myself"
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2093
362
claus
parents: 360
diff changeset
  2094
    "Read the documentation on why there seem to be no
claus
parents: 360
diff changeset
  2095
     instances of SmallInteger and UndefinedObject"
claus
parents: 360
diff changeset
  2096
369
claus
parents: 362
diff changeset
  2097
"/    ObjectMemory allObjectsDo:[:anObject |
claus
parents: 362
diff changeset
  2098
"/        (anObject class == self) ifTrue:[
claus
parents: 362
diff changeset
  2099
"/            ^ true
claus
parents: 362
diff changeset
  2100
"/        ]
claus
parents: 362
diff changeset
  2101
"/    ].
claus
parents: 362
diff changeset
  2102
    ObjectMemory allInstancesOf:self do:[:anObject |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2103
	    ^ true
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2104
    ].
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2105
    ^ false
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2106
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2107
    "
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2108
     Object hasInstances
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2109
     SequenceableCollection hasInstances
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2110
     Float hasInstances
362
claus
parents: 360
diff changeset
  2111
     SmallInteger hasInstances
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2112
    "
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2113
!
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2114
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2115
instanceCount
362
claus
parents: 360
diff changeset
  2116
    "return the number of instances of myself."
claus
parents: 360
diff changeset
  2117
claus
parents: 360
diff changeset
  2118
    "Read the documentation on why there seem to be no
claus
parents: 360
diff changeset
  2119
     instances of SmallInteger and UndefinedObject"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2120
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2121
    |count|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2122
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2123
    count := 0.
369
claus
parents: 362
diff changeset
  2124
"/    ObjectMemory allObjectsDo:[:anObject |
claus
parents: 362
diff changeset
  2125
"/        (anObject class == self) ifTrue:[
claus
parents: 362
diff changeset
  2126
"/            count := count + 1
claus
parents: 362
diff changeset
  2127
"/        ]
claus
parents: 362
diff changeset
  2128
"/    ].
claus
parents: 362
diff changeset
  2129
    ObjectMemory allInstancesOf:self do:[:anObject |
claus
parents: 362
diff changeset
  2130
	count := count + 1
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2131
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2132
    ^ count
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2133
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2134
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2135
     View instanceCount
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2136
     Object instanceCount
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2137
     Float instanceCount
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2138
     SequenceableCollection instanceCount
362
claus
parents: 360
diff changeset
  2139
     SmallInteger instanceCount   .... mhmh - hear, hear
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2140
    "
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2141
!
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2142
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2143
derivedInstanceCount
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2144
    "return the number of instances of myself and of subclasses"
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2145
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2146
    |count|
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2147
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2148
    count := 0.
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2149
    ObjectMemory allObjectsDo:[:anObject |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2150
	(anObject isKindOf:self) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2151
	    count := count + 1
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2152
	]
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2153
    ].
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2154
    ^ count
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2155
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2156
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2157
     View derivedInstanceCount
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2158
     SequenceableCollection derivedInstanceCount
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2159
    "
2
claus
parents: 1
diff changeset
  2160
!
claus
parents: 1
diff changeset
  2161
claus
parents: 1
diff changeset
  2162
selectorIndex:aSelector
claus
parents: 1
diff changeset
  2163
    "return the index in the arrays for given selector aSelector"
claus
parents: 1
diff changeset
  2164
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2165
    ^ selectorArray identityIndexOf:aSelector startingAt:1
2
claus
parents: 1
diff changeset
  2166
!
claus
parents: 1
diff changeset
  2167
295
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  2168
includesSelector:aSelector
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  2169
    "for ST-80 compatibility"
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  2170
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  2171
    ^ self implements:aSelector
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  2172
!
14d0cf46c739 *** empty log message ***
claus
parents: 293
diff changeset
  2173
2
claus
parents: 1
diff changeset
  2174
compiledMethodAt:aSelector
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2175
    "return the method for given selector aSelector or nil.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2176
     Only methods in the receiver - not in the superclass chain are tested."
2
claus
parents: 1
diff changeset
  2177
claus
parents: 1
diff changeset
  2178
    |index|
claus
parents: 1
diff changeset
  2179
328
claus
parents: 325
diff changeset
  2180
    selectorArray isNil ifTrue:[
claus
parents: 325
diff changeset
  2181
	('oops: nil selectorArray in ' , self name) errorPrintNL.
claus
parents: 325
diff changeset
  2182
	^ nil
claus
parents: 325
diff changeset
  2183
    ].
claus
parents: 325
diff changeset
  2184
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2185
    index := selectorArray identityIndexOf:aSelector startingAt:1.
2
claus
parents: 1
diff changeset
  2186
    (index == 0) ifTrue:[^ nil].
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2187
    ^ methodArray at:index
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2188
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2189
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2190
     Object compiledMethodAt:#==
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2191
     (Object compiledMethodAt:#==) category
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2192
    "
2
claus
parents: 1
diff changeset
  2193
!
claus
parents: 1
diff changeset
  2194
claus
parents: 1
diff changeset
  2195
sourceCodeAt:aSelector
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2196
    "return the methods source for given selector aSelector or nil.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2197
     Only methods in the receiver - not in the superclass chain are tested."
2
claus
parents: 1
diff changeset
  2198
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  2199
    |method|
2
claus
parents: 1
diff changeset
  2200
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  2201
    method := self compiledMethodAt:aSelector.
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  2202
    method isNil ifTrue:[^ nil].
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
  2203
    ^ method source
2
claus
parents: 1
diff changeset
  2204
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2205
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2206
     True sourceCodeAt:#ifTrue:
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2207
     Object sourceCodeAt:#==
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2208
     Behavior sourceCodeAt:#sourceCodeAt:
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2209
    "
2
claus
parents: 1
diff changeset
  2210
!
claus
parents: 1
diff changeset
  2211
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2212
lookupMethodFor:aSelector
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2213
    "return the method, which would be executed if aSelector was sent to
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2214
     an instance of the receiver. I.e. the selector arrays of the receiver
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2215
     and all of its superclasses are searched for aSelector.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2216
     Return the method, or nil if instances do not understand aSelector.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2217
     EXPERIMENTAL: take care of multiple superclasses."
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2218
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2219
    |m cls|
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2220
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2221
    cls := self.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2222
    [cls notNil] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2223
	m := cls compiledMethodAt:aSelector.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2224
	m notNil ifTrue:[^ m].
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2225
	cls hasMultipleSuperclasses ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2226
	    cls superclasses do:[:aSuperClass |
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2227
		m := aSuperClass lookupMethodFor:aSelector.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2228
		m notNil ifTrue:[^ m].
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2229
	    ].
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2230
	    ^ nil
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2231
	] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2232
	    cls := cls superclass
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2233
	]
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2234
    ].
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2235
    ^ nil
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2236
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2237
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2238
cachedLookupMethodFor:aSelector
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2239
    "return the method, which would be executed if aSelector was sent to
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2240
     an instance of the receiver. I.e. the selector arrays of the receiver
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2241
     and all of its superclasses are searched for aSelector.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2242
     Return the method, or nil if instances do not understand aSelector.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2243
     This interface provides exactly the same information as #lookupMethodFor:,
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2244
     but uses the lookup-cache in the VM for faster search. 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2245
     However, keep in mind, that doing a lookup through the cache also adds new
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2246
     entries and can thus slow down the system by polluting the cache with 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2247
     irrelevant entries. (do NOT loop over all objects calling this method).
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2248
     Does NOT (currently) handle MI"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2249
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2250
%{  /* NOCONTEXT */
362
claus
parents: 360
diff changeset
  2251
    extern OBJ __lookup();
claus
parents: 360
diff changeset
  2252
claus
parents: 360
diff changeset
  2253
    RETURN ( __lookup(self, aSelector, SENDER) );
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2254
%}
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2255
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2256
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2257
     String cachedLookupMethodFor:#=
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2258
     String cachedLookupMethodFor:#asOrderedCollection
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2259
    "
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2260
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2261
2
claus
parents: 1
diff changeset
  2262
hasMethods
claus
parents: 1
diff changeset
  2263
    "return true, if there are any (local) methods in this class"
claus
parents: 1
diff changeset
  2264
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2265
    ^ (methodArray size ~~ 0)
10
claus
parents: 5
diff changeset
  2266
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2267
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2268
     True hasMethods
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2269
     True class hasMethods
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2270
    "
2
claus
parents: 1
diff changeset
  2271
!
claus
parents: 1
diff changeset
  2272
claus
parents: 1
diff changeset
  2273
implements:aSelector
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2274
    "return true, if the receiver implements aSelector.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2275
     (i.e. implemented in THIS class - NOT in a superclass).
10
claus
parents: 5
diff changeset
  2276
     Dont use this method to check if someone responds to a message -
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2277
     use #canUnderstand: on the class or #respondsTo: on the instance
10
claus
parents: 5
diff changeset
  2278
     to do this."
2
claus
parents: 1
diff changeset
  2279
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2280
    ^ (selectorArray identityIndexOf:aSelector startingAt:1) ~~ 0
2
claus
parents: 1
diff changeset
  2281
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2282
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2283
     True implements:#ifTrue:
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2284
     True implements:#==
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2285
    "
2
claus
parents: 1
diff changeset
  2286
!
claus
parents: 1
diff changeset
  2287
claus
parents: 1
diff changeset
  2288
canUnderstand:aSelector
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2289
    "return true, if the receiver or one of its superclasses implements aSelector.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2290
     (i.e. true if my instances understand aSelector)"
2
claus
parents: 1
diff changeset
  2291
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2292
    ^ (self lookupMethodFor:aSelector) notNil
10
claus
parents: 5
diff changeset
  2293
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2294
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2295
     True canUnderstand:#ifTrue:
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2296
     True canUnderstand:#==
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2297
     True canUnderstand:#do:
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2298
    "
2
claus
parents: 1
diff changeset
  2299
!
claus
parents: 1
diff changeset
  2300
claus
parents: 1
diff changeset
  2301
whichClassImplements:aSelector
328
claus
parents: 325
diff changeset
  2302
    "obsolete interface;
claus
parents: 325
diff changeset
  2303
     use whichClassIncludesSelector: for ST-80 compatibility."
claus
parents: 325
diff changeset
  2304
claus
parents: 325
diff changeset
  2305
    ^ self whichClassIncludesSelector:aSelector
claus
parents: 325
diff changeset
  2306
!
claus
parents: 325
diff changeset
  2307
claus
parents: 325
diff changeset
  2308
whichClassIncludesSelector:aSelector
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2309
    "return the class in the inheritance chain, which implements the method
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2310
     for aSelector; return nil if none.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2311
     EXPERIMENTAL: handle multiple superclasses"
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2312
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2313
    |cls|
2
claus
parents: 1
diff changeset
  2314
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2315
    cls := self.
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2316
    [cls notNil] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2317
	(cls implements:aSelector) ifTrue:[^ cls].
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2318
	cls hasMultipleSuperclasses ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2319
	    cls superclasses do:[:aSuperClass |
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2320
		|implementingClass|
2
claus
parents: 1
diff changeset
  2321
328
claus
parents: 325
diff changeset
  2322
		implementingClass := aSuperClass whichClassIncludesSelector:aSelector.
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2323
		implementingClass notNil ifTrue:[^ implementingClass].
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2324
	    ].
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2325
	    ^ nil
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2326
	] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2327
	    cls := cls superclass
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2328
	]
2
claus
parents: 1
diff changeset
  2329
    ].
claus
parents: 1
diff changeset
  2330
    ^ nil
claus
parents: 1
diff changeset
  2331
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2332
    "
328
claus
parents: 325
diff changeset
  2333
     String whichClassIncludesSelector:#==
claus
parents: 325
diff changeset
  2334
     String whichClassIncludesSelector:#collect:
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2335
    "
2
claus
parents: 1
diff changeset
  2336
!
claus
parents: 1
diff changeset
  2337
claus
parents: 1
diff changeset
  2338
inheritsFrom:aClass
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2339
    "return true, if the receiver inherits methods from aClass"
2
claus
parents: 1
diff changeset
  2340
claus
parents: 1
diff changeset
  2341
    ^ self isSubclassOf:aClass
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2342
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2343
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2344
     True inheritsFrom:Object
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2345
     LinkedList inheritsFrom:Array
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2346
    "
2
claus
parents: 1
diff changeset
  2347
!
claus
parents: 1
diff changeset
  2348
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2349
selectorAtMethod:aMethod ifAbsent:failBlock
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2350
    "return the selector for given method aMethod
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2351
     or the value of failBlock, if not found."
2
claus
parents: 1
diff changeset
  2352
claus
parents: 1
diff changeset
  2353
    |index|
claus
parents: 1
diff changeset
  2354
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2355
    index := methodArray identityIndexOf:aMethod startingAt:1.
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2356
    (index == 0) ifTrue:[^ failBlock value].
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2357
    ^ selectorArray at:index
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2358
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2359
    "
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2360
     |m|
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2361
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2362
     m := Object compiledMethodAt:#copy.
328
claus
parents: 325
diff changeset
  2363
     Object selectorAtMethod:m ifAbsent:['oops'].
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2364
    "
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2365
    "
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2366
     |m|
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2367
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2368
     m := Object compiledMethodAt:#copy.
328
claus
parents: 325
diff changeset
  2369
     Fraction selectorAtMethod:m ifAbsent:['oops'].
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2370
    "
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2371
!
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2372
328
claus
parents: 325
diff changeset
  2373
selectorAtMethod:aMethod
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2374
    "Return the selector for given method aMethod."
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2375
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2376
    ^ self selectorAtMethod:aMethod ifAbsent:[nil]
328
claus
parents: 325
diff changeset
  2377
claus
parents: 325
diff changeset
  2378
    "
claus
parents: 325
diff changeset
  2379
     |m|
claus
parents: 325
diff changeset
  2380
claus
parents: 325
diff changeset
  2381
     m := Object compiledMethodAt:#copy.
claus
parents: 325
diff changeset
  2382
     Fraction selectorAtMethod:m.
claus
parents: 325
diff changeset
  2383
    "
claus
parents: 325
diff changeset
  2384
    "
claus
parents: 325
diff changeset
  2385
     |m|
claus
parents: 325
diff changeset
  2386
claus
parents: 325
diff changeset
  2387
     m := Object compiledMethodAt:#copy.
claus
parents: 325
diff changeset
  2388
     Object selectorAtMethod:m.
claus
parents: 325
diff changeset
  2389
    "
2
claus
parents: 1
diff changeset
  2390
!
claus
parents: 1
diff changeset
  2391
claus
parents: 1
diff changeset
  2392
containsMethod:aMethod
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2393
    "Return true, if the argument, aMethod is a method of myself"
2
claus
parents: 1
diff changeset
  2394
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2395
    methodArray isNil ifTrue:[^ false].  "degenerated class"
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2396
    ^ (methodArray identityIndexOf:aMethod startingAt:1) ~~ 0
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2397
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2398
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2399
!Behavior methodsFor:'private accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2400
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2401
setSuperclass:sup selectors:sels methods:m instSize:i flags:f
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2402
    "set some inst vars. 
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2403
     this method is for special uses only - there will be no recompilation
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2404
     and no change record is written here. Also, if the receiver class has 
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2405
     already been in use, future operation of the system is not guaranteed to
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2406
     be correct, since no caches are flushed.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2407
     Therefore: do NOT use it; use Behavior>>superclass: (or flush the caches, at least)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2408
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2409
    SubclassInfo := nil.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2410
    superclass := sup.
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2411
    selectorArray := sels.
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2412
    methodArray := m.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2413
    instSize := i.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2414
    flags := f
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2415
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2416
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2417
setSuperclass:aClass
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2418
    "set the superclass of the receiver.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2419
     this method is for special uses only - there will be no recompilation
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2420
     and no change record written here. Also, if the receiver class has
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2421
     already been in use, future operation of the system is not guaranteed to
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2422
     be correct, since no caches are flushed.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2423
     Therefore: do NOT use it; use Behavior>>superclass: (or flush the caches, at least)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2424
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2425
    SubclassInfo := nil.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2426
    superclass := aClass
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2427
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2428
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2429
setOtherSuperclasses:anArrayOfClasses
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2430
    "EXPERIMENTAL: set the other superclasses of the receiver.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2431
     this method is for special uses only - there will be no recompilation
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2432
     and no change record written here; 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2433
     Do NOT use it."
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2434
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2435
    SubclassInfo := nil.
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2436
    otherSuperclasses := anArrayOfClasses
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2437
!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2438
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2439
instSize:aNumber
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2440
    "set the instance size.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2441
     this method is for special uses only - there will be no recompilation
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2442
     and no change record written here; 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2443
     Do NOT use it."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2444
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2445
    instSize := aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2446
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2447
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2448
flags:aNumber
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2449
    "set the flags.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2450
     this method is for special uses only - there will be no recompilation
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2451
     and no change record written here; 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2452
     Do NOT use it."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2453
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2454
    flags := aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2455
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2456
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2457
setSelectors:sels methods:m
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2458
    "set some inst vars. 
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2459
     this method is for special uses only - there will be no recompilation
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2460
     and no change record written here; 
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2461
     Do NOT use it."
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2462
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2463
    selectorArray := sels.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2464
    methodArray := m.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2465
!
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2466
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2467
setSelectorArray:anArray
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2468
    "set the selector array of the receiver.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2469
     this method is for special uses only - there will be no recompilation
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2470
     and no change record written here.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2471
     NOT for general use."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2472
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2473
    selectorArray := anArray
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2474
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2475
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2476
setMethodArray:anArray
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2477
    "set the method array of the receiver.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2478
     this method is for special uses only - there will be no recompilation
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2479
     and no change record written here.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2480
     NOT for general use."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2481
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2482
    methodArray := anArray
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2483
!
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2484
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2485
setMethodDictionary:aDictionary
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2486
    "set the receivers method dictionary. 
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2487
     Since no dictionary is actually used, decompose into selector- and
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2488
     method arrays and set those. For ST-80 compatibility.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2489
     NOT for general use."
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2490
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2491
    |n newSelectorArray newMethodArray idx|
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2492
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2493
    n := aDictionary size.
359
claus
parents: 357
diff changeset
  2494
    newSelectorArray := Array basicNew:n.
claus
parents: 357
diff changeset
  2495
    newMethodArray := Array basicNew:n.
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2496
    idx := 1.
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2497
    aDictionary keysAndValuesDo:[:sel :method |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2498
	newSelectorArray at:idx put:sel.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2499
	newMethodArray at:idx put:method.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2500
	idx := idx + 1
77
6c38ca59927f *** empty log message ***
claus
parents: 68
diff changeset
  2501
    ].
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2502
    selectorArray := newSelectorArray.
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2503
    methodArray := newMethodArray
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2504
!
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2505
249
claus
parents: 216
diff changeset
  2506
primAddSelector:newSelector withMethod:newMethod
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2507
    "add the method given by 2nd argument under the selector given by
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2508
     the 1st argument to the methodDictionary. 
249
claus
parents: 216
diff changeset
  2509
     Does NOT flush any caches, does NOT write a change record.
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2510
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2511
     Do not use this in normal situations, strange behavior will be
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2512
     the consequence.
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2513
     I.e. executing obsolete methods, since the old method will still 
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2514
     be executed out of the caches."
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2515
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2516
    |index oldSelectorArray oldMethodArray newSelectorArray newMethodArray|
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2517
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2518
    (newSelector isMemberOf:Symbol) ifFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2519
	self error:'invalid selector'. 
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2520
	^ false
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2521
    ].
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2522
    newMethod isNil ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2523
	self error:'invalid method'. 
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2524
	^ false
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2525
    ].
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2526
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2527
    index := selectorArray identityIndexOf:newSelector startingAt:1.
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2528
    (index == 0) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2529
	"
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2530
	 a new selector
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2531
	"
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2532
	newSelectorArray := selectorArray copyWith:newSelector.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2533
	newMethodArray := methodArray copyWith:newMethod.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2534
	"
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2535
	 keep a reference so they wont go away ...
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2536
	 mhmh: this is no longer needed - try without
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2537
	"
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2538
	oldSelectorArray := selectorArray.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2539
	oldMethodArray := methodArray.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2540
	selectorArray := newSelectorArray.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2541
	methodArray := newMethodArray
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2542
    ] ifFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2543
	methodArray at:index put:newMethod
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2544
    ].
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2545
    ^ true
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2546
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2547
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2548
!Behavior methodsFor:'compiler interface'!
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2549
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2550
compiler
249
claus
parents: 216
diff changeset
  2551
    "return the compiler to use for this class.
345
claus
parents: 343
diff changeset
  2552
     OBSOLETE: This is the old ST/X interface, kept for migration. 
claus
parents: 343
diff changeset
  2553
	       Dont use it - it will vanish."
249
claus
parents: 216
diff changeset
  2554
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2555
    ^ self compilerClass
249
claus
parents: 216
diff changeset
  2556
!
claus
parents: 216
diff changeset
  2557
claus
parents: 216
diff changeset
  2558
compilerClass
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2559
    "return the compiler to use for this class - 
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2560
     this can be redefined in special classes, to get classes with
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2561
     Lisp, Prolog, ASN1, Basic :-) or whatever syntax."
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2562
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2563
    ^ Compiler
345
claus
parents: 343
diff changeset
  2564
!
claus
parents: 343
diff changeset
  2565
claus
parents: 343
diff changeset
  2566
evaluatorClass
claus
parents: 343
diff changeset
  2567
    "return the compiler to use for expression evaluation for this class - 
claus
parents: 343
diff changeset
  2568
     this can be redefined in special classes, to get classes with
claus
parents: 343
diff changeset
  2569
     Lisp, Prolog, ASN1, Basic :-) or whatever syntax."
claus
parents: 343
diff changeset
  2570
claus
parents: 343
diff changeset
  2571
    ^ Compiler
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2572
! !
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2573
216
a8abff749575 *** empty log message ***
claus
parents: 213
diff changeset
  2574
!Behavior methodsFor:'enumerating'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2575
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2576
allInstancesDo:aBlock
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2577
    "evaluate aBlock for all of my instances"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2578
369
claus
parents: 362
diff changeset
  2579
"/    ObjectMemory allObjectsDo:[:anObject |
claus
parents: 362
diff changeset
  2580
"/        (anObject class == self) ifTrue:[
claus
parents: 362
diff changeset
  2581
"/            aBlock value:anObject
claus
parents: 362
diff changeset
  2582
"/        ]
claus
parents: 362
diff changeset
  2583
"/    ]
claus
parents: 362
diff changeset
  2584
claus
parents: 362
diff changeset
  2585
    ObjectMemory allInstancesOf:self do:[:anObject |
claus
parents: 362
diff changeset
  2586
	aBlock value:anObject
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2587
    ]
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2588
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2589
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2590
     StandardSystemView allInstancesDo:[:v | Transcript showCr:(v name)]
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2591
    "
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2592
!
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2593
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2594
allDerivedInstancesDo:aBlock
328
claus
parents: 325
diff changeset
  2595
    "evaluate aBlock for all of my instances and all instances of subclasses.
claus
parents: 325
diff changeset
  2596
     This method is going to be removed for protocol compatibility with
claus
parents: 325
diff changeset
  2597
     other STs; use allSubInstancesDo:"
claus
parents: 325
diff changeset
  2598
345
claus
parents: 343
diff changeset
  2599
    self obsoleteMethodWarning:'please use #allSubInstancesDo:'.
328
claus
parents: 325
diff changeset
  2600
    self allSubInstancesDo:aBlock
claus
parents: 325
diff changeset
  2601
claus
parents: 325
diff changeset
  2602
    "
claus
parents: 325
diff changeset
  2603
     StandardSystemView allDerivedInstancesDo:[:v | Transcript showCr:(v name)]
claus
parents: 325
diff changeset
  2604
    "
claus
parents: 325
diff changeset
  2605
!
claus
parents: 325
diff changeset
  2606
claus
parents: 325
diff changeset
  2607
allSubInstancesDo:aBlock
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2608
    "evaluate aBlock for all of my instances and all instances of subclasses"
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2609
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2610
    ObjectMemory allObjectsDo:[:anObject |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2611
	(anObject isKindOf:self) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2612
	    aBlock value:anObject
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2613
	]
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2614
    ]
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2615
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2616
    "
328
claus
parents: 325
diff changeset
  2617
     StandardSystemView allSubInstancesDo:[:v | Transcript showCr:(v name)]
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2618
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2619
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2620
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2621
subclassesDo:aBlock
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2622
    "evaluate the argument, aBlock for all immediate subclasses.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2623
     This will only enumerate globally known classes - for anonymous
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2624
     behaviors, you have to walk over all instances of Behavior."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2625
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2626
    |coll|
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2627
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2628
    SubclassInfo isNil ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2629
	Behavior subclassInfo
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2630
    ].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2631
    SubclassInfo notNil ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2632
	coll := SubclassInfo at:self ifAbsent:nil.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2633
	coll notNil ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2634
	    coll do:aBlock.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2635
	].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2636
	^ self
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2637
    ].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2638
2
claus
parents: 1
diff changeset
  2639
    Smalltalk allBehaviorsDo:[:aClass |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2640
	(aClass superclass == self) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2641
	    aBlock value:aClass
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2642
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2643
    ]
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2644
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2645
    "
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2646
     Collection subclassesDo:[:c | Transcript showCr:(c name)]
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2647
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2648
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2649
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2650
allSubclassesDo:aBlock
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2651
    "evaluate aBlock for all of my subclasses.
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2652
     There is no specific order, in which the entries are enumerated.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2653
     This will only enumerate globally known classes - for anonymous
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2654
     behaviors, you have to walk over all instances of Behavior."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2655
2
claus
parents: 1
diff changeset
  2656
    Smalltalk allBehaviorsDo:[:aClass |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2657
	(aClass isSubclassOf:self) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2658
	    aBlock value:aClass
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2659
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2660
    ]
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2661
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2662
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2663
     Collection allSubclassesDo:[:c | Transcript showCr:(c name)]
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2664
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2665
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2666
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2667
allSubclassesInOrderDo:aBlock
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2668
    "evaluate aBlock for all of my subclasses.
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2669
     Higher level subclasses will be enumerated before the deeper ones,
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2670
     so the order in which aBlock gets called is ok to fileOut classes in
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2671
     correct order for later fileIn.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2672
     This will only enumerate globally known classes - for anonymous
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2673
     behaviors, you have to walk over all instances of Behavior"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2674
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2675
    self subclassesDo:[:aClass |
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2676
	aBlock value:aClass.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2677
	aClass allSubclassesInOrderDo:aBlock
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2678
    ]
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2679
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2680
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2681
     Collection allSubclassesInOrderDo:[:c | Transcript showCr:(c name)]
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2682
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2683
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2684
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2685
allSuperclassesDo:aBlock
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2686
    "evaluate aBlock for all of my superclasses"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2687
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2688
    |theClass|
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2689
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2690
    theClass := superclass.
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2691
    [theClass notNil] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2692
	aBlock value:theClass.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2693
	theClass := theClass superclass
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2694
    ]
45
0c270a39d4a2 *** empty log message ***
claus
parents: 43
diff changeset
  2695
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2696
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2697
     String allSuperclassesDo:[:c | Transcript showCr:(c name)]
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2698
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  2699
! !
2
claus
parents: 1
diff changeset
  2700
68
59faa75185ba *** empty log message ***
claus
parents: 54
diff changeset
  2701
!Behavior methodsFor:'binary storage'!
2
claus
parents: 1
diff changeset
  2702
343
claus
parents: 340
diff changeset
  2703
storeBinaryDefinitionOn: stream manager: manager
claus
parents: 340
diff changeset
  2704
    "binary store of a classes definition.
claus
parents: 340
diff changeset
  2705
     Classes will store the name only and restore by looking for
claus
parents: 340
diff changeset
  2706
     that name in the Smalltalk dictionary."
claus
parents: 340
diff changeset
  2707
claus
parents: 340
diff changeset
  2708
    | myName |
claus
parents: 340
diff changeset
  2709
claus
parents: 340
diff changeset
  2710
    myName := self name.
claus
parents: 340
diff changeset
  2711
    stream nextNumber:4 put:self signature.
claus
parents: 340
diff changeset
  2712
    stream nextNumber:2 put:0.
claus
parents: 340
diff changeset
  2713
    stream nextNumber:2 put:myName size.
claus
parents: 340
diff changeset
  2714
    myName do:[:c| 
claus
parents: 340
diff changeset
  2715
	stream nextPut:c asciiValue
claus
parents: 340
diff changeset
  2716
    ]
claus
parents: 340
diff changeset
  2717
claus
parents: 340
diff changeset
  2718
    "
claus
parents: 340
diff changeset
  2719
     |s|
claus
parents: 340
diff changeset
  2720
     s := WriteStream on:ByteArray new.
claus
parents: 340
diff changeset
  2721
     #(1 2 3 4) storeBinaryOn:s.
claus
parents: 340
diff changeset
  2722
     Object readBinaryFrom:(ReadStream on:s contents)  
claus
parents: 340
diff changeset
  2723
claus
parents: 340
diff changeset
  2724
     |s|
claus
parents: 340
diff changeset
  2725
     s := WriteStream on:ByteArray new.
claus
parents: 340
diff changeset
  2726
     Rectangle storeBinaryOn:s.
claus
parents: 340
diff changeset
  2727
     Object readBinaryFrom:(ReadStream on:s contents)  
claus
parents: 340
diff changeset
  2728
    "
claus
parents: 340
diff changeset
  2729
!
claus
parents: 340
diff changeset
  2730
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2731
readBinaryFrom:aStream
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2732
    "read an objects binary representation from the argument,
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2733
     aStream and return it. 
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2734
     The read object must be a kind of myself, otherwise an error is raised. 
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2735
     To get any object, use 'Object readBinaryFrom:...',
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2736
     To get any number, use 'Number readBinaryFrom:...' and so on.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2737
     This is the reverse operation to 'storeBinaryOn:'. "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2738
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2739
    ^ self readBinaryFrom:aStream onError:[self error:('expected ' , self name)]
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2740
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2741
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2742
     |s|
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2743
     s := WriteStream on:(ByteArray new).
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2744
     #(1 2 3 4) storeBinaryOn:s.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2745
     Object readBinaryFrom:(ReadStream on:s contents)  
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2746
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2747
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2748
     |s|
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2749
     s := 'testFile' asFilename writeStream binary.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2750
     #(1 2 3 4) storeBinaryOn:s.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2751
     'hello world' storeBinaryOn:s.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2752
     s close.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2753
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2754
     s := 'testFile' asFilename readStream binary.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2755
     Transcript showCr:(Object readBinaryFrom:s).
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2756
     Transcript showCr:(Object readBinaryFrom:s).
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2757
     s close.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2758
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2759
!
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2760
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2761
readBinaryFrom:aStream onError:exceptionBlock
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2762
    "read an objects binary representation from the argument,
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2763
     aStream and return it. 
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2764
     The read object must be a kind of myself, otherwise the value of
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2765
     the exceptionBlock is returned.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2766
     To get any object, use 'Object readBinaryFrom:...',
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2767
     To get any number, use 'Number readBinaryFrom:...' and so on.
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2768
     This is the reverse operation to 'storeBinaryOn:'. "
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2769
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2770
    |newObject|
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2771
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2772
    newObject := (BinaryInputManager new:1024) readFrom:aStream.
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2773
    (newObject isKindOf:self) ifFalse:[^ exceptionBlock value].
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2774
    ^ newObject
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2775
91
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2776
    "
b3971c7dc731 *** empty log message ***
claus
parents: 88
diff changeset
  2777
     |s|
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2778
     s := WriteStream on:(ByteArray new).
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2779
     #(1 2 3 4) storeBinaryOn:s.
198
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2780
     Object readBinaryFrom:(ReadStream on:s contents) onError:['oops'] 
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2781
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2782
    "
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2783
     |s|
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2784
     s := WriteStream on:(ByteArray new).
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2785
     #[1 2 3 4] storeBinaryOn:s.
d0d0e3910c98 added readFrom:onError: / binaryReadFrom:onError:
claus
parents: 165
diff changeset
  2786
     Array readBinaryFrom:(ReadStream on:s contents)  onError:['oops']  
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2787
    "
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2788
!
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
  2789
43
00ca34676cbf *** empty log message ***
claus
parents: 25
diff changeset
  2790
binaryDefinitionFrom:stream manager:manager
343
claus
parents: 340
diff changeset
  2791
    "sent during a binary read by the input manager.
claus
parents: 340
diff changeset
  2792
     Read the definition on an empty instance (of my class) from stream.
43
00ca34676cbf *** empty log message ***
claus
parents: 25
diff changeset
  2793
     All pointer instances are left nil, while all bits are read in here.
00ca34676cbf *** empty log message ***
claus
parents: 25
diff changeset
  2794
     return the new object."
2
claus
parents: 1
diff changeset
  2795
43
00ca34676cbf *** empty log message ***
claus
parents: 25
diff changeset
  2796
    |obj t
00ca34676cbf *** empty log message ***
claus
parents: 25
diff changeset
  2797
     basicSize "{ Class: SmallInteger }" |
2
claus
parents: 1
diff changeset
  2798
claus
parents: 1
diff changeset
  2799
    self isPointers ifTrue: [
343
claus
parents: 340
diff changeset
  2800
	"/
claus
parents: 340
diff changeset
  2801
	"/ inst size not needed - if you uncomment the line below,
claus
parents: 340
diff changeset
  2802
	"/ also uncomment the corresponding line in
claus
parents: 340
diff changeset
  2803
	"/ Object>>storeBinaryDefinitionOn:manager:
claus
parents: 340
diff changeset
  2804
	"/
claus
parents: 340
diff changeset
  2805
	"/ stream next. "skip instSize"
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2806
	self isVariable ifTrue: [
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2807
	    ^ self basicNew:(stream nextNumber:3)
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2808
	].
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2809
	^ self basicNew
2
claus
parents: 1
diff changeset
  2810
    ].
claus
parents: 1
diff changeset
  2811
343
claus
parents: 340
diff changeset
  2812
    "
claus
parents: 340
diff changeset
  2813
     an object with bit-valued instance variables.
claus
parents: 340
diff changeset
  2814
     These are read here.
claus
parents: 340
diff changeset
  2815
    "
43
00ca34676cbf *** empty log message ***
claus
parents: 25
diff changeset
  2816
    basicSize := stream nextNumber:4.
00ca34676cbf *** empty log message ***
claus
parents: 25
diff changeset
  2817
    obj := self basicNew:basicSize.
00ca34676cbf *** empty log message ***
claus
parents: 25
diff changeset
  2818
2
claus
parents: 1
diff changeset
  2819
    self isBytes ifTrue: [
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2820
	stream nextBytes:basicSize into:obj
2
claus
parents: 1
diff changeset
  2821
    ] ifFalse: [
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2822
	self isWords ifTrue: [
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2823
	    1 to:basicSize do:[:i |
213
3b56a17534fd *** empty log message ***
claus
parents: 198
diff changeset
  2824
		obj basicAt:i put:(stream nextNumber:2)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2825
	    ]
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2826
	] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2827
	    self isLongs ifTrue: [
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2828
		1 to:basicSize do:[:i |
213
3b56a17534fd *** empty log message ***
claus
parents: 198
diff changeset
  2829
		    obj basicAt:i put:(stream nextNumber:4)
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2830
		]
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2831
	    ] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2832
		self isFloats ifTrue: [
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2833
		    "could do it in one big read on machines which use IEEE floats ..."
343
claus
parents: 340
diff changeset
  2834
		    t := Float basicNew.
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2835
		    1 to:basicSize do:[:i |
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2836
			Float readBinaryIEEESingleFrom:stream into:t.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2837
			obj basicAt:i put: t
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2838
		    ]
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2839
		] ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2840
		    self isDoubles ifTrue: [
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2841
			"could do it in one big read on machines which use IEEE doubles ..."
343
claus
parents: 340
diff changeset
  2842
			t := Float basicNew.
154
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2843
			1 to:basicSize do:[:i |
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2844
			    Float readBinaryIEEEDoubleFrom:stream into:t.
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2845
			    obj basicAt:i put: t
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2846
			]
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2847
		    ]
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2848
		]
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2849
	    ]
d4236ec280a6 *** empty log message ***
claus
parents: 151
diff changeset
  2850
	]
2
claus
parents: 1
diff changeset
  2851
    ].
claus
parents: 1
diff changeset
  2852
    ^obj
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2853
!
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2854
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2855
canCloneFrom:anObject 
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2856
    "return true, if this class can clone an obsolete object as retrieved
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2857
     by a binary load. Subclasses which do not want to have obsolete objects
343
claus
parents: 340
diff changeset
  2858
     be converted, should redefine this method to return false.
claus
parents: 340
diff changeset
  2859
     (However, conversion is never done silently in a binary load; you
claus
parents: 340
diff changeset
  2860
      have to have a handler for the binaryload errors and for the conversion
claus
parents: 340
diff changeset
  2861
      request signal.)"
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2862
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2863
    ^ true
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2864
!
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2865
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2866
cloneFrom:aPrototype
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2867
    "return an instance of myself with variables initialized from
343
claus
parents: 340
diff changeset
  2868
     a prototype. This is used when instances of obsolete classes are
claus
parents: 340
diff changeset
  2869
     binary loaded and a conversion is done on the obsolete object. 
claus
parents: 340
diff changeset
  2870
     UserClasses may redefine this for better conversions."
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2871
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2872
    |newInst indexed myInfo otherInfo varIndexAssoc|
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2873
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2874
    indexed := false.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2875
    aPrototype class isVariable ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2876
	self isVariable ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2877
	    indexed := true.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2878
	].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2879
	"otherwise, these are lost ..."
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2880
    ].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2881
    indexed ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2882
	newInst := self basicNew:aPrototype basicSize
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2883
    ] ifFalse:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2884
	newInst := self basicNew
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2885
    ].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2886
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2887
    myInfo := self instanceVariableOffsets.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2888
    otherInfo := aPrototype class instanceVariableOffsets.
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2889
    myInfo keysAndValuesDo:[:name :index |
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2890
	varIndexAssoc := otherInfo at:name ifAbsent:[].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2891
	varIndexAssoc notNil ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2892
	    newInst instVarAt:index put:(aPrototype instVarAt:(varIndexAssoc value))
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2893
	]
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2894
    ].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2895
    indexed ifTrue:[
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2896
	1 to:aPrototype basicSize do:[:index |
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2897
	    newInst basicAt:index put:(aPrototype basicAt:index)
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2898
	].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2899
    ].
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2900
    ^ newInst
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2901
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2902
    "
421
claus
parents: 384
diff changeset
  2903
     Class withoutUpdatingChangesDo:[
442
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  2904
	 Point subclass:#Point3D
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2905
	   instanceVariableNames:'z'
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2906
	   classVariableNames:''
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2907
	   poolDictionaries:''
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2908
	   category:'testing'.
442
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  2909
	 (Point3D cloneFrom:1@2) inspect.
421
claus
parents: 384
diff changeset
  2910
     ]
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2911
    "
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2912
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2913
    "
421
claus
parents: 384
diff changeset
  2914
     Class withoutUpdatingChangesDo:[
442
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  2915
	 Point variableSubclass:#Point3D
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2916
	   instanceVariableNames:'z'
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2917
	   classVariableNames:''
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2918
	   poolDictionaries:''
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2919
	   category:'testing'.
442
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  2920
	 (Point3D cloneFrom:#(1 2 3)) inspect.
421
claus
parents: 384
diff changeset
  2921
     ]
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2922
    "
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2923
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2924
    "
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2925
     |someObject|
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2926
421
claus
parents: 384
diff changeset
  2927
     Class withoutUpdatingChangesDo:[
442
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  2928
	 Object subclass:#TestClass1 
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2929
	   instanceVariableNames:'foo bar'
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2930
	   classVariableNames:''
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2931
	   poolDictionaries:''
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2932
	   category:'testing'.
442
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  2933
	 someObject := TestClass1 new.
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  2934
	 someObject instVarAt:1 put:'foo'; instVarAt:2 put:'bar'.
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  2935
	 Object subclass:#TestClass2 
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2936
	   instanceVariableNames:'bar foo'
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2937
	   classVariableNames:''
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2938
	   poolDictionaries:''
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2939
	   category:'testing'.
442
65a11cda5e9e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  2940
	 (TestClass2 cloneFrom:someObject) inspect.
421
claus
parents: 384
diff changeset
  2941
     ]
308
f04744ef7b5d *** empty log message ***
claus
parents: 295
diff changeset
  2942
    "
2
claus
parents: 1
diff changeset
  2943
! !