WeakArray.st
author Stefan Vogel <sv@exept.de>
Wed, 08 Jan 1997 20:42:17 +0100
changeset 2091 c11bb3e29a1b
parent 1903 30c98b3377c5
child 2145 d243ffafeae3
permissions -rw-r--r--
Use dependent mechamism of WeakArray instead of #watcher. Remove deprecated watcher stuff.
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
2091
c11bb3e29a1b Use dependent mechamism of WeakArray instead of #watcher.
Stefan Vogel <sv@exept.de>
parents: 1903
diff changeset
    13
'From Smalltalk/X, Version:3.1.3 on 7-jan-1997 at 17:23:10'                     !
c11bb3e29a1b Use dependent mechamism of WeakArray instead of #watcher.
Stefan Vogel <sv@exept.de>
parents: 1903
diff changeset
    14
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
    15
Array subclass:#WeakArray
2091
c11bb3e29a1b Use dependent mechamism of WeakArray instead of #watcher.
Stefan Vogel <sv@exept.de>
parents: 1903
diff changeset
    16
	instanceVariableNames:'dependents'
1263
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
    17
	classVariableNames:'RegistrationFailedSignal AlreadyInitialized'
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
    18
	poolDictionaries:''
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
    19
	category:'Collections-Arrayed'
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
    20
!
62211a9bc04d Initial revision
claus
parents:
diff changeset
    21
62211a9bc04d Initial revision
claus
parents:
diff changeset
    22
!WeakArray class methodsFor:'documentation'!
62211a9bc04d Initial revision
claus
parents:
diff changeset
    23
88
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    24
copyright
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    25
"
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    26
 COPYRIGHT (c) 1991 by Claus Gittinger
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
    27
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    28
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    29
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    30
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    32
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    33
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    34
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    35
"
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    36
!
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    37
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
    38
documentation
62211a9bc04d Initial revision
claus
parents:
diff changeset
    39
"
88
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    40
    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
    41
    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
    42
    garbage collected.
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    43
    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
    44
    and the WeakArray is informed by the storage manager. The WeakArray itself
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    45
    then informs possible dependents via te dependency mechanism.
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    46
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
    47
    WeakArrays are used to track disposal of objects which keep external
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    48
    world resources. For example, FileStreams must close their underlying
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    49
    file when disposed (otherwise you could run out of OS filedescriptors).
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    50
    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
    51
    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
    52
    freed, search both arrays for an index where the stream is zero, but the
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    53
    filedescriptor is non-nil. Then close that file, and nil the filedescriptor
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    54
    entry. Notice, that there is a class (Registry) which does exactly this in
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    55
    a more programmer friendly way.
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    56
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    57
    Another application is caching of data: keep it in a weakArray, so the
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    58
    data in that cache will not be unreclaimable due to being cached.
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
    59
    (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
    60
     used resource data for a while).
