WeakArray.st
author Claus Gittinger <cg@exept.de>
Tue, 28 Mar 2000 19:39:48 +0200
changeset 5334 f8837914d424
parent 4730 278b9e735be7
child 5454 7c81e5984e44
permissions -rw-r--r--
checkin from browser
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
     1
"
62211a9bc04d Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1991 by Claus Gittinger
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
     3
	      All Rights Reserved
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
     4
62211a9bc04d Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
62211a9bc04d Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
62211a9bc04d Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
62211a9bc04d Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
62211a9bc04d Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
62211a9bc04d Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
62211a9bc04d Initial revision
claus
parents:
diff changeset
    11
"
62211a9bc04d Initial revision
claus
parents:
diff changeset
    12
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
    13
ArrayedCollection variableSubclass:#WeakArray
2091
c11bb3e29a1b Use dependent mechamism of WeakArray instead of #watcher.
Stefan Vogel <sv@exept.de>
parents: 1903
diff changeset
    14
	instanceVariableNames:'dependents'
1263
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
    15
	classVariableNames:'RegistrationFailedSignal AlreadyInitialized'
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
    16
	poolDictionaries:''
4351
27cb4edec0e2 category change
Claus Gittinger <cg@exept.de>
parents: 4311
diff changeset
    17
	category:'Collections-Weak'
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
    18
!
62211a9bc04d Initial revision
claus
parents:
diff changeset
    19
62211a9bc04d Initial revision
claus
parents:
diff changeset
    20
!WeakArray class methodsFor:'documentation'!
62211a9bc04d Initial revision
claus
parents:
diff changeset
    21
88
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    22
copyright
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    23
"
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    24
 COPYRIGHT (c) 1991 by Claus Gittinger
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
    25
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    26
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    27
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    28
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    30
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    31
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    32
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    33
"
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    34
!
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    35
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
    36
documentation
62211a9bc04d Initial revision
claus
parents:
diff changeset
    37
"
88
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    38
    WeakArrays can be used to trace disposal of objects; in contrast to other
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
    39
    objects, references by WeakArrays will NOT keep an object from being
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
    40
    garbage collected.
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    41
    Instead, whenever an object kept in a WeakArray dies, its entry is zeroed,
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    42
    and the WeakArray is informed by the storage manager. The WeakArray itself
2271
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
    43
    then informs possible dependents via the dependency mechanism.
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    44
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
    45
    WeakArrays are used to track disposal of objects which keep external
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    46
    world resources. For example, FileStreams must close their underlying
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    47
    file when disposed (otherwise you could run out of OS filedescriptors).
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    48
    This can be done by keeping the FileStream objects in a weakArray, and
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
    49
    keep a parallel array of filedescriptors. Whenever a fileStream is
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    50
    freed, search both arrays for an index where the stream is zero, but the
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    51
    filedescriptor is non-nil. Then close that file, and nil the filedescriptor
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    52
    entry. Notice, that there is a class (Registry) which does exactly this in
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    53
    a more programmer friendly way.
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    54
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    55
    Another application is caching of data: keep it in a weakArray, so the
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    56
    data in that cache will not be unreclaimable due to being cached.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    57
    (for example, the ResourcePack class uses a WeakArray to cache recently
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
    58
     used resource data for a while).
88
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    59
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
    60
    The way in which weakArrays get informed by the runtime system is via
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    61
    an interrupt (DisposeInterrupt) which is first sent to the disposeHandler
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    62
    (typically ObjectMemory). ObjectMemory then takes the required steps to
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    63
    notify all weakArrays via the #lostPointer message.
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    64
    The reason for not sending messages directly from the VM is to make it 
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    65
    possible to run the finalization code at lower priority or from another class. 
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
    66
    Also, as a side effect, it is possible to delay finalization by blocking 
2271
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
    67
    interrupts. (thus, the actual sending of the #lostPointer message is under
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
    68
    control of Smalltalk code, which is modifyable).
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
    69
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
    70
2091
c11bb3e29a1b Use dependent mechamism of WeakArray instead of #watcher.
Stefan Vogel <sv@exept.de>
parents: 1903
diff changeset
    71
    A weakArray notifies its dependents via normal dependency notfications.
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
    72
2145
d243ffafeae3 more docu
Claus Gittinger <cg@exept.de>
parents: 2091
diff changeset
    73
    [hint:] 
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    74
	WeakArray handling adds small some overhead to the VM 
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    75
	(each weakarray is scanned after each GC). 
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    76
	It is uncertain, if the current mechanism works well
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    77
	with (say) ten-thousands of weakArrays.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    78
	We had the system running with >2000 weakArrays, some being quite
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    79
	big for a while and had a few percent of added gc time.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    80
	The system as delivered creates between 50 and 100 weakArrays,
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    81
	but with many dependents, this number may grow.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    82
	If you need the dependency mechanism on a huge number of objects,
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    83
	consider adding a (non-weak) dependents field to your class
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    84
	- take the implementation of Model as a guide (or subclass them
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    85
	from Model).
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    86
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    87
    As a possible option, we could perform the weakArray scanning only in
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    88
    the oldSpace reclamation code - this would remove most of the overhead,
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    89
    but will lead to much longer delayed finalization .... we will see.
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    90
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    91
1290
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 1263
diff changeset
    92
    [instance variables:]
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    93
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    94
	dependents                  get informed via #change notifiction 
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    95
				    that the weakArray has lost pointers.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
    96
				    Having the dependents here is an optimization.
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    97
1290
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 1263
diff changeset
    98
    [class variables:]
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    99
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   100
	RegistrationFailedSignal    raised if a weakArray cannot be
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   101
				    registered by the VM. This only happens,
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   102
				    if the VM has to resize its internal tables
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   103
				    and is running out of malloc-memory.
