BContext.st
author Claus Gittinger <cg@exept.de>
Tue, 23 Apr 1996 16:47:53 +0200
changeset 1268 38b3714d9eaf
parent 1183 e3d58d115e53
child 1293 02fb05148c98
permissions -rw-r--r--
commentary
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1993 by Claus Gittinger
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Context subclass:#BlockContext
1183
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 623
diff changeset
    14
	instanceVariableNames:''
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 623
diff changeset
    15
	classVariableNames:''
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 623
diff changeset
    16
	poolDictionaries:''
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 623
diff changeset
    17
	category:'Kernel-Methods'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    20
!BlockContext class methodsFor:'documentation'!
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    21
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    22
copyright
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    23
"
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    24
 COPYRIGHT (c) 1993 by Claus Gittinger
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
    25
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    27
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    28
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    30
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    31
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    32
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    33
"
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    34
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    35
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    36
documentation
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    37
"
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    38
    BlockContexts represent the stack context objects of blocks. 
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    39
    The layout is the same as for other contexts - this class has been added 
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    40
    to avoid a flag in an instance variable.
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    41
    (has become necessary with cheap blocks, which have no home).
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    42
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    43
    WARNING: layout and size known by compiler and runtime system - 
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
    44
	     do not change.
88
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    45
"
81dacba7a63a *** empty log message ***
claus
parents: 68
diff changeset
    46
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    47
a27a279701f8 Initial revision
claus
parents:
diff changeset
    48
!BlockContext methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    49
623
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    50
canReturn
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    51
    "return true, if the receiver allows returning through it.
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    52
     For normal method contexts, this normally returns true;
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    53
     for blocks, it (currently) always returns false."
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    54
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    55
    ^ false
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    56
!
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    57
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    58
home
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    59
    "return the immediate home of the receiver.
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    60
     normally this is the methodcontext, where the block was created,
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    61
     for nested block contexts, this is the surrounding blocks context."
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    62
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    63
    home isContext ifFalse:[^ nil]. "copying blocks have no home"
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    64
    ^ home
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    65
!
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    66
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
isBlockContext
a27a279701f8 Initial revision
claus
parents:
diff changeset
    68
    "return true, iff the receiver is a BlockContext, false otherwise"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    69
a27a279701f8 Initial revision
claus
parents:
diff changeset
    70
    ^ true
a27a279701f8 Initial revision
claus
parents:
diff changeset
    71
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    72
623
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    73
method
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    74
    "return the method in which the current contexts block was created."
360
claus
parents: 357
diff changeset
    75
623
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    76
    home notNil ifTrue:[^ home method].
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    77
    ^ nil
360
claus
parents: 357
diff changeset
    78
!
claus
parents: 357
diff changeset
    79
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    80
methodHome
a27a279701f8 Initial revision
claus
parents:
diff changeset
    81
    "return the method-home for block contexts"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    82
a27a279701f8 Initial revision
claus
parents:
diff changeset
    83
    |con h|
a27a279701f8 Initial revision
claus
parents:
diff changeset
    84
a27a279701f8 Initial revision
claus
parents:
diff changeset
    85
    home isNil ifTrue:[^ nil]. "XXX will change soon"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
    home isContext ifFalse:[^ nil]. "copying blocks have no method home"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