88
81dacba7a63a *** empty log message ***
claus
parents: 44
diff changeset
    61
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
    62
    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
    63
    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
    64
    (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
    65
    notify all weakArrays via the #lostPointer message.
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    66
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    67
    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
    68
    possible to run the finalization code at lower priority or from another class. 
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
    69
    Also, as a side effect, it is possible to delay finalization by blocking 
216
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
    70
    interrupts.
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
    71
2091
c11bb3e29a1b Use dependent mechamism of WeakArray instead of #watcher.
Stefan Vogel <sv@exept.de>
parents: 1903
diff changeset
    72
    A weakArray notifies its dependents via normal dependency notfications.
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
    73
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    74
    NOTICE: 
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    75
        WeakArray handling adds some overhead to the VM 
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    76
        (each weakarray is scanned after each GC). 
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    77
        It is uncertain, if the current mechanism works well
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    78
        with (say) ten-thousands of weakArrays.
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    79
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    80
    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
    81
    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
    82
    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
    83
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    84
1290
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 1263
diff changeset
    85
    [instance variables:]
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    86
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    87
        dependents                      get informed via #change notifiction 
1263
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
    88
                                        that the weakArray has lost pointers.
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
    89
                                        Having the dependents here is an optimization.
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    90
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    91
1290
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 1263
diff changeset
    92
    [class variables:]
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
    93
1263
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
    94
        RegistrationFailedSignal        raised if a weakArray cannot be
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
    95
                                        registered by the VM. This only happens,
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
    96
                                        if the VM has to resize its shadow tables
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
    97
                                        and is running out of malloc-memory.
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
    98
1290
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 1263
diff changeset
    99
    [author:]
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 1263
diff changeset
   100
        Claus Gittinger
15ba3221b89b documentation
Claus Gittinger <cg@exept.de>
parents: 1263
diff changeset
   101
1263
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
   102
    [See also:]
92c1db6b0776 commentary
Claus Gittinger <cg@exept.de>
parents: 1178
diff changeset
   103
        Array WeakIdentitySet WeakIdentityDictionary
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   104
"
62211a9bc04d Initial revision
claus
parents:
diff changeset
   105
! !
62211a9bc04d Initial revision
claus
parents:
diff changeset
   106
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   107
!WeakArray class methodsFor:'initialization'!
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   108
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   109
initialize
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   110
    "setup the private signal"
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   111
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   112
    RegistrationFailedSignal isNil ifTrue:[
302
1f76060d58a4 *** empty log message ***
claus
parents: 290
diff changeset
   113
	RegistrationFailedSignal := ErrorSignal newSignalMayProceed:true.
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   114
	RegistrationFailedSignal nameClass:self message:#registrationFailedSignal.
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   115
	RegistrationFailedSignal notifierString:'weakArray registration failed'.
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   116
    ]
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   117
! !
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   118
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   119
!WeakArray class methodsFor:'instance creation'!
62211a9bc04d Initial revision
claus
parents:
diff changeset
   120
62211a9bc04d Initial revision
claus
parents:
diff changeset
   121
new:size
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   122
    "return a new weakArray with size slots"
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   123
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   124
    "This is a kludge: I would like to set WEAK-flag in the classes
216
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   125
     initialize method, but (currently) the order in which the class-initialize
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   126
     methods are called is not defined ...
216
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   127
     ... therefore it could happen, that a WeakArray is used by other
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   128
     classes initialize method BEFORE this method is evaluated. 
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   129
     To avoid this, the WEAK bit in the class is set here, when the very first 
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   130
     WeakArray is created."
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   131
216
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   132
    AlreadyInitialized isNil ifTrue:[
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   133
	self flags:(Behavior flagWeakPointers).
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   134
	AlreadyInitialized := true
a8abff749575 *** empty log message ***
claus
parents: 186
diff changeset
   135
    ].
95
d22739a0c6e9 *** empty log message ***
claus
parents: 88
diff changeset
   136
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   137
    ^ (self basicNew:size) registerAsWeakArray
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   138
! !
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   139
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   140
!WeakArray methodsFor:'GC registration'!
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   141
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   142
registerAsWeakArray
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   143
    "register the receiver in the VM - 
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   144
     i.e. tell the VM to nil disposed entries in the receiver
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   145
     and notify the disposeInterruptHandler whenever that happened."
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   146
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   147
    |ok|
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   148
%{
62211a9bc04d Initial revision
claus
parents:
diff changeset
   149
    OBJ __addShadowObject();
62211a9bc04d Initial revision
claus
parents:
diff changeset
   150
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   151
    ok = __addShadowObject(self, 0);
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   152
    if (ok == false) {
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   153
	/* 
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   154
	 * this happens when too many shadow objects are
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   155
	 * already there, collect garbage to get rid of
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   156
	 * obsolete ones, and try again.
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   157
	 * since a full collect is expensive, we try
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   158
	 * a scavenge first, doing a full collect only if 
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   159
	 * that does not help.
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   160
	 *
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   161
	 * THIS MAY OR MAY NOT BE A GOOD IDEA: although it reduces
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   162
	 * the number of shadow objects that have to be
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   163
	 * processed at GC time, it may create a long delay here,
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   164
	 * at shadow object creation time.
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   165
	 * Dont know which is better ...
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   166
	 */
326
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
   167
	__nonTenuringScavenge(__context);
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   168
	ok = __addShadowObject(self, 0);
308
f04744ef7b5d *** empty log message ***
claus
parents: 302
diff changeset
   169
#ifdef OLD
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   170
	if (ok == false) {
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   171
	    /* 
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   172
	     * try more ... 
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   173
	     */
326
d2902942491d *** empty log message ***
claus
parents: 308
diff changeset
   174
	    __scavenge(__context);
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   175
	    ok = __addShadowObject(self, 0);
308
f04744ef7b5d *** empty log message ***
claus
parents: 302
diff changeset
   176
#endif
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   177
	    if (ok == false) {
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   178
		/* 
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   179
		 * hard stuff - need full collect
462
fdccb7651d2e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   180
		 * if this is the very first GC, assume that we are in
fdccb7651d2e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   181
		 * the startup phase. Then do no GC.
fdccb7651d2e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   182
		 * Heuristics showed, that this GC does not find much ...
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   183
		 */
1127
990dc1e1065e no more global data
Claus Gittinger <cg@exept.de>
parents: 981
diff changeset
   184
		if ((__garbageCollectCount() != 0)
990dc1e1065e no more global data
Claus Gittinger <cg@exept.de>
parents: 981
diff changeset
   185
		 || (__incrementalGCCount() != 0)) {
462
fdccb7651d2e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   186
		    __markAndSweepIfUseful(__context);
fdccb7651d2e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   187
		    ok = __addShadowObject(self, 0);
fdccb7651d2e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 384
diff changeset
   188
		}
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   189
		if (ok == false) {
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   190
		    /*
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   191
		     * mhmh - it seems that there are really many shadow 
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   192
		     * objects around - force creation
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   193
		     */
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   194
		    ok = __addShadowObject(self, 1);
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   195
		    if (ok == false) {
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   196
			/* no chance - something must be wrong */
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   197
		    }
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   198
		}
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   199
	    }
308
f04744ef7b5d *** empty log message ***
claus
parents: 302
diff changeset
   200
#ifdef OLD
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   201
	}
308
f04744ef7b5d *** empty log message ***
claus
parents: 302
diff changeset
   202
#endif
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   203
    }
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   204
%}.
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   205
    ok ifFalse:[
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   206
	"
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   207
	 the VM was not able to register the new weakArray
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   208
	 This can only happen, if the VM has to resize its tables,
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   209
	 and a malloc request failed. Usually, this smells like big
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   210
	 trouble being on the way (soon running out of memory in
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   211
	 other places as well).
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   212
	 Configure your OS for more swap space.
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   213
	"
186
a4c3032fc825 *** empty log message ***
claus
parents: 159
diff changeset
   214
	^ RegistrationFailedSignal raiseRequestWith:self
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   215
    ]
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   216
! !
62211a9bc04d Initial revision
claus
parents:
diff changeset
   217
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   218
!WeakArray methodsFor:'accessing'!
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   219
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   220
at:index
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   221
    "return the indexed instance variable with index, anInteger.
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   222
     Reimplemented here for IGC readBarrier. You dont have to understand this."
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   223
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   224
    ^ self basicAt:index
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   225
!
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   226
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   227
basicAt:index
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   228
    "return the indexed instance variable with index, anInteger.
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   229
     Reimplemented here for IGC readBarrier. You dont have to understand this."
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   230
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   231
%{  /* NOCONTEXT */
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   232
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   233
    REGISTER int indx;
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   234
    REGISTER unsigned int nIndex;
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   235
    OBJ el;
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   236
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   237
    if (__isSmallInteger(index)) {
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   238
	indx = __intVal(index) - 1;
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   239
	if (indx >= 0) {
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   240
	    nIndex = __BYTES2OBJS__(__qSize(self) - OHDR_SIZE);
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   241
	    indx += __intVal(__ClassInstPtr(__qClass(self))->c_ninstvars);
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   242
	    if (indx < nIndex) {
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   243
		el = __InstPtr(self)->i_instvars[indx];
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   244
		if (__isNonNilObject(el)) el = __WEAK_READ__(self, el);
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   245
		RETURN (el);
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   246
	    }
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   247
	}
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
%}.
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   250
    ^ super basicAt:index
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   251
!
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   252
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   253
dependents 
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   254
    "return the dependents of the receiver"
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   255
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   256
    ^ dependents
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   257
!
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   258
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   259
dependents:aCollection
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   260
    "set the dependents of the receiver"
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   261
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   262
    dependents := aCollection
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   263
! !
62211a9bc04d Initial revision
claus
parents:
diff changeset
   264
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   265
!WeakArray methodsFor:'copying'!
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   266
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   267
postCopy
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   268
    "copying alone does not really help - we have to tell
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   269
     the VM, that there is a new WeakArray around ...
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   270
     Q: who copies weakArrays ?"
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   271
290
23994c0a7f7b *** empty log message ***
claus
parents: 216
diff changeset
   272
    dependents := nil.
159
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   273
    self registerAsWeakArray.
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   274
! !
514c749165c3 *** empty log message ***
claus
parents: 95
diff changeset
   275
1825
6f81b866a74a category rename
Claus Gittinger <cg@exept.de>
parents: 1785
diff changeset
   276
!WeakArray methodsFor:'enumerating'!
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   277
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   278
do:aBlock
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   279
    "evaluate the argument, aBlock for each element in the collection.
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   280
     - reimplemented for IGC readBarrier. You dont have to understand this."
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   281
981
6da206fcc1c4 keep ref to weak-element somewhere (this is a try)
Claus Gittinger <cg@exept.de>
parents: 829
diff changeset
   282
    |home element|
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   283
%{
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   284
    REGISTER OBJFUNC codeVal;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   285
    REGISTER int index;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   286
    unsigned int nIndex;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   287
    static struct inlineCache val = _ILC1;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   288
    REGISTER OBJ rHome;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   289
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   290
    index = __intVal(__ClassInstPtr(__qClass(self))->c_ninstvars);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   291
    nIndex = __BYTES2OBJS__(__qSize(self) - OHDR_SIZE);
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   292
    if (__isBlockLike(aBlock)
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   293
     && ((codeVal = __BlockInstPtr(aBlock)->b_code) != (OBJFUNC)nil)
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   294
     && (__BlockInstPtr(aBlock)->b_nargs == __MKSMALLINT(1))) {
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   295
#ifdef NEW_BLOCK_CALL
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   296
	for (; index < nIndex; index++) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   297
	    if (InterruptPending != nil) __interruptL(@line);
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   298
	    element = __InstPtr(self)->i_instvars[index];
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   299
	    if (__isNonNilObject(element)) element = __WEAK_READ__(self, element);
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   300
	    (*codeVal)(aBlock, element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   301
	} 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   302
#else
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   303
	home = __BlockInstPtr(aBlock)->b_home;
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   304
	rHome = home;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   305
	if ((rHome == nil) || (__qSpace(rHome) >= STACKSPACE)) {
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   306
	    /*
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   307
	     * home will not move - keep in a fast register
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   308
	     */
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   309
	    for (; index < nIndex; index++) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   310
		if (InterruptPending != nil) __interruptL(@line);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   311
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   312
		element = __InstPtr(self)->i_instvars[index];
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   313
	        if (__isNonNilObject(element)) element = __WEAK_READ__(self, element);
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   314
		(*codeVal)(rHome, element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   315
	    } 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   316
	} else {
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   317
	    for (; index < nIndex; index++) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   318
		if (InterruptPending != nil) __interruptL(@line);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   319
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   320
		element = __InstPtr(self)->i_instvars[index];
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   321
	        if (__isNonNilObject(element)) element = __WEAK_READ__(self, element);
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   322
		(*codeVal)(home, element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   323
	    } 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   324
	} 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   325
#endif
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   326
    } else {
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   327
	for (; index < nIndex; index++) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   328
	    if (InterruptPending != nil) __interruptL(@line);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   329
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   330
	    element = __InstPtr(self)->i_instvars[index];
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   331
	    if (__isNonNilObject(element)) element = __WEAK_READ__(self, element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   332
	    (*val.ilc_func)(aBlock, 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   333
			    @symbol(value:), 
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   334
			    nil, &val, 
981
6da206fcc1c4 keep ref to weak-element somewhere (this is a try)
Claus Gittinger <cg@exept.de>
parents: 829
diff changeset
   335
			    element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   336
	} 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   337
    }
981
6da206fcc1c4 keep ref to weak-element somewhere (this is a try)
Claus Gittinger <cg@exept.de>
parents: 829
diff changeset
   338
%}.
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   339
    ^ self
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   340
!
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   341
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   342
forAllDeadIndicesDo:aBlock
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   343
    "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
   344
     replaced by zero (due to a collected object)."
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   345
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   346
    self keysAndValuesDo:[:index :element |
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   347
	element == 0 ifTrue:[
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   348
	     aBlock value:index
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   349
	]
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   350
    ]
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   351
!
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   352
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   353
forAllDeadIndicesDo:aBlock replacingCorpsesWith:newValue
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   354
    "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
   355
     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
   356
     with newValue.
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   357
     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
   358
     changed before the block is called); this behavior is not guaranteed
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   359
     with future versions."
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   360
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   361
    self keysAndValuesDo:[:index :element |
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   362
	element == 0 ifTrue:[
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   363
	    self at:index put:newValue.
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   364
	    aBlock value:index.
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   365
	]
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   366
    ]
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   367
!
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   368
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   369
from:start to:stop do:aBlock
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   370
    "evaluate the argument, aBlock for the elements starting at index start
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   371
     up to (and including) stop in the collection.
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   372
     - reimplemented for IGC readBarrier. You dont have to understand this."
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   373
981
6da206fcc1c4 keep ref to weak-element somewhere (this is a try)
Claus Gittinger <cg@exept.de>
parents: 829
diff changeset
   374
    |home element|
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   375
%{
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   376
    REGISTER OBJFUNC codeVal;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   377
    REGISTER int index;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   378
    REGISTER OBJ rHome;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   379
    int nIndex, nInsts;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   380
    static struct inlineCache val = _ILC1;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   381
    int indexLow, indexHigh;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   382
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   383
    if (__bothSmallInteger(start, stop)) {
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   384
	indexLow = __intVal(start);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   385
	if (indexLow > 0) {
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   386
	    indexHigh = __intVal(stop);
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   387
	    nInsts = __intVal(__ClassInstPtr(__qClass(self))->c_ninstvars);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   388
	    indexLow += nInsts;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   389
	    indexHigh += nInsts;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   390
	    nIndex = __BYTES2OBJS__(__qSize(self) - OHDR_SIZE);
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   391
	    if (indexHigh <= nIndex) {
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   392
		indexLow--;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   393
		indexHigh--;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   394
		if (__isBlockLike(aBlock)
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   395
		 && ((codeVal = __BlockInstPtr(aBlock)->b_code) != (OBJFUNC)nil)
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   396
		 && (__BlockInstPtr(aBlock)->b_nargs == __MKSMALLINT(1))) {
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   397
#ifdef NEW_BLOCK_CALL
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   398
		    for (index=indexLow; index <= indexHigh; index++) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   399
			if (InterruptPending != nil) __interruptL(@line);
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   400
			element = __InstPtr(self)->i_instvars[index];
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   401
	    		if (__isNonNilObject(element)) element = __WEAK_READ__(self, element);
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   402
			(*codeVal)(aBlock, element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   403
		    } 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   404
#else
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   405
		    home = __BlockInstPtr(aBlock)->b_home;
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   406
		    rHome = home;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   407
		    if ((rHome == nil) || (__qSpace(rHome) >= STACKSPACE)) {
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   408
			index = indexLow;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   409
			for (; index <= indexHigh; index++) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   410
			    if (InterruptPending != nil) __interruptL(@line);
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   411
			    element = __InstPtr(self)->i_instvars[index];
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   412
	    		    if (__isNonNilObject(element)) element = __WEAK_READ__(self, element);
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   413
			    (*codeVal)(rHome, element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   414
			} 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   415
		    } else {
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   416
			for (index=indexLow; index <= indexHigh; index++) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   417
			    if (InterruptPending != nil) __interruptL(@line);
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   418
			    element = __InstPtr(self)->i_instvars[index];
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   419
	    		    if (__isNonNilObject(element)) element = __WEAK_READ__(self, element);
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   420
			    (*codeVal)(home, element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   421
			} 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   422
		    }
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   423
#endif
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   424
		} else {
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   425
		    for (index=indexLow; index <= indexHigh; index++) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   426
			if (InterruptPending != nil) __interruptL(@line);
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   427
			element = __InstPtr(self)->i_instvars[index];
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   428
	    		if (__isNonNilObject(element)) element = __WEAK_READ__(self, element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   429
			(*val.ilc_func) (aBlock, 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   430
					 @symbol(value:), 
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   431
					 nil, &val, 
981
6da206fcc1c4 keep ref to weak-element somewhere (this is a try)
Claus Gittinger <cg@exept.de>
parents: 829
diff changeset
   432
					 element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   433
		    } 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   434
		}
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   435
	    }
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   436
	    RETURN ( self );
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   437
	}
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   438
    }
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   439
%}.
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   440
    ^ super from:start to:stop do:aBlock
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   441
!
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   442
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   443
keysAndValuesDo:aBlock
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   444
    "evaluate the argument, aBlock for each element in the collection.
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   445
     Pass both index and element to the block.
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   446
     - reimplemented for speed"
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   447
981
6da206fcc1c4 keep ref to weak-element somewhere (this is a try)
Claus Gittinger <cg@exept.de>
parents: 829
diff changeset
   448
    |home element|
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   449
%{
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   450
    REGISTER OBJFUNC codeVal;
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   451
    REGISTER int index;
1782
76bcca2667a8 oops - keysAndValuesDo: passed the wrong index
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
   452
    unsigned int nIndex, index0;
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   453
    static struct inlineCache val2 = _ILC2;
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   454
    REGISTER OBJ rHome;
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   455
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   456
    index = __intVal(__ClassInstPtr(__qClass(self))->c_ninstvars);
1782
76bcca2667a8 oops - keysAndValuesDo: passed the wrong index
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
   457
    index0 = index;
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   458
    nIndex = __BYTES2OBJS__(__qSize(self) - OHDR_SIZE);
1782
76bcca2667a8 oops - keysAndValuesDo: passed the wrong index
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
   459
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   460
    if (__isBlockLike(aBlock)
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   461
     && ((codeVal = __BlockInstPtr(aBlock)->b_code) != (OBJFUNC)nil)
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   462
     && (__BlockInstPtr(aBlock)->b_nargs == __MKSMALLINT(2))) {
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   463
#ifdef NEW_BLOCK_CALL
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   464
	for (; index < nIndex; index++) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   465
	    if (InterruptPending != nil) __interruptL(@line);
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   466
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   467
	    element = __InstPtr(self)->i_instvars[index];
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   468
	    if (__isNonNilObject(element)) element = __WEAK_READ__(self, element);
1782
76bcca2667a8 oops - keysAndValuesDo: passed the wrong index
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
   469
	    (*codeVal)(aBlock, __MKSMALLINT(index+1-index0), element);
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   470
	} 
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   471
#else
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   472
	home = __BlockInstPtr(aBlock)->b_home;
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   473
	rHome = home;
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   474
	if ((rHome == nil) || (__qSpace(rHome) >= STACKSPACE)) {
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   475
	    /*
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   476
	     * home will not move - keep in a fast register
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   477
	     */
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   478
	    while (index < nIndex) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   479
		if (InterruptPending != nil) __interruptL(@line);
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   480
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   481
		element = __InstPtr(self)->i_instvars[index];
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   482
	        if (__isNonNilObject(element)) element = __WEAK_READ__(self, element);
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   483
		index++;
1782
76bcca2667a8 oops - keysAndValuesDo: passed the wrong index
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
   484
		(*codeVal)(rHome, __MKSMALLINT(index-index0), element);
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   485
	    } 
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   486
	} else {
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   487
	    while (index < nIndex) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   488
		if (InterruptPending != nil) __interruptL(@line);
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   489
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   490
		element = __InstPtr(self)->i_instvars[index];
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   491
	        if (__isNonNilObject(element)) element = __WEAK_READ__(self, element);
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   492
		index++;
1782
76bcca2667a8 oops - keysAndValuesDo: passed the wrong index
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
   493
		(*codeVal)(home, __MKSMALLINT(index-index0), element);
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   494
	    } 
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   495
	} 
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   496
#endif
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   497
    } else {
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   498
	while (index < nIndex) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   499
	    if (InterruptPending != nil) __interruptL(@line);
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   500
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   501
	    element = __InstPtr(self)->i_instvars[index];
1780
1b3a4ddc5b94 changed WeakArray to set emptied slots to zero
Claus Gittinger <cg@exept.de>
parents: 1688
diff changeset
   502
	    if (__isNonNilObject(element)) element = __WEAK_READ__(self, element);
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   503
	    index++;
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   504
	    (*val2.ilc_func)(aBlock, 
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   505
			    @symbol(value:value:), 
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   506
			    nil, &val2,
1782
76bcca2667a8 oops - keysAndValuesDo: passed the wrong index
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
   507
			    __MKSMALLINT(index-index0),
981
6da206fcc1c4 keep ref to weak-element somewhere (this is a try)
Claus Gittinger <cg@exept.de>
parents: 829
diff changeset
   508
			    element);
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   509
	} 
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   510
    }
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   511
%}.
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   512
    ^ self
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   513
!
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   514
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   515
nilAllCorpsesAndDo:aBlock
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   516
    "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
   517
     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
   518
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   519
    self forAllDeadIndicesDo:aBlock replacingCorpsesWith:nil
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   520
!
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   521
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   522
nonNilElementsDo:aBlock
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   523
    "evaluate the argument, aBlock for each non-nil element"
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   524
981
6da206fcc1c4 keep ref to weak-element somewhere (this is a try)
Claus Gittinger <cg@exept.de>
parents: 829
diff changeset
   525
    |home element|
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   526
%{
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   527
    REGISTER OBJFUNC codeVal;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   528
    REGISTER int index;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   529
    int nIndex;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   530
    static struct inlineCache val = _ILC1;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   531
    REGISTER OBJ rHome;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   532
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   533
    index = __intVal(__ClassInstPtr(__qClass(self))->c_ninstvars);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   534
    nIndex = __BYTES2OBJS__(__qSize(self) - OHDR_SIZE);
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   535
    if (__isBlockLike(aBlock)
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   536
     && ((codeVal = __BlockInstPtr(aBlock)->b_code) != (OBJFUNC)nil)
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   537
     && (__BlockInstPtr(aBlock)->b_nargs == __MKSMALLINT(1))) {
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   538
#ifdef NEW_BLOCK_CALL
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   539
	for (; index < nIndex; index++) {
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   540
	    element = __InstPtr(self)->i_instvars[index];
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   541
	    if (element != nil) {
1903
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   542
		if (InterruptPending != nil) {
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   543
		    __interruptL(CONARG);
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   544
		    /* refetch; who knows what is done in the interrupt ... */
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   545
		    element = __InstPtr(self)->i_instvars[index];
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   546
		}
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   547
		element = __WEAK_READ__(self, element);
759
908363ce8a32 interest is written with one 'r' (shame on me)
Claus Gittinger <cg@exept.de>
parents: 681
diff changeset
   548
		if (element != nil) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   549
		    (*codeVal)(aBlock, element);
759
908363ce8a32 interest is written with one 'r' (shame on me)
Claus Gittinger <cg@exept.de>
parents: 681
diff changeset
   550
		}
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   551
	    }
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   552
	} 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   553
#else
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   554
	home = __BlockInstPtr(aBlock)->b_home;
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   555
	rHome = home;
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   556
	if ((rHome == nil) || (__qSpace(rHome) >= STACKSPACE)) {
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   557
	    /*
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   558
	     * home will not move - keep in in a register
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   559
	     */
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   560
	    for (; index < nIndex; index++) {
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   561
		element = __InstPtr(self)->i_instvars[index];
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   562
		if (element != nil) {
1903
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   563
		    if (InterruptPending != nil) {
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   564
			__interruptL(CONARG);
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   565
			/* refetch; who knows what is done in the interrupt ... */
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   566
			element = __InstPtr(self)->i_instvars[index];
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   567
		    }
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   568
		    element = __WEAK_READ__(self, element);
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   569
		    if (element != nil) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   570
			(*codeVal)(rHome, element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   571
		    }
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   572
		}
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   573
	    } 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   574
	} else {
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   575
	    for (; index < nIndex; index++) {
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   576
		element = __InstPtr(self)->i_instvars[index];
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   577
		if (element != nil) {
1903
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   578
		    if (InterruptPending != nil) {
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   579
			__interruptL(@line CONARG);
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   580
			/* refetch; who knows what is done in the interrupt ... */
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   581
			element = __InstPtr(self)->i_instvars[index];
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   582
		    }
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   583
		    element = __WEAK_READ__(self, element);
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   584
		    if (element != nil) {
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   585
			(*codeVal)(home, element);
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   586
		    }
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   587
		}
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   588
	    }
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   589
	} 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   590
#endif
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   591
    } else {
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   592
	for (; index < nIndex; index++) {
1136
898af060dfde underline cleanup
Claus Gittinger <cg@exept.de>
parents: 1127
diff changeset
   593
	    element = __InstPtr(self)->i_instvars[index];
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   594
	    if (element != nil) {
1903
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   595
		if (InterruptPending != nil) {
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   596
		    __interruptL(@line CONARG);
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   597
		    /* refetch; who knows what is done in the interrupt ... */
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   598
		    element = __InstPtr(self)->i_instvars[index];
30c98b3377c5 slight tuning
Claus Gittinger <cg@exept.de>
parents: 1825
diff changeset
   599
		}
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   600
		element = __WEAK_READ__(self, element);
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   601
		if (element != nil) {
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   602
		    (*val.ilc_func)(aBlock, 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   603
				    @symbol(value:), 
1688
8a42db1eea60 removed all COMMA_CON / CON_COMMA uses
Claus Gittinger <cg@exept.de>
parents: 1290
diff changeset
   604
				    nil, &val, 
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   605
				    element);
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   606
		}
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   607
	    }
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   608
	} 
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   609
    }