1263
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
   104
4062
4959de96b06f documentation
Claus Gittinger <cg@exept.de>
parents: 3090
diff changeset
   105
    [memory requirements:]
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   106
	OBJ-HEADER + (size * ptr-size) + ptr-size
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   107
		   + sizeof(dependents-collection)
4062
4959de96b06f documentation
Claus Gittinger <cg@exept.de>
parents: 3090
diff changeset
   108
1290
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 1263
diff changeset
   109
    [author:]
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   110
	Claus Gittinger
1290
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 1263
diff changeset
   111
1263
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
   112
    [See also:]
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   113
	Array WeakIdentitySet WeakIdentityDictionary Registry
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   114
	Model
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   115
"
62211a9bc04d Initial revision
claus
parents:
diff changeset
   116
! !
62211a9bc04d Initial revision
claus
parents:
diff changeset
   117
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   118
!WeakArray class methodsFor:'initialization'!
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   119
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   120
initialize
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   121
    "setup the private signal"
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   122
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   123
    RegistrationFailedSignal isNil ifTrue:[
302
1f76060d58a4 *** empty log message ***
claus
parents: 290
diff changeset
   124
	RegistrationFailedSignal := ErrorSignal newSignalMayProceed:true.
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   125
	RegistrationFailedSignal nameClass:self message:#registrationFailedSignal.
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   126
	RegistrationFailedSignal notifierString:'weakArray registration failed'.
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   127
    ]
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   128
! !
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   129
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   130
!WeakArray class methodsFor:'instance creation'!
62211a9bc04d Initial revision
claus
parents:
diff changeset
   131
3090
51ff4bd4c4ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3056
diff changeset
   132
basicNew:size
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   133
    "return a new weakArray with size slots"
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   134
2271
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   135
    "This is a kludge: I would like to set the WEAK-flag in the classes
216
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   136
     initialize method, but (currently) the order in which the class-initialize
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   137
     methods are called is not defined ...
216
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   138
     ... therefore it could happen, that a WeakArray is used by other
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   139
     classes initialize method BEFORE this method is evaluated. 
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   140
     To avoid this, the WEAK bit in the class is set here, when the very first 