a27a279701f8 Initial revision
claus
parents:
diff changeset
    88
    con := self.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
    h := home.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
    [h notNil] whileTrue:[
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
    91
	con := h.
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
    92
	h := con home
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    93
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
    94
    ^ con
a27a279701f8 Initial revision
claus
parents:
diff changeset
    95
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    96
a27a279701f8 Initial revision
claus
parents:
diff changeset
    97
selector
a27a279701f8 Initial revision
claus
parents:
diff changeset
    98
    "return the selector of the context - which is one of the value
281
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
    99
     selectors. This selector is not found in the context, but synthesized."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   100
a27a279701f8 Initial revision
claus
parents:
diff changeset
   101
    |nargs|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
154
d4236ec280a6 *** empty log message ***
claus
parents: 92
diff changeset
   103
    nargs := self numArgs.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   104
    (nargs == 0) ifTrue:[^ #value].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   105
    (nargs == 1) ifTrue:[^ #value:].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   106
    (nargs == 2) ifTrue:[^ #value:value:].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   107
    (nargs == 3) ifTrue:[^ #value:value:value:].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   108
    (nargs == 4) ifTrue:[^ #value:value:value:value:].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   109
    (nargs == 5) ifTrue:[^ #value:value:value:value:value:].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   110
    ^ nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
   111
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   112
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   113
!BlockContext methodsFor:'printing & storing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   114
a27a279701f8 Initial revision
claus
parents:
diff changeset
   115
receiverPrintString
281
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   116
    "return a printString describing the contexts receiver.
357
claus
parents: 293
diff changeset
   117
claus
parents: 293
diff changeset
   118
     Since this is also used by the debugger(s), be very careful to
281
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   119
     return something useful, even in case internals of the system
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   120
     got corrupted ... (i.e. avoid messageNotUnderstood here)"
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   121
357
claus
parents: 293
diff changeset
   122
    |cls who mHome m className 
claus
parents: 293
diff changeset
   123
     sender selSender tryVars possibleBlocks method mWho|
claus
parents: 293
diff changeset
   124
claus
parents: 293
diff changeset
   125
    (home isNil or:[home isContext not]) ifTrue:[
claus
parents: 293
diff changeset
   126
	"
claus
parents: 293
diff changeset
   127
	 mhmh - an optimized blocks context
claus
parents: 293
diff changeset
   128
	 should get the block here, and get the method from
claus
parents: 293
diff changeset
   129
	 that one ...
claus
parents: 293
diff changeset
   130
	 ... but in 2.10.x, there is no easy way to get to the block
claus
parents: 293
diff changeset
   131
	 since that one is not in the context.
claus
parents: 293
diff changeset
   132
	 Starting with 2.11, the new block calling scheme will fix this.
claus
parents: 293
diff changeset
   133
	"
241
6f30be88e314 *** empty log message ***
claus
parents: 216
diff changeset
   134
357
claus
parents: 293
diff changeset
   135
	"temporary kludge - peek into the sender context.
claus
parents: 293
diff changeset
   136
	 If its a do-like method and there is a single block variable 
claus
parents: 293
diff changeset
   137
	 in the args or temporaries, that must be the one.
claus
parents: 293
diff changeset
   138
	 This helps in some cases.
claus
parents: 293
diff changeset
   139
	"
claus
parents: 293
diff changeset
   140
	(sender := self sender) notNil ifTrue:[
claus
parents: 293
diff changeset
   141
	    tryVars := false.
claus
parents: 293
diff changeset
   142
	    (selSender := sender selector) notNil ifTrue:[
claus
parents: 293
diff changeset
   143
		(selSender endsWith:'do:') ifTrue:[
claus
parents: 293
diff changeset
   144
		    tryVars := true.
claus
parents: 293
diff changeset
   145
		] ifFalse:[
claus
parents: 293
diff changeset
   146
		    (selSender endsWith:'Do:') ifTrue:[
claus
parents: 293
diff changeset
   147
			tryVars := true.
claus
parents: 293
diff changeset
   148
		    ]
claus
parents: 293
diff changeset
   149
		]
claus
parents: 293
diff changeset
   150
	    ].
claus
parents: 293
diff changeset
   151
	    tryVars ifTrue:[
claus
parents: 293
diff changeset
   152
		possibleBlocks := sender argsAndVars select:[:v | v isBlock].
claus
parents: 293
diff changeset
   153
		possibleBlocks := possibleBlocks select:[:b | b home isNil].
claus
parents: 293
diff changeset
   154
claus
parents: 293
diff changeset
   155
		possibleBlocks size == 1 ifTrue:[
claus
parents: 293
diff changeset
   156
		    method := possibleBlocks first method.
claus
parents: 293
diff changeset
   157
		    "
claus
parents: 293
diff changeset
   158
		     change the line in the upper-listview
claus
parents: 293
diff changeset
   159
		     according the information we have now
claus
parents: 293
diff changeset
   160
		    "
claus
parents: 293
diff changeset
   161
		    mWho := method who.
claus
parents: 293
diff changeset
   162
		    ^ '[] (optimized) in ' , 
claus
parents: 293
diff changeset
   163
		      (mWho at:1) name , '-' , (mWho at:2).
claus
parents: 293
diff changeset
   164
		].
claus
parents: 293
diff changeset
   165
	    ]
claus
parents: 293
diff changeset
   166
	].
claus
parents: 293
diff changeset
   167
165
63341654cfb8 *** empty log message ***
claus
parents: 154
diff changeset
   168
	^ '[] optimized'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   169
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   170
281
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   171
    mHome := self methodHome.
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   172
    mHome isNil ifTrue:[
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   173
	'BCONTEXT: no methodHome' errorPrintNL.
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   174
	^ '[] in ???'
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   175
    ].
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   176
293
31df3850e98c *** empty log message ***
claus
parents: 281
diff changeset
   177
    "
31df3850e98c *** empty log message ***
claus
parents: 281
diff changeset
   178
     kludge to avoid slow search for containing class
31df3850e98c *** empty log message ***
claus
parents: 281
diff changeset
   179
    "
31df3850e98c *** empty log message ***
claus
parents: 281
diff changeset
   180
    mHome selector == #doIt ifTrue:[
31df3850e98c *** empty log message ***
claus
parents: 281
diff changeset
   181
	who := Array with:mHome receiver class
31df3850e98c *** empty log message ***
claus
parents: 281
diff changeset
   182
		     with:#doIt
31df3850e98c *** empty log message ***
claus
parents: 281
diff changeset
   183
    ] ifFalse:[
31df3850e98c *** empty log message ***
claus
parents: 281
diff changeset
   184
	m := mHome method.
31df3850e98c *** empty log message ***
claus
parents: 281
diff changeset
   185
	m isNil ifTrue:[
31df3850e98c *** empty log message ***
claus
parents: 281
diff changeset
   186
	    'BCONTEXT: no method' errorPrintNL.
31df3850e98c *** empty log message ***
claus
parents: 281
diff changeset
   187
	    ^ '[] in ???'
31df3850e98c *** empty log message ***
claus
parents: 281
diff changeset
   188
	].
31df3850e98c *** empty log message ***
claus
parents: 281
diff changeset
   189
	who := m who.
281
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   190
    ].
241
6f30be88e314 *** empty log message ***
claus
parents: 216
diff changeset
   191
    who notNil ifTrue:[
6f30be88e314 *** empty log message ***
claus
parents: 216
diff changeset
   192
	cls := who at:1
6f30be88e314 *** empty log message ***
claus
parents: 216
diff changeset
   193
    ] ifFalse:[
6f30be88e314 *** empty log message ***
claus
parents: 216
diff changeset
   194
	cls := receiver class.
6f30be88e314 *** empty log message ***
claus
parents: 216
diff changeset
   195
    ].
281
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   196
    className := cls name.
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   197
    className isNil ifTrue:[
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   198
	'BCONTEXT: nameless class' errorPrintNL.
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   199
	className := '???'
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   200
    ].
d63a7d2c31a6 *** empty log message ***
claus
parents: 241
diff changeset
   201
    ^ '[] in ' , className , '-' , mHome selector printString
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   202
! !
623
6795a71e39d1 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   203
1183
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 623
diff changeset
   204
!BlockContext class methodsFor:'documentation'!
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 623
diff changeset
   205
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 623
diff changeset
   206
version
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 623
diff changeset
   207
    ^ '$Header: /cvs/stx/stx/libbasic/Attic/BContext.st,v 1.20 1996-04-16 09:28:38 cg Exp $'
e3d58d115e53 subclasses of fixed classes are still possible
Claus Gittinger <cg@exept.de>
parents: 623
diff changeset
   208
! !