604
0e1ec470923d extern declaration
Claus Gittinger <cg@exept.de>
parents: 603
diff changeset
   610
%}.
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   611
    ^ self
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   612
! !
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   613
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   614
!WeakArray methodsFor:'notification'!
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   615
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   616
lostPointer
2091
c11bb3e29a1b Use dependent mechamism of WeakArray instead of #watcher.
Stefan Vogel <sv@exept.de>
parents: 1903
diff changeset
   617
    "I lost a pointer; tell dependents.
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   618
     This is sent from the finalization code in ObjectMemory."
586
cab695f942a6 weakArray readBarrier for IGC
Claus Gittinger <cg@exept.de>
parents: 530
diff changeset
   619
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   620
    dependents notNil ifTrue:[
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   621
        self changed:#ElementExpired with:nil.
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   622
    ].
1785
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   623
4b18823528b8 commentary & change-aspect made ST-80 compatible
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
   624
    "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
   625
    "Modified: 7.1.1997 / 17:22:52 / stefan"
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   626
! !
6
62211a9bc04d Initial revision
claus
parents:
diff changeset
   627
628
7aa563e4c64a version at the end
Claus Gittinger <cg@exept.de>
parents: 604
diff changeset
   628
!WeakArray class methodsFor:'documentation'!
7aa563e4c64a version at the end
Claus Gittinger <cg@exept.de>
parents: 604
diff changeset
   629
7aa563e4c64a version at the end
Claus Gittinger <cg@exept.de>
parents: 604
diff changeset
   630
version
2091
c11bb3e29a1b Use dependent mechamism of WeakArray instead of #watcher.
Stefan Vogel <sv@exept.de>
parents: 1903
diff changeset
   631
    ^ '$Header: /cvs/stx/stx/libbasic/WeakArray.st,v 1.37 1997-01-08 19:42:14 stefan Exp $'
628
7aa563e4c64a version at the end
Claus Gittinger <cg@exept.de>
parents: 604
diff changeset
   632
! !
603
72bdeb24ccba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 586
diff changeset
   633
WeakArray initialize!