2271
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   141
     WeakArray is created.
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   142
     [Actually, the cleanest solution was to add another class definition
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   143
      keyword (such as #variableWeakSubclass:) which sets the weak flag right
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   144
      from the start.]"
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   145
216
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   146
    AlreadyInitialized isNil ifTrue:[
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   147
	self flags:(Behavior flagWeakPointers).
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   148
	AlreadyInitialized := true
216
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   149
    ].
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   150
3090
51ff4bd4c4ab *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 3056
diff changeset
   151
    ^ (super basicNew:size) registerAsWeakArray
2271
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   152
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   153
    "Modified: 25.1.1997 / 13:17:22 / cg"
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   154
! !
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   155
2318
880ab58b4ef9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2305
diff changeset
   156
!WeakArray class methodsFor:'queries'!
880ab58b4ef9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2305
diff changeset
   157
880ab58b4ef9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2305
diff changeset
   158
isBuiltInClass
880ab58b4ef9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2305
diff changeset
   159
    "return true if this class is known by the run-time-system.
880ab58b4ef9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2305
diff changeset
   160
     Here, true is returned for myself, false for subclasses."
880ab58b4ef9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2305
diff changeset
   161
880ab58b4ef9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2305
diff changeset
   162
    ^ self == WeakArray
880ab58b4ef9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2305
diff changeset
   163
! !
880ab58b4ef9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2305
diff changeset
   164
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   165
!WeakArray methodsFor:'GC registration'!
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   166
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   167
registerAsWeakArray
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   168
    "register the receiver in the VM - 
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   169
     i.e. tell the VM to nil disposed entries in the receiver
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   170
     and notify the disposeInterruptHandler whenever that happened."
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   171
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   172
    |ok|
2318
880ab58b4ef9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2305
diff changeset
   173
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   174
%{
62211a9bc04d Initial revision
claus
parents:
diff changeset
   175
    OBJ __addShadowObject();
62211a9bc04d Initial revision
claus
parents:
diff changeset
   176
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   177
    ok = __addShadowObject(self, 0);
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   178
    if (ok == false) {
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   179
	/* 
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   180
	 * the behavior of __addShadowObject() in case of overflowing
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   181
	 * VM-table space can be controlled by the second argument:
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   182
	 *   if its 0, the weakObject is not registered, and false
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   183
	 *   is returned.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   184
	 *   if its 1, the tables are reallocated, registration proceeds,
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   185
	 *   and true is returned.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   186
	 * This allows for the caller to have an influence on the VM's
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   187
	 * shadow table allocation.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   188
	 *
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   189
	 * If addShadowObject() returned false, too many shadow objects are
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   190
	 * already there. Then collect garbage to get rid of
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   191
	 * obsolete ones, and try again.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   192
	 * Since a full collect is expensive, we try
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   193
	 * a scavenge first, doing a full collect only if 
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   194
	 * that does not help.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   195
	 *
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   196
	 * THIS MAY OR MAY NOT BE A GOOD IDEA: although it reduces
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   197
	 * the number of shadow objects that have to be
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   198
	 * processed at GC time, it may create a long delay here,
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   199
	 * at shadow object creation time.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   200
	 * Dont know which is better ...
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   201
	 */
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   202
	__nonTenuringScavenge(__context);
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   203
	ok = __addShadowObject(self, 0);
2271
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   204
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   205
	if (ok == false) {
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   206
	    /* 
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   207
	     * hard stuff - need full collect
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   208
	     * if this is the very first GC, assume that we are in
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   209
	     * the startup phase (where all weak stuff is allocated). 
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   210
	     * Then do no GC.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   211
	     * Heuristics showed, that this GC does not find much ...
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   212
	     */
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   213
	    if ((__garbageCollectCount() != 0)
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   214
	     || (__incrementalGCCount() != 0)) {
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   215
		__markAndSweepIfUseful(__context);
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   216
		ok = __addShadowObject(self, 0);
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   217
	    }
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   218
	    if (ok == false) {
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   219
		/*
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   220
		 * mhmh - it seems that there are really many shadow 
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   221
		 * objects around - force creation
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   222
		 */
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   223
		ok = __addShadowObject(self, 1);
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   224
		if (ok == false) {
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   225
		    /* 
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   226
		     * no chance - something must be wrong 
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   227
		     * lets fall into the exception and see.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   228
		     */
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   229
		}
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   230
	    }
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   231
	}
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   232
    }
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   233
%}.
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   234
    ok ifFalse:[
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   235
	"
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   236
	 the VM was not able to register the new weakArray
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   237
	 This can only happen, if the VM has to resize its tables,
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   238
	 and a malloc request failed. Usually, this smells like big
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   239
	 trouble being on the way (soon running out of memory in
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   240
	 other places as well).
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   241
	 Configure your OS for more swap space.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   242
	"
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   243
	^ RegistrationFailedSignal raiseRequestWith:self
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   244
    ]
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   245
! !
62211a9bc04d Initial revision
claus
parents:
diff changeset
   246
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   247
!WeakArray methodsFor:'accessing'!
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   248
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   249
at:index
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   250
    "return the indexed instance variable with index, anInteger.
2271
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   251
     Reimplemented here for IGC readBarrier. 
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   252
     (You dont have to understand this.)"
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   253
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   254
    ^ self basicAt:index
2271
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   255
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   256
    "Modified: 25.1.1997 / 13:41:25 / cg"
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   257
!
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   258
3056
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   259
at:index put:someObject
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   260
    "store someObject in the weakArray at some index."
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   261
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   262
    ^ self basicAt:index put:someObject
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   263
!
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   264
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   265
basicAt:index
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   266
    "return the indexed instance variable with index, anInteger.
2271
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   267
     Reimplemented here for IGC readBarrier. 
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   268
     (You dont have to understand this.)"
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   269
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   270
%{  /* NOCONTEXT */
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   271
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   272
    REGISTER int indx;
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   273
    REGISTER unsigned int nIndex;
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   274
    OBJ el;
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   275
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   276
    if (__isSmallInteger(index)) {
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   277
	indx = __intVal(index) - 1;
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   278
	if (indx >= 0) {
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   279
	    nIndex = __BYTES2OBJS__(__qSize(self) - OHDR_SIZE);
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   280
	    indx += __intVal(__ClassInstPtr(__qClass(self))->c_ninstvars);
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   281
	    if (indx < nIndex) {
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   282
		el = __InstPtr(self)->i_instvars[indx];
4311
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   283
		if (__isNonNilObject(el)) {
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   284
		    el = __WEAK_READ__(self, el);
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   285
		}
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   286
		RETURN (el);
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   287
	    }
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   288
	}
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   289
    }
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   290
%}.
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   291
    ^ super basicAt:index
2644
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   292
!
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   293
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   294
basicAt:index put:someObject
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   295
    "store someObject in the weakArray at some index."
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   296
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   297
%{  /* NOCONTEXT */
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   298
    REGISTER int indx;
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   299
    REGISTER unsigned int nIndex;
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   300
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   301
    if (__isSmallInteger(index)) {
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   302
	indx = __intVal(index) - 1;
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   303
	if (indx >= 0) {
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   304
	    nIndex = __BYTES2OBJS__(__qSize(self) - OHDR_SIZE);
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   305
	    indx += __intVal(__ClassInstPtr(__qClass(self))->c_ninstvars);
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   306
	    if (indx < nIndex) {
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   307
		REGISTER OBJ el = someObject;
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   308
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   309
		__InstPtr(self)->i_instvars[indx] = el;
2644
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   310
		if (__isNonNilObject(el)) {
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   311
		    __STORE(self, el);
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   312
		    __WEAK_WRITE__(self, el);
2644
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   313
		}
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   314
		RETURN (el);
2644
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   315
	    }
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   316
	}
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   317
    }
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   318
%}.
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   319
    "/ for the error-message ...
b6e66194e355 need write barrier to keep track of newSpace refs in weakArrays
Claus Gittinger <cg@exept.de>
parents: 2318
diff changeset
   320
    ^ super basicAt:index put:someObject
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   321
! !
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   322
3056
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   323
!WeakArray methodsFor:'copying'!
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   324
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   325
postCopy
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   326
    "copying alone does not really help - we have to tell
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   327
     the VM, that there is a new WeakArray around ...
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   328
     Q: who copies weakArrays ?"
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   329
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   330
    dependents := nil.
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   331
    self registerAsWeakArray.
4730
278b9e735be7 deepCopy fix (do not copy dependents)
Claus Gittinger <cg@exept.de>
parents: 4351
diff changeset
   332
!
278b9e735be7 deepCopy fix (do not copy dependents)
Claus Gittinger <cg@exept.de>
parents: 4351
diff changeset
   333
278b9e735be7 deepCopy fix (do not copy dependents)
Claus Gittinger <cg@exept.de>
parents: 4351
diff changeset
   334
skipInstvarIndexInDeepCopy:index
278b9e735be7 deepCopy fix (do not copy dependents)
Claus Gittinger <cg@exept.de>
parents: 4351
diff changeset
   335
    "a helper for deepCopy; only indices for which this method returns
278b9e735be7 deepCopy fix (do not copy dependents)
Claus Gittinger <cg@exept.de>
parents: 4351
diff changeset
   336
     false are copied in a deep copy."
278b9e735be7 deepCopy fix (do not copy dependents)
Claus Gittinger <cg@exept.de>
parents: 4351
diff changeset
   337
278b9e735be7 deepCopy fix (do not copy dependents)
Claus Gittinger <cg@exept.de>
parents: 4351
diff changeset
   338
    index == 1 ifTrue:[
278b9e735be7 deepCopy fix (do not copy dependents)
Claus Gittinger <cg@exept.de>
parents: 4351
diff changeset
   339
        ^ true "/ skip dependents
278b9e735be7 deepCopy fix (do not copy dependents)
Claus Gittinger <cg@exept.de>
parents: 4351
diff changeset
   340
    ].
278b9e735be7 deepCopy fix (do not copy dependents)
Claus Gittinger <cg@exept.de>
parents: 4351
diff changeset
   341
    ^ false
278b9e735be7 deepCopy fix (do not copy dependents)
Claus Gittinger <cg@exept.de>
parents: 4351
diff changeset
   342
3056
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   343
! !
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   344
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   345
!WeakArray methodsFor:'dependents access'!
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   346
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   347
addDependent:anObject
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   348
    "make the argument, anObject be a dependent of the receiver"
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   349
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   350
    |wasBlocked|
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   351
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   352
    wasBlocked := OperatingSystem blockInterrupts.
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   353
    [
5334
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   354
        |deps|
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   355
5334
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   356
        deps := dependents.
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   357
        "/
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   358
        "/ store the very first dependent directly in
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   359
        "/ the dependents instVar
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   360
        "/
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   361
        (deps isNil and:[anObject isCollection not]) ifTrue:[
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   362
            dependents := anObject
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   363
        ] ifFalse:[
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   364
            "/
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   365
            "/ store more dependents in the dependents collection
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   366
            "/
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   367
            deps isCollection ifTrue:[
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   368
                deps add:anObject
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   369
            ] ifFalse:[
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   370
                deps == anObject ifFalse:[
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   371
                    deps isNil ifTrue:[
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   372
                        dependents := (IdentitySet with:anObject)
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   373
                    ] ifFalse:[
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   374
                        dependents := (IdentitySet with:deps with:anObject)
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   375
                    ]
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   376
                ]
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   377
            ]
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   378
        ]
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   379
    ] valueNowOrOnUnwindDo:[
5334
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   380
        wasBlocked ifFalse:[
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   381
            OperatingSystem unblockInterrupts
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   382
        ]
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   383
    ]
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   384
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   385
    "Modified: 8.1.1997 / 23:40:30 / cg"
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   386
!
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   387
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   388
dependents 
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   389
    "return the dependents of the receiver"
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   390
3056
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   391
    dependents isNil ifTrue:[^ #()].
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   392
    dependents isCollection ifTrue:[
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   393
	^ dependents
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   394
    ].
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   395
    ^ IdentitySet with:dependents
3056
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   396
e1eae509aadb dependents now always returns a collection
Claus Gittinger <cg@exept.de>
parents: 2644
diff changeset
   397
    "Modified: / 27.10.1997 / 19:37:16 / cg"
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   398
!
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   399
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   400
dependents:aCollection
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   401
    "set the dependents of the receiver"
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   402
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   403
    |dep|
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   404
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   405
    aCollection size == 1 ifTrue:[
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   406
	dep := aCollection first.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   407
	dep isCollection ifFalse:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   408
	    dependents := aCollection first.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   409
	    ^ self
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   410
	]
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   411
    ].
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   412
    dependents := aCollection
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   413
!
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   414
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   415
dependentsDo:aBlock
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   416
    "evaluate aBlock for all of my dependents"
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   417
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   418
    |deps|
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   419
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   420
    deps := dependents.
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   421
    deps notNil ifTrue:[
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   422
	deps isCollection ifTrue:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   423
	    deps do:aBlock
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   424
	] ifFalse:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   425
	    aBlock value:deps
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   426
	]
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   427
    ]
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   428
!
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   429
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   430
removeDependent:anObject
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   431
    "make the argument, anObject be independent of the receiver"
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   432
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   433
    |wasBlocked|
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   434
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   435
    "/ must do this save from interrupts, since the dependents collection
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   436
    "/ is possibly accessed from multiple threads.
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   437
    "/ Used to use #valueUninterruptably here; inlined that code for slightly
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   438
    "/ faster execution.
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   439
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   440
    wasBlocked := OperatingSystem blockInterrupts.
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   441
    [
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   442
	|deps sz dep|
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   443
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   444
	deps := dependents.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   445
	deps notNil ifTrue:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   446
	    deps isCollection ifTrue:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   447
		deps remove:anObject ifAbsent:[].
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   448
		(sz := deps size) == 0 ifTrue:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   449
		    dependents := nil
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   450
		] ifFalse:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   451
		    sz == 1 ifTrue:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   452
			(dep := deps first) isCollection ifFalse:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   453
			    dependents := dep
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   454
			]
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   455
		    ]
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   456
		]
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   457
	    ] ifFalse:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   458
		deps == anObject ifTrue:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   459
		    dependents := nil
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   460
		]
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   461
	    ]
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   462
	]
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   463
    ] valueNowOrOnUnwindDo:[
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   464
	wasBlocked ifFalse:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   465
	    OperatingSystem unblockInterrupts
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   466
	]
2305
1413b683d299 made it a subclass of ArrayedCollection - avoid inheriting inprotected
Claus Gittinger <cg@exept.de>
parents: 2271
diff changeset
   467
    ]
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   468
! !
62211a9bc04d Initial revision
claus
parents:
diff changeset
   469
1825
6f81b866a74a category rename
Claus Gittinger <cg@exept.de>
parents: 1785
diff changeset
   470
!WeakArray methodsFor:'enumerating'!
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   471
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   472
do:aBlock
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   473
    "evaluate the argument, aBlock for each element in the collection.
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   474
     - reimplemented for IGC readBarrier. 
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   475
     You dont have to understand this."
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   476
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   477
%{
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   478
    REGISTER int index;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   479
    unsigned int nIndex;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   480
    static struct inlineCache val = _ILC1;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   481
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   482
    index = __intVal(__ClassInstPtr(__qClass(self))->c_ninstvars);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   483
    nIndex = __BYTES2OBJS__(__qSize(self) - OHDR_SIZE);
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   484
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   485
    if (__isBlockLike(aBlock)
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   486
     && (__BlockInstPtr(aBlock)->b_nargs == __MKSMALLINT(1))) {
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   487
	{
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   488
	    /*
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   489
	     * the most common case: a static compiled block, with home on the stack ...
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   490
	     */
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   491
	    REGISTER OBJFUNC codeVal;
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   492
2254
5e3cb9e7e682 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2221
diff changeset
   493
	    if (((codeVal = __BlockInstPtr(aBlock)->b_code) != (OBJFUNC)nil)
5e3cb9e7e682 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2221
diff changeset
   494
	     && (! ((INT)(__BlockInstPtr(aBlock)->b_flags) & __MASKSMALLINT(F_DYNAMIC)))) {
5e3cb9e7e682 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2221
diff changeset
   495
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   496
#ifdef NEW_BLOCK_CALL
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   497
#               define BLOCK_ARG        aBlock
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   498
#else
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   499
#               define BLOCK_ARG        rHome
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   500
		REGISTER OBJ rHome;
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   501
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   502
		rHome = __BlockInstPtr(aBlock)->b_home;
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   503
		if ((rHome == nil) || (__qSpace(rHome) >= STACKSPACE)) 
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   504
#endif
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   505
		{
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   506
		    for (; index < nIndex; index++) {
2216
e4fed6c622de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2199
diff changeset
   507
			OBJ element;
e4fed6c622de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2199
diff changeset
   508
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   509
			if (InterruptPending != nil) __interruptL(@line);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   510
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   511
			element = __InstPtr(self)->i_instvars[index];
4311
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   512
			if (__isNonNilObject(element)) {
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   513
			    element = __WEAK_READ__(self, element);
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   514
			}
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   515
			(*codeVal)(BLOCK_ARG, element);
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   516
		    }
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   517
		    RETURN (self);
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   518
		}
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   519
	    }
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   520
	}
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   521
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   522
	/*
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   523
	 * sorry, must check code-pointer in the loop
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   524
	 * it could be recompiled or flushed
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   525
	 */
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   526
#       undef BLOCK_ARG
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   527
#ifdef NEW_BLOCK_CALL
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   528
#       define BLOCK_ARG        aBlock
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   529
#       define IBLOCK_ARG       nil
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   530
#else
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   531
#       define BLOCK_ARG        (__BlockInstPtr(aBlock)->b_home)
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   532
#       define IBLOCK_ARG       (__BlockInstPtr(aBlock)->b_home)
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   533
#endif
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   534
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   535
	for (; index < nIndex; index++) {
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   536
	    REGISTER OBJFUNC codeVal;
2220
17ec32355032 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2216
diff changeset
   537
	    OBJ element;
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   538
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   539
	    if (InterruptPending != nil) __interruptL(@line);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   540
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   541
	    element = __InstPtr(self)->i_instvars[index];
4311
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   542
	    if (__isNonNilObject(element)) {
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   543
		element = __WEAK_READ__(self, element);
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   544
	    }
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   545
	    if ((codeVal = __BlockInstPtr(aBlock)->b_code) != (OBJFUNC)nil) {
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   546
		(*codeVal)(BLOCK_ARG, element);
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   547
	    } else {
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   548
		if (__BlockInstPtr(aBlock)->b_bytecodes != nil) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   549
		    /*
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   550
		     * arg is a compiled block with bytecode -
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   551
		     * directly call interpreter without going through Block>>value
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   552
		     */
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   553
#ifdef PASS_ARG_POINTER
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   554
		    __interpret(aBlock, 1, nil, IBLOCK_ARG, nil, nil, &element);
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   555
#else
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   556
		    __interpret(aBlock, 1, nil, IBLOCK_ARG, nil, nil, element);
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   557
#endif
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   558
		} else {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   559
		    /*
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   560
		     * arg is something else - call it with #value
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   561
		     */
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   562
		    (*val.ilc_func)(aBlock, @symbol(value:), nil, &val, element);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   563
		}
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   564
	    }
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   565
	} 
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   566
	RETURN (self);
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   567
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   568
#       undef BLOCK_ARG
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   569
#       undef IBLOCK_ARG
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   570
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   571
    }
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   572
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   573
    /*
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   574
     * not a block - send it #value:
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   575
     */
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   576
    for (; index < nIndex; index++) {
2216
e4fed6c622de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2199
diff changeset
   577
	OBJ element;
e4fed6c622de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2199
diff changeset
   578
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   579
	if (InterruptPending != nil) __interruptL(@line);
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   580
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   581
	element = __InstPtr(self)->i_instvars[index];
4311
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   582
	if (__isNonNilObject(element)) {
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   583
	    element = __WEAK_READ__(self, element);
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   584
	}
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   585
	(*val.ilc_func)(aBlock, 
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   586
			    @symbol(value:), 
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   587
			    nil, &val, 
981
6da206fcc1c4 keep ref to weak-element somewhere (this is a try)
Claus Gittinger <cg@exept.de>
parents: 829
diff changeset
   588
			    element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   589
    }
981
6da206fcc1c4 keep ref to weak-element somewhere (this is a try)
Claus Gittinger <cg@exept.de>
parents: 829
diff changeset
   590
%}.
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   591
    ^ self
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   592
!
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   593
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   594
forAllDeadIndicesDo:aBlock
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   595
    "evaluate the argument, aBlock for all indices where elements have been
2271
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   596
     replaced by zero (due to a collected object).
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   597
     Be aware, that while indices are being enumerated, other
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   598
     slots may change iff the garbage collector finds new garbage."
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   599
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   600
    self keysAndValuesDo:[:index :element |
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   601
	element == 0 ifTrue:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   602
	     aBlock value:index
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   603
	]
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   604
    ]
2271
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   605
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   606
    "Modified: 25.1.1997 / 14:50:59 / cg"
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   607
!
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   608
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   609
forAllDeadIndicesDo:aBlock replacingCorpsesWith:newValue
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   610
    "evaluate the argument, aBlock for all indices where elements have been
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   611
     replaced by zero (due to a collected object), and replace the element
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   612
     with newValue.
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   613
     In the current implementation, the block sees the newValue (i.e. it is
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   614
     changed before the block is called); this behavior is not guaranteed
2271
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   615
     with future versions.
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   616
     Be aware, that while indices are being enumerated, other
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   617
     slots may change iff the garbage collector finds new garbage."
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   618
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   619
    self keysAndValuesDo:[:index :element |
4310
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   620
	element == 0 ifTrue:[
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   621
	    self at:index put:newValue.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   622
	    aBlock value:index.
7282fde15db3 oops - hard bug fix
Claus Gittinger <cg@exept.de>
parents: 4062
diff changeset
   623
	]
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   624
    ]
2271
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   625
65fe1df5b0b3 commentary
Claus Gittinger <cg@exept.de>
parents: 2254
diff changeset
   626
    "Modified: 25.1.1997 / 14:51:28 / cg"
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   627
!
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   628
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   629
nilAllCorpsesAndDo:aBlock
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   630
    "evaluate the argument, aBlock for all indices where elements have been
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   631
     cleared (due to a collected object), nil the entry."
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   632
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   633
    self forAllDeadIndicesDo:aBlock replacingCorpsesWith:nil
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   634
!
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   635
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   636
nonNilElementsDo:aBlock
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   637
    "evaluate the argument, aBlock for each non-nil element"
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   638
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   639
%{
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   640
    REGISTER int index;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   641
    int nIndex;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   642
    static struct inlineCache val = _ILC1;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   643
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   644
    index = __intVal(__ClassInstPtr(__qClass(self))->c_ninstvars);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   645
    nIndex = __BYTES2OBJS__(__qSize(self) - OHDR_SIZE);
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   646
    if (__isBlockLike(aBlock)
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   647
     && (__BlockInstPtr(aBlock)->b_nargs == __MKSMALLINT(1))) {
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   648
	{
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   649
	    /*
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   650
	     * the most common case: a static compiled block, with home on the stack ...
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   651
	     */
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   652
	    REGISTER OBJFUNC codeVal;
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   653
2254
5e3cb9e7e682 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2221
diff changeset
   654
	    if (((codeVal = __BlockInstPtr(aBlock)->b_code) != (OBJFUNC)nil)
5e3cb9e7e682 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2221
diff changeset
   655
	     && (! ((INT)(__BlockInstPtr(aBlock)->b_flags) & __MASKSMALLINT(F_DYNAMIC)))) {
5e3cb9e7e682 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2221
diff changeset
   656
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   657
#ifdef NEW_BLOCK_CALL
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   658
#               define BLOCK_ARG        aBlock
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   659
#else
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   660
#               define BLOCK_ARG        rHome
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   661
		REGISTER OBJ rHome;
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   662
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   663
		rHome = __BlockInstPtr(aBlock)->b_home;
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   664
		if ((rHome == nil) || (__qSpace(rHome) >= STACKSPACE)) 
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   665
#endif
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   666
		{
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   667
		    for (; index < nIndex; index++) {
2216
e4fed6c622de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2199
diff changeset
   668
			REGISTER OBJ element;
e4fed6c622de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2199
diff changeset
   669
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   670
			element = __InstPtr(self)->i_instvars[index];
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   671
			if (element) {
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   672
			    if (InterruptPending != nil) {
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   673
				__interruptL(@line);
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   674
				element = __InstPtr(self)->i_instvars[index];
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   675
			    }
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   676
4311
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   677
			    if (__isNonNilObject(element)) {
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   678
				element = __WEAK_READ__(self, element);
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   679
			    }
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   680
			    if (element) {
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   681
				(*codeVal)(BLOCK_ARG, element);
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   682
			    }
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   683
			}
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   684
		    }
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   685
		    RETURN (self);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   686
		}
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   687
	    }
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   688
	}
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   689
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   690
	/*
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   691
	 * sorry, must check code-pointer in the loop
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   692
	 * it could be recompiled or flushed
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   693
	 */
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   694
#       undef BLOCK_ARG
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   695
#ifdef NEW_BLOCK_CALL
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   696
#       define BLOCK_ARG        aBlock
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   697
#       define IBLOCK_ARG       nil
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   698
#else
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   699
#       define BLOCK_ARG        (__BlockInstPtr(aBlock)->b_home)
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   700
#       define IBLOCK_ARG       (__BlockInstPtr(aBlock)->b_home)
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   701
#endif
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   702
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   703
	for (; index < nIndex; index++) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   704
	    REGISTER OBJFUNC codeVal;
2220
17ec32355032 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2216
diff changeset
   705
	    OBJ element;
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   706
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   707
	    element = __InstPtr(self)->i_instvars[index];
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   708
	    if (element) {
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   709
		if (InterruptPending != nil) {
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   710
		    __interruptL(@line);
1903
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   711
		    element = __InstPtr(self)->i_instvars[index];
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   712
		}
4311
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   713
		if (__isNonNilObject(element)) {
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   714
		    element = __WEAK_READ__(self, element);
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   715
		}
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   716
		if (element) {
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   717
		    if ((codeVal = __BlockInstPtr(aBlock)->b_code) != (OBJFUNC)nil) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   718
			(*codeVal)(BLOCK_ARG, element);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   719
		    } else {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   720
			if (__BlockInstPtr(aBlock)->b_bytecodes != nil) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   721
			    /*
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   722
			     * arg is a compiled block with bytecode -
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   723
			     * directly call interpreter without going through Block>>value
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   724
			     */
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   725
#ifdef PASS_ARG_POINTER
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   726
			    __interpret(aBlock, 1, nil, IBLOCK_ARG, nil, nil, &element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   727
#else
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   728
			    __interpret(aBlock, 1, nil, IBLOCK_ARG, nil, nil, element);
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   729
#endif
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   730
			} else {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   731
			    /*
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   732
			     * arg is something else - call it with #value
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   733
			     */
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   734
			    (*val.ilc_func)(aBlock, @symbol(value:), nil, &val, element);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   735
			}
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   736
		    }
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   737
		}
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   738
	    } 
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   739
	}
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   740
	RETURN (self);
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   741
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   742
#       undef BLOCK_ARG
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   743
#       undef IBLOCK_ARG
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   744
    }
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   745
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   746
    /*
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   747
     * not a block - send it #value:
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   748
     */
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   749
    for (; index < nIndex; index++) {
2216
e4fed6c622de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2199
diff changeset
   750
	REGISTER OBJ element;
e4fed6c622de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2199
diff changeset
   751
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   752
	element = __InstPtr(self)->i_instvars[index];
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   753
	if (element) {
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   754
	    if (InterruptPending != nil) {
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   755
		__interruptL(@line);
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   756
		element = __InstPtr(self)->i_instvars[index];
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   757
	    }
4311
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   758
	    if (__isNonNilObject(element)) {
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   759
		element = __WEAK_READ__(self, element);
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   760
	    }
2186
a82449c022fc care for blocks being recompiled, or code being flushed while
Claus Gittinger <cg@exept.de>
parents: 2145
diff changeset
   761
	    if (element) {
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   762
		(*val.ilc_func)(aBlock, 
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   763
				    @symbol(value:), 
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   764
				    nil, &val, 
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   765
				    element);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   766
	    }
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   767
	}
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   768
    }
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   769
%}.
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   770
    ^ self
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   771
!
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   772
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   773
validElementsDo:aBlock
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   774
    "evaluate the argument, aBlock for each non-nil/non-zero element"
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   775
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   776
%{
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   777
    REGISTER int index;
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   778
    int nIndex;
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   779
    static struct inlineCache val = _ILC1;
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   780
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   781
    index = __intVal(__ClassInstPtr(__qClass(self))->c_ninstvars);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   782
    nIndex = __BYTES2OBJS__(__qSize(self) - OHDR_SIZE);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   783
    if (__isBlockLike(aBlock)
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   784
     && (__BlockInstPtr(aBlock)->b_nargs == __MKSMALLINT(1))) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   785
	{
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   786
	    /*
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   787
	     * the most common case: a static compiled block, with home on the stack ...
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   788
	     */
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   789
	    REGISTER OBJFUNC codeVal;
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   790
2254
5e3cb9e7e682 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2221
diff changeset
   791
	    if (((codeVal = __BlockInstPtr(aBlock)->b_code) != (OBJFUNC)nil)
5e3cb9e7e682 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2221
diff changeset
   792
	     && (! ((INT)(__BlockInstPtr(aBlock)->b_flags) & __MASKSMALLINT(F_DYNAMIC)))) {
5e3cb9e7e682 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2221
diff changeset
   793
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   794
#ifdef NEW_BLOCK_CALL
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   795
#               define BLOCK_ARG        aBlock
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   796
#else
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   797
#               define BLOCK_ARG        rHome
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   798
		REGISTER OBJ rHome;
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   799
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   800
		rHome = __BlockInstPtr(aBlock)->b_home;
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   801
		if ((rHome == nil) || (__qSpace(rHome) >= STACKSPACE)) 
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   802
#endif
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   803
		{
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   804
		    for (; index < nIndex; index++) {
2216
e4fed6c622de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2199
diff changeset
   805
			REGISTER OBJ element;
e4fed6c622de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2199
diff changeset
   806
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   807
			element = __InstPtr(self)->i_instvars[index];
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   808
			if (element && (element != __MKSMALLINT(0))) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   809
			    if (InterruptPending != nil) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   810
				__interruptL(@line);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   811
				element = __InstPtr(self)->i_instvars[index];
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   812
			    }
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   813
4311
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   814
			    if (__isNonNilObject(element)) {
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   815
				element = __WEAK_READ__(self, element);
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   816
			    }
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   817
			    if (element && (element != __MKSMALLINT(0))) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   818
				(*codeVal)(BLOCK_ARG, element);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   819
			    }
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   820
			}
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   821
		    }
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   822
		    RETURN (self);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   823
		}
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   824
	    }
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   825
	}
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   826
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   827
	/*
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   828
	 * sorry, must check code-pointer in the loop
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   829
	 * it could be recompiled or flushed
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   830
	 */
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   831
#       undef BLOCK_ARG
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   832
#ifdef NEW_BLOCK_CALL
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   833
#       define BLOCK_ARG        aBlock
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   834
#       define IBLOCK_ARG       nil
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   835
#else
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   836
#       define BLOCK_ARG        (__BlockInstPtr(aBlock)->b_home)
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   837
#       define IBLOCK_ARG       (__BlockInstPtr(aBlock)->b_home)
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   838
#endif
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   839
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   840
	for (; index < nIndex; index++) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   841
	    REGISTER OBJFUNC codeVal;
2220
17ec32355032 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2216
diff changeset
   842
	    OBJ element;
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   843
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   844
	    element = __InstPtr(self)->i_instvars[index];
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   845
	    if (element && (element != __MKSMALLINT(0))) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   846
		if (InterruptPending != nil) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   847
		    __interruptL(@line);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   848
		    element = __InstPtr(self)->i_instvars[index];
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   849
		}
4311
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   850
		if (__isNonNilObject(element)) {
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   851
		    element = __WEAK_READ__(self, element);
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   852
		}
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   853
		if (element && (element != __MKSMALLINT(0))) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   854
		    if ((codeVal = __BlockInstPtr(aBlock)->b_code) != (OBJFUNC)nil) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   855
			(*codeVal)(BLOCK_ARG, element);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   856
		    } else {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   857
			if (__BlockInstPtr(aBlock)->b_bytecodes != nil) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   858
			    /*
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   859
			     * arg is a compiled block with bytecode -
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   860
			     * directly call interpreter without going through Block>>value
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   861
			     */
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   862
#ifdef PASS_ARG_POINTER
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   863
			    __interpret(aBlock, 1, nil, IBLOCK_ARG, nil, nil, &element);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   864
#else
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   865
			    __interpret(aBlock, 1, nil, IBLOCK_ARG, nil, nil, element);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   866
#endif
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   867
			} else {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   868
			    /*
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   869
			     * arg is something else - call it with #value
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   870
			     */
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   871
			    (*val.ilc_func)(aBlock, @symbol(value:), nil, &val, element);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   872
			}
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   873
		    }
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   874
		}
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   875
	    } 
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   876
	}
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   877
	RETURN (self);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   878
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   879
#       undef BLOCK_ARG
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   880
#       undef IBLOCK_ARG
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   881
    }
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   882
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   883
    /*
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   884
     * not a block - send it #value:
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   885
     */
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   886
    for (; index < nIndex; index++) {
2216
e4fed6c622de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2199
diff changeset
   887
	REGISTER OBJ element;
e4fed6c622de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 2199
diff changeset
   888
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   889
	element = __InstPtr(self)->i_instvars[index];
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   890
	if (element && (element != __MKSMALLINT(0))) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   891
	    if (InterruptPending != nil) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   892
		__interruptL(@line);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   893
		element = __InstPtr(self)->i_instvars[index];
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   894
	    }
4311
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   895
	    if (__isNonNilObject(element)) {
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   896
		element = __WEAK_READ__(self, element);
7c622aa9e980 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 4310
diff changeset
   897
	    }
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   898
	    if (element && (element != __MKSMALLINT(0))) {
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   899
		(*val.ilc_func)(aBlock, 
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   900
				    @symbol(value:), 
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   901
				    nil, &val, 
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   902
				    element);
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   903
	    }
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   904
	}
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   905
    }
604
0e1ec470923d extern declaration
Claus Gittinger <cg@exept.de>
parents: 603
diff changeset
   906
%}.
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   907
    ^ self
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   908
! !
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   909
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   910
!WeakArray methodsFor:'notification'!
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   911
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   912
lostPointer
2091
c11bb3e29a1b Use dependent mechamism of WeakArray instead of #watcher.
Stefan Vogel <sv@exept.de>
parents: 1903
diff changeset
   913
    "I lost a pointer; tell dependents.
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   914
     This is sent from the finalization code in ObjectMemory."
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   915
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   916
    dependents notNil ifTrue:[
2189
618dcdc1cee9 added #validElementsDo:
Claus Gittinger <cg@exept.de>
parents: 2186
diff changeset
   917
	self changed:#ElementExpired with:nil.
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   918
    ].
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   919
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   920
    "Modified: 18.10.1996 / 21:28:10 / cg"
2091
c11bb3e29a1b Use dependent mechamism of WeakArray instead of #watcher.
Stefan Vogel <sv@exept.de>
parents: 1903
diff changeset
   921
    "Modified: 7.1.1997 / 17:22:52 / stefan"
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   922
! !
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   923
628
7aa563e4c64a version at the end
Claus Gittinger <cg@exept.de>
parents: 604
diff changeset
   924
!WeakArray class methodsFor:'documentation'!
7aa563e4c64a version at the end
Claus Gittinger <cg@exept.de>
parents: 604
diff changeset
   925
7aa563e4c64a version at the end
Claus Gittinger <cg@exept.de>
parents: 604
diff changeset
   926
version
5334
f8837914d424 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 4730
diff changeset
   927
    ^ '$Header: /cvs/stx/stx/libbasic/WeakArray.st,v 1.57 2000-03-28 17:39:48 cg Exp $'
628
7aa563e4c64a version at the end
Claus Gittinger <cg@exept.de>
parents: 604
diff changeset
   928
! !
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   929
WeakArray initialize!