Context.st
author claus
Fri, 28 Oct 1994 02:21:37 +0100
changeset 170 40ea50c7b9fe
parent 154 d4236ec280a6
child 202 40ca7cc6fb9c
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1988 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
     3
	      All Rights Reserved
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Object variableSubclass:#Context
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:'flags sender home receiver selector searchClass
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    15
			      lineNr retvalTemp handle*'
105
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
    16
       classVariableNames:'InvalidReturnSignal'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
       category:'Kernel-Methods'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
Context comment:'
5
67342904af11 *** empty log message ***
claus
parents: 3
diff changeset
    22
COPYRIGHT (c) 1988 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    23
	      All Rights Reserved
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
    24
170
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
    25
$Header: /cvs/stx/stx/libbasic/Context.st,v 1.20 1994-10-28 01:21:37 claus Exp $
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
    26
'!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
    27
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
    28
!Context class methodsFor:'documentation'!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
    29
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    30
copyright
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    31
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    32
 COPYRIGHT (c) 1988 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    33
	      All Rights Reserved
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    34
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    35
 This software is furnished under a license and may be used
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    36
 only in accordance with the terms of that license and with the
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    37
 inclusion of the above copyright notice.   This software may not
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    38
 be provided or otherwise made available to, or used by, any
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    39
 other person.  No title to or ownership of the software is
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    40
 hereby transferred.
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    41
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    42
!
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    43
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    44
version
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    45
"
170
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
    46
$Header: /cvs/stx/stx/libbasic/Context.st,v 1.20 1994-10-28 01:21:37 claus Exp $
88
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    47
"
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    48
!
81dacba7a63a *** empty log message ***
claus
parents: 77
diff changeset
    49
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
    50
documentation
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
    51
"
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
    52
    Context represents the stack context objects; each message send adds a context
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
    53
    to a chain, which can be traced back via the sender field. 
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    54
    (The actual implementation uses the machines stack for this, building real 
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    55
     contexts when needed only).
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
    56
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
    57
    For both method- and block-contexts, the layout is the same. 
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    58
    For method contexts, the home-field is nil, while for blockcontexts the home-
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    59
    field is either the context of its surrounding block (i.e. the context of the
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    60
    block, in which the receiving block was created, if its a nested block) or of
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    61
    its home method. 
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    62
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    63
    Contexts of cheap blocks do not have a home context - their home field is 
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    64
    also nil.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
    65
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    66
    Currently, contexts do not contain a reference to the method or block which
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    67
    created it - this is not needed for program execution, but could get the debugger
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    68
    somewhat into trouble: it has to search the class hierarchy for receiver/selector
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    69
    combinations to find the method. This usually works, but fails in case of methods
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    70
    which are not anchored in any class - especially leading to problems with wrapper-
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    71
    and lazy methods. Also, Method>>valueWithReceiver - type of invocations cannot
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    72
    be easily debugged.
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    73
    Therefore, the implementation will be changed in the near future, to include a
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    74
    field for the method/block, and set it in the VM during program execution.
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    75
    (there may be some small performance penalty for this, though).
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    76
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
    78
    instance variables:
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    79
	flags       <SmallInteger>          - used by the VM; never touch.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    80
					      contains info about number of args, locals and
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    81
					      temporaries.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    82
	sender      <Context>               - the 'calling' context
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    83
	home        <Context>               - the context, where this block was created, or nil
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    84
	receiver    <Object>                - the receiver of this message
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    85
	selector    <Symbol>                - the selector of this message
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    86
	searchClass <Class>                 - the class, where the message lookup started
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    87
					      (for super sends) or nil, for regular sends.
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    88
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    89
	lineNr      <SmallInteger>          - the position where the context left off
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    90
					      (kind of p-counter)
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    91
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    92
	retValTemp  nil                     - temporary - always nil, when you see the context
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    93
					      (used in the VM as temporary)
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
    94
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    95
	handle      *noObject*              - used by the VM; not accessable, not an object
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    96
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    97
	<indexed>                           - arguments of the send followed by
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    98
					      locals of the method/block followed by
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
    99
					      temporaries
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   100
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   101
    WARNING: layout and size known by the compiler and runtime system - do not change.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   102
"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   103
! !
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   104
105
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   105
!Context class methodsFor:'initialization'!
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   106
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   107
initialize
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   108
    InvalidReturnSignal isNil ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   109
	Object initialize.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   110
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   111
	InvalidReturnSignal := Object errorSignal newSignalMayProceed:true.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   112
	InvalidReturnSignal nameClass:self message:#invalidReturnSignal.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   113
	InvalidReturnSignal notifierString:'invalid return; method cannot return twice'.
105
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   114
    ]
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   115
! !
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   116
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   117
!Context class methodsFor:'signal access'!
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   118
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   119
invalidReturnSignal
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   120
    "return the signal used when a method is tried to be returned twice
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   121
     or, when some dead context is unwound or restarted."
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   122
105
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   123
    ^ InvalidReturnSignal
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   124
! !
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   125
3
24d81bf47225 *** empty log message ***
claus
parents: 1
diff changeset
   126
!Context class methodsFor:'queries'!
24d81bf47225 *** empty log message ***
claus
parents: 1
diff changeset
   127
24d81bf47225 *** empty log message ***
claus
parents: 1
diff changeset
   128
isBuiltInClass
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   129
    "this class & subclasses are known by the run-time-system"
3
24d81bf47225 *** empty log message ***
claus
parents: 1
diff changeset
   130
24d81bf47225 *** empty log message ***
claus
parents: 1
diff changeset
   131
    ^ true
24d81bf47225 *** empty log message ***
claus
parents: 1
diff changeset
   132
! !
24d81bf47225 *** empty log message ***
claus
parents: 1
diff changeset
   133
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   134
!Context methodsFor:'copying'!
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   135
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   136
deepCopy
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   137
    "raise an error - deepCopy is not allowed for contexts"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   138
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   139
    ^ self deepCopyError
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   140
! !
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   141
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   142
!Context methodsFor:'testing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   143
a27a279701f8 Initial revision
claus
parents:
diff changeset
   144
isContext
a27a279701f8 Initial revision
claus
parents:
diff changeset
   145
    "return true, iff the receiver is a Context, false otherwise"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   146
a27a279701f8 Initial revision
claus
parents:
diff changeset
   147
    ^ true
a27a279701f8 Initial revision
claus
parents:
diff changeset
   148
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   149
a27a279701f8 Initial revision
claus
parents:
diff changeset
   150
isBlockContext
a27a279701f8 Initial revision
claus
parents:
diff changeset
   151
    "return true, iff the receiver is a BlockContext, false otherwise"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   152
a27a279701f8 Initial revision
claus
parents:
diff changeset
   153
    ^ false
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   154
! 
25
e34a6267c79b *** empty log message ***
claus
parents: 12
diff changeset
   155
e34a6267c79b *** empty log message ***
claus
parents: 12
diff changeset
   156
isRecursive
e34a6267c79b *** empty log message ***
claus
parents: 12
diff changeset
   157
    "return true, if this context is one of a recursive send of the same
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   158
     selector and same arguments to the same receiver before. 
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   159
     Used to detect recursive errors or recursive printing - for example."
25
e34a6267c79b *** empty log message ***
claus
parents: 12
diff changeset
   160
170
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   161
    |c rec "numArgs" "{Class: SmallInteger }"|
25
e34a6267c79b *** empty log message ***
claus
parents: 12
diff changeset
   162
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   163
    rec := 0.
25
e34a6267c79b *** empty log message ***
claus
parents: 12
diff changeset
   164
    c := self sender.
e34a6267c79b *** empty log message ***
claus
parents: 12
diff changeset
   165
    [c notNil] whileTrue:[
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   166
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   167
	((c selector == selector) 
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   168
	and:[(c receiver == receiver)]) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   169
	    "
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   170
	     stupid: the current ST/X context does not include
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   171
	     the method, but the class, in which the search started ...
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   172
	    "
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   173
	    (c searchClass whichClassImplements:selector) == (self searchClass whichClassImplements:selector) ifTrue:[
170
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   174
"/              "
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   175
"/               finally, look for different arguments
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   176
"/              "
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   177
"/              numArgs := self numArgs.
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   178
"/              1 to:numArgs do:[:argIndex |
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   179
"/                  (self argAt:argIndex) == (c argAt:argIndex) ifFalse:[^ false]
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   180
"/              ]. 
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   181
		^ true
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   182
	    ]
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   183
	].
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   184
	c := c sender.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   185
	"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   186
	 this special test was added to get out after a while
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   187
	 if the sender chain is corrupt - this gives us at least
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   188
	 a chance to find those errors.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   189
	"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   190
	rec := rec + 1.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   191
	rec >= 100000 ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   192
	    'bad context chain' errorPrintNL.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   193
	    ^ true
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   194
	]
25
e34a6267c79b *** empty log message ***
claus
parents: 12
diff changeset
   195
    ].
e34a6267c79b *** empty log message ***
claus
parents: 12
diff changeset
   196
    ^ false
e34a6267c79b *** empty log message ***
claus
parents: 12
diff changeset
   197
! !
e34a6267c79b *** empty log message ***
claus
parents: 12
diff changeset
   198
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   199
!Context methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   200
a27a279701f8 Initial revision
claus
parents:
diff changeset
   201
instVarAt:index
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   202
    "have to catch instVar access to retVal and handle - they are invalid.
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   203
     Notice, that one of the next ST/X versions will get some syntactic
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   204
     extension to get this automatically)."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   205
a27a279701f8 Initial revision
claus
parents:
diff changeset
   206
    (index == 8) ifTrue:[^ nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   207
    (index == 9) ifTrue:[^ nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   208
    ^ super instVarAt:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
   209
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   210
a27a279701f8 Initial revision
claus
parents:
diff changeset
   211
instVarAt:index put:value
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   212
    "have to catch instVar access to retVal and handle - they are invalid.
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   213
     Notice, that one of the next ST/X versions will get some syntactic
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   214
     extension to get this automatically)."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   215
a27a279701f8 Initial revision
claus
parents:
diff changeset
   216
    (index == 8) ifTrue:[^ nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   217
    (index == 9) ifTrue:[^ nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   218
    ^ super instVarAt:index put:value
a27a279701f8 Initial revision
claus
parents:
diff changeset
   219
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   220
a27a279701f8 Initial revision
claus
parents:
diff changeset
   221
methodHome
a27a279701f8 Initial revision
claus
parents:
diff changeset
   222
    "return the method-home - for method contexts this is the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   223
a27a279701f8 Initial revision
claus
parents:
diff changeset
   224
    ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   225
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   226
a27a279701f8 Initial revision
claus
parents:
diff changeset
   227
home
a27a279701f8 Initial revision
claus
parents:
diff changeset
   228
    "return the immediate home of the receiver.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   229
     for block contexts, this is the methodcontext, where the block was created,
a27a279701f8 Initial revision
claus
parents:
diff changeset
   230
     for nested block contexts, its the surrounding blocks context.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   231
     for method-contexts this is nil."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   232
a27a279701f8 Initial revision
claus
parents:
diff changeset
   233
    ^ nil "home"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   234
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   235
a27a279701f8 Initial revision
claus
parents:
diff changeset
   236
method
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   237
    "return the method for which the receiver was created.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   238
     To save time during normal execution, this information is not held in the
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   239
     context, but computed here on request."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   240
a27a279701f8 Initial revision
claus
parents:
diff changeset
   241
    |c|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   242
a27a279701f8 Initial revision
claus
parents:
diff changeset
   243
    c := self searchClass whichClassImplements:selector.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   244
    c notNil ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   245
	^ c compiledMethodAt:selector
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   246
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   247
    ^ nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
   248
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   249
a27a279701f8 Initial revision
claus
parents:
diff changeset
   250
sender
a27a279701f8 Initial revision
claus
parents:
diff changeset
   251
    "return the sender of the context"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   252
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   253
    "this special test is for the very first context (startup-context);
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   254
     actually, its cosmetics, to avoid a visible nil>>nil context in the debugger."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   255
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   256
"
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   257
    (sender isNil or:[sender selector isNil and:[sender sender isNil]]) ifTrue:[^ nil].
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   258
"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   259
    ^ sender
a27a279701f8 Initial revision
claus
parents:
diff changeset
   260
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   261
a27a279701f8 Initial revision
claus
parents:
diff changeset
   262
receiver
a27a279701f8 Initial revision
claus
parents:
diff changeset
   263
    "return the receiver of the context"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   264
a27a279701f8 Initial revision
claus
parents:
diff changeset
   265
    ^ receiver
a27a279701f8 Initial revision
claus
parents:
diff changeset
   266
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   267
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
searchClass
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   269
    "this is the class where the method-lookup started;
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   270
     for normal sends, it is nil (or sometimes the receivers class).
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   271
     For supersends, its the superclass of the one, in which the
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   272
     caller was defined."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   273
a27a279701f8 Initial revision
claus
parents:
diff changeset
   274
    searchClass notNil ifTrue:[^ searchClass].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   275
    ^ receiver class
a27a279701f8 Initial revision
claus
parents:
diff changeset
   276
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   277
a27a279701f8 Initial revision
claus
parents:
diff changeset
   278
selector
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   279
    "return the selector of the method for which the context was created"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   280
a27a279701f8 Initial revision
claus
parents:
diff changeset
   281
    ^ selector
a27a279701f8 Initial revision
claus
parents:
diff changeset
   282
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   283
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   284
numArgs
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   285
    "return the number of arguments to the Block/Method"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   286
a27a279701f8 Initial revision
claus
parents:
diff changeset
   287
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   288
a27a279701f8 Initial revision
claus
parents:
diff changeset
   289
    RETURN ( _MKSMALLINT( (_intVal(_INST(flags)) >> __NARG_SHIFT) & __NARG_MASK) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   290
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   291
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   292
a27a279701f8 Initial revision
claus
parents:
diff changeset
   293
nvars
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   294
    "return the number of local variables of the Block/Method"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   295
a27a279701f8 Initial revision
claus
parents:
diff changeset
   296
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   297
a27a279701f8 Initial revision
claus
parents:
diff changeset
   298
    RETURN ( _MKSMALLINT( (_intVal(_INST(flags)) >> __NVAR_SHIFT) & __NVAR_MASK) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   299
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   300
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   301
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   302
ntemp
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   303
    "return the number of temporary variables of the Block/Method.
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   304
     (for debugging only)"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   305
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   306
    ^ self size - self numArgs - self nvars
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   307
!
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   308
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   309
args
a27a279701f8 Initial revision
claus
parents:
diff changeset
   310
    "return an array filled with the arguments of this context"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   311
a27a279701f8 Initial revision
claus
parents:
diff changeset
   312
    |newArray n "{ Class: SmallInteger }" |
a27a279701f8 Initial revision
claus
parents:
diff changeset
   313
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   314
    n := self numArgs.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   315
    newArray := Array new:n.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   316
    1 to:n do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   317
	newArray at:index put:(self at:index)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   318
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   319
    ^ newArray
a27a279701f8 Initial revision
claus
parents:
diff changeset
   320
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   321
a27a279701f8 Initial revision
claus
parents:
diff changeset
   322
argsAndVars
a27a279701f8 Initial revision
claus
parents:
diff changeset
   323
    "return an array filled with the arguments and variables of this context"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   324
a27a279701f8 Initial revision
claus
parents:
diff changeset
   325
    |newArray mySize "{ Class: SmallInteger }" |
a27a279701f8 Initial revision
claus
parents:
diff changeset
   326
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   327
    mySize := self numArgs + self nvars.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   328
    newArray := Array new:mySize.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   329
    1 to:mySize do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   330
	newArray at:index put:(self at:index)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   331
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   332
    ^ newArray
a27a279701f8 Initial revision
claus
parents:
diff changeset
   333
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   334
10
claus
parents: 5
diff changeset
   335
argAt:n
claus
parents: 5
diff changeset
   336
    "return the n'th argument"
claus
parents: 5
diff changeset
   337
claus
parents: 5
diff changeset
   338
    ^ self at:n
claus
parents: 5
diff changeset
   339
!
claus
parents: 5
diff changeset
   340
claus
parents: 5
diff changeset
   341
argAt:n put:value
claus
parents: 5
diff changeset
   342
    "set the n'th argument - useful when the receiver should be restarted"
claus
parents: 5
diff changeset
   343
claus
parents: 5
diff changeset
   344
    ^ self at:n put:value
claus
parents: 5
diff changeset
   345
!
claus
parents: 5
diff changeset
   346
claus
parents: 5
diff changeset
   347
varAt:n
claus
parents: 5
diff changeset
   348
    "return the n'th local variable"
claus
parents: 5
diff changeset
   349
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   350
    ^ self at:(n + self numArgs)
10
claus
parents: 5
diff changeset
   351
!
claus
parents: 5
diff changeset
   352
claus
parents: 5
diff changeset
   353
varAt:n put:value
claus
parents: 5
diff changeset
   354
    "set the n'th local variable - useful when the receiver should be restarted
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   355
     or continued"
10
claus
parents: 5
diff changeset
   356
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   357
    self at:(n + self numArgs) put:value
10
claus
parents: 5
diff changeset
   358
!
claus
parents: 5
diff changeset
   359
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   360
lineNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   361
    "this returns the lineNumber within the methods source, where the context was
a27a279701f8 Initial revision
claus
parents:
diff changeset
   362
     interrupted or called another method. (currently, sometimes this information
a27a279701f8 Initial revision
claus
parents:
diff changeset
   363
     is not available - in this case 0 is returned)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   364
a27a279701f8 Initial revision
claus
parents:
diff changeset
   365
    ^ lineNr
a27a279701f8 Initial revision
claus
parents:
diff changeset
   366
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   367
92
0c73b48551ac *** empty log message ***
claus
parents: 88
diff changeset
   368
!Context methodsFor:'printing & storing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   369
42
e33491f6f260 *** empty log message ***
claus
parents: 37
diff changeset
   370
argsDisplayString
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   371
    |fullString n "{ Class: SmallInteger }" |
a27a279701f8 Initial revision
claus
parents:
diff changeset
   372
a27a279701f8 Initial revision
claus
parents:
diff changeset
   373
    fullString := ''.
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   374
    n := self numArgs.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   375
    1 to:n do:[:index |
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   376
	fullString := fullString , (' ' , (self at:index) displayString)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   377
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   378
    ^ fullString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   379
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   380
a27a279701f8 Initial revision
claus
parents:
diff changeset
   381
printReceiver
37
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   382
    "print the receiver of the context - used for MiniDebugger only"
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   383
170
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   384
    self receiverPrintString print.
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   385
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   386
"/    |class implementorClass|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   387
170
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   388
"/    class := receiver class.
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   389
"/    (class == SmallInteger) ifTrue:[
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   390
"/        '(' print. receiver print. ') ' print
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   391
"/    ].
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   392
"/    class name print.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   393
170
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   394
"/    selector notNil ifTrue:[
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   395
"/        implementorClass := self searchClass whichClassImplements:selector.
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   396
"/        implementorClass notNil ifTrue: [
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   397
"/            (implementorClass ~= receiver class) ifTrue: [
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   398
"/                '>>>' print.
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   399
"/                implementorClass name print
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   400
"/            ]
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   401
"/        ] ifFalse:[
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   402
"/            self searchClass ~~ receiver class ifTrue:[
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   403
"/                '>>>' print. self searchClass name print
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   404
"/            ].
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   405
"/            '>>>**NONE**' print
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   406
"/        ]
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   407
"/    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   408
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   409
    
37
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   410
fullPrint
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   411
    "print the receiver, selector and args of the context 
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   412
     - used for MiniDebuggers walkback print only"
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   413
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   414
    self printReceiver.
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   415
    ' ' print.
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   416
    selector print.
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   417
    self size ~~ 0 ifTrue: [
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   418
	' ' print.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   419
	self argsDisplayString print
37
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   420
    ].
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   421
    ' [' print. lineNr print. ']' printNewline
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   422
!
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   423
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   424
receiverPrintString
37
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   425
    "return a string describing the receiver of the context" 
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   426
170
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   427
    |receiverClass receiverClassName newString implementorClass|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   428
170
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   429
    receiverClass := receiver class.
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   430
    receiverClassName := receiverClass name.
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   431
    (receiverClass == SmallInteger) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   432
	newString := '(' , receiver printString , ') ' , receiverClassName
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   433
    ] ifFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   434
	newString := receiverClassName
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   435
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   436
a27a279701f8 Initial revision
claus
parents:
diff changeset
   437
    selector notNil ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   438
	implementorClass := self searchClass whichClassImplements:selector.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   439
	implementorClass notNil ifTrue: [
170
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   440
	    (implementorClass ~~ receiverClass) ifTrue: [
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   441
		newString := newString , '>>>',
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   442
			     implementorClass name printString
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   443
	    ]
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   444
	] ifFalse:[
170
40ea50c7b9fe *** empty log message ***
claus
parents: 154
diff changeset
   445
	    self searchClass ~~ receiverClass ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   446
		newString := newString , '>>>' , self searchClass name
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   447
	    ].
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   448
	    newString := newString , '>>>**NONE**'
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   449
	]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   450
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   451
a27a279701f8 Initial revision
claus
parents:
diff changeset
   452
    ^ newString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   453
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   454
    
a27a279701f8 Initial revision
claus
parents:
diff changeset
   455
printString
37
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   456
    "return a string describing the context" 
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   457
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   458
    ^ self receiverPrintString , ' ' , self selector printString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   459
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   460
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   461
displayString
37
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   462
    "return a string describing the context - for display in Inspector" 
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   463
42
e33491f6f260 *** empty log message ***
claus
parents: 37
diff changeset
   464
    ^ self class name , '(' , self printString , ')'
12
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   465
!
8e03bd717355 *** empty log message ***
claus
parents: 10
diff changeset
   466
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   467
printOn:aStream
37
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   468
    "append a printed description of the receiver onto aStream"
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   469
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   470
    aStream nextPutAll:(self receiverPrintString).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   471
    aStream space.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   472
    self selector printOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   473
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   474
a27a279701f8 Initial revision
claus
parents:
diff changeset
   475
fullPrintAll
37
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   476
    "print a full walkback starting at the receiver
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   477
     - for MiniDebugger only"
d9a302eaa3ef *** empty log message ***
claus
parents: 25
diff changeset
   478
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   479
    |context|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   480
    context := self.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   481
    [context notNil] whileTrue: [
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   482
	context fullPrint.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   483
	context := context sender
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   484
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   485
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   486
77
6c38ca59927f *** empty log message ***
claus
parents: 69
diff changeset
   487
!Context methodsFor:'error handling'!
6c38ca59927f *** empty log message ***
claus
parents: 69
diff changeset
   488
6c38ca59927f *** empty log message ***
claus
parents: 69
diff changeset
   489
invalidReturn:returnValue
6c38ca59927f *** empty log message ***
claus
parents: 69
diff changeset
   490
    "this message is sent by the VM, when a methods context
6c38ca59927f *** empty log message ***
claus
parents: 69
diff changeset
   491
     which has already returned is about to return again.
6c38ca59927f *** empty log message ***
claus
parents: 69
diff changeset
   492
     (i.e. about to execute a return from an already returned
105
7fe3d60db5e1 invalid return now raises a signal
claus
parents: 92
diff changeset
   493
      method in a block).
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   494
    We raise a signal here, to allow catching of that situation."
77
6c38ca59927f *** empty log message ***
claus
parents: 69
diff changeset
   495
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   496
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   497
     in previous versions of ST/X and ST-80, this was no error;
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   498
     comment out the raise to get that (old) behavior
77
6c38ca59927f *** empty log message ***
claus
parents: 69
diff changeset
   499
    " 
6c38ca59927f *** empty log message ***
claus
parents: 69
diff changeset
   500
" "
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   501
    ^ InvalidReturnSignal raiseRequestWith:returnValue.
77
6c38ca59927f *** empty log message ***
claus
parents: 69
diff changeset
   502
" "
6c38ca59927f *** empty log message ***
claus
parents: 69
diff changeset
   503
    ^ returnValue
6c38ca59927f *** empty log message ***
claus
parents: 69
diff changeset
   504
! !
6c38ca59927f *** empty log message ***
claus
parents: 69
diff changeset
   505
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   506
!Context methodsFor:'non local control flow'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   507
a27a279701f8 Initial revision
claus
parents:
diff changeset
   508
restart
a27a279701f8 Initial revision
claus
parents:
diff changeset
   509
    "restart the receiver - i.e. the method is evaluated again.
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   510
     if the context to restart already died - do nothing.
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   511
     This is a low level helper for unwindAndRestart.
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   512
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   513
     NOTICE: 
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   514
	 NO unwind actions are performed - this is usually not
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   515
	 what you want (see Context>>unwindAndRestart).
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   516
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   517
     LIMITATION: 
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   518
	 currently a context can only be restarted by
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   519
	 the owning process - not from outside."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   520
a27a279701f8 Initial revision
claus
parents:
diff changeset
   521
    sender isNil ifTrue:[^ nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   522
%{
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   523
    __RESUMECONTEXT__(SND_COMMA self, RESTART_VALUE, 0);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   524
a27a279701f8 Initial revision
claus
parents:
diff changeset
   525
    /* when we reach here, something went wrong */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   526
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   527
.
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   528
    "
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   529
     debugging ...
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   530
    "
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   531
"
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   532
    'restart: context not on calling chain' errorPrintNL.
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   533
    ^ self error:'restart: context not on calling chain'.
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   534
"
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   535
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   536
     tried to restart a context which is already dead
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   537
     (i.e. the method/block has already executed a return)
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   538
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   539
    ^ InvalidReturnSignal 
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   540
	  raiseRequestWith:nil
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   541
	  errorString:'restart: context not on calling chain'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   542
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   543
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   544
return
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   545
    "return from this context with nil. I.e. as if it did a ^ nil.
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   546
     NOTICE:
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   547
	 NO unwind actions are performed - this is usually not
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   548
	 what you want (See Context>>unwind).
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   549
	 This is a low level method - a helper for unwind.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   550
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   551
     LIMITATION: 
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   552
	 currently a context can only be returned by
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   553
	 the owning process - not from outside."
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   554
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   555
    ^ self return:nil
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   556
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   557
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   558
return:value
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   559
    "return from this context as if it did a '^ value'.
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   560
     NOTICE:
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   561
	 NO unwind actions are performed- this is usually not
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   562
	 what you want (See Context>>unwind:).
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   563
	 This is a low level method - a helper for unwind.
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   564
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   565
     LIMITATION: 
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   566
	 currently a context can only be returned by
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   567
	 the owning process - not from outside."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   568
a27a279701f8 Initial revision
claus
parents:
diff changeset
   569
    sender isNil ifTrue:[^ nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   570
%{
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   571
    __RESUMECONTEXT__(SND_COMMA self, value, 0);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   572
a27a279701f8 Initial revision
claus
parents:
diff changeset
   573
    /* when we reach here, something went wrong */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   574
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   575
.
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   576
    "
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   577
     debugging ...
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   578
    "
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   579
"
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   580
    'return: context not on calling chain' errorPrintNL.
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   581
    ^ self error:'return: context not on calling chain'.
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   582
"
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   583
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   584
     tried to return a context which is already dead
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   585
     (i.e. the method/block has already executed a return)
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   586
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   587
    ^ InvalidReturnSignal 
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   588
	  raiseRequestWith:value 
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   589
	  errorString:'return: context not on calling chain'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   590
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   591
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   592
resume
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   593
    "resume execution in this context. I.e. as if the method called
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   594
     last by the receiver did a ^ nil.
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   595
     If the context has already returned, do nothing.
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   596
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   597
     NOTICE:
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   598
	 NO unwind actions are performed (see Context>>unwind).
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   599
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   600
     LIMITATION: 
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   601
	 currently a context can only be resumed by
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   602
	 the owning process - not from outside."
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   603
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   604
    ^ self resume:nil
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   605
!
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   606
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   607
resume:value
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   608
    "resume the receiver - as if it got 'value' from whatever
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   609
     it called.
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   610
     If the context has already returned - do nothing. 
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   611
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   612
     NOTICE:
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   613
	 NO unwind actions are performed (see Context>>unwind:).
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   614
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   615
     LIMITATION: 
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   616
	 currently a context can only be resumed by
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   617
	 the owning process - not from outside."
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   618
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   619
    |con|
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   620
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   621
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   622
     starting with this context, find the one below and return from it
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   623
    "
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   624
    con := thisContext.
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   625
    [con notNil and:[con sender ~~ self]] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   626
	con := con sender
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   627
    ].
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   628
    con isNil ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   629
	"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   630
	 debugging ...
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   631
	"
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   632
"
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   633
	'resume: context not on calling chain' errorPrintNL.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   634
	^ self error:'resume: context not on calling chain'.
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   635
"
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   636
	"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   637
	 tried to continue in context which is already dead
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   638
	 (i.e. the method/block has already executed a return)
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   639
	"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   640
	^ InvalidReturnSignal 
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   641
	      raiseRequestWith:value 
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   642
	      errorString:'resume: context not on calling chain'
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   643
    ].
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   644
    ^ con return:value
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   645
!
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   646
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   647
unwind
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   648
    "return nil from the receiver - i.e. simulate a '^ nil'.
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   649
     If the context has already retruned, do nothing.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   650
     Evaluate all unwind-blocks as specified in Block>>valueNowOrOnUnwind:
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   651
     and Block>>valueOnUnwindDo: on the way.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   652
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   653
     LIMITATION: 
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   654
	 currently a context can only be unwound by
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   655
	 the owning process - not from outside."
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   656
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   657
    ^ self unwind:nil
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   658
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   659
a27a279701f8 Initial revision
claus
parents:
diff changeset
   660
unwind:value
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   661
    "return value from the receiver - i.e. simulate a '^ value'.
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   662
     If the context has already returned , do nothing.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   663
     Evaluate all unwind-blocks as specified in Block>>valueNowOrOnUnwind:
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   664
     and Block>>valueOnUnwindDo: on the way.
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   665
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   666
     LIMITATION: 
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   667
	 currently a context can only be unwound by
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   668
	 the owning process - not from outside."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   669
10
claus
parents: 5
diff changeset
   670
    |con sel|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   671
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   672
    sender isNil ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   673
	"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   674
	 tried to return to a context which is already dead
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   675
	 (i.e. the method/block has already executed a return)
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   676
	"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   677
	^ InvalidReturnSignal 
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   678
	      raiseRequestWith:value 
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   679
	      errorString:'unwind: no sender to unwind to'
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   680
    ].
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   681
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   682
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   683
     start with this context, moving up, looking for unwind actions
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   684
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   685
    con := thisContext.
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   686
    [con notNil and:[con ~~ self]] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   687
	con isBlockContext ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   688
	    "
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   689
	     the way we find those unwind contexts seems kludgy ...
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   690
	    "
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   691
	    sel := con selector.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   692
	    ((sel == #valueNowOrOnUnwindDo:) or:[sel == #valueOnUnwindDo:]) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   693
		"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   694
		 ... the way we evaluate the unwind blocks too
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   695
		"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   696
		(con argAt:1) value
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   697
	    ]
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   698
	].
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   699
	con := con sender
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   700
    ].
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   701
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   702
    "oops, I am not on the calling chain
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   703
     (should we check for this situation first and NOT evaluate
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   704
      the unwind actions in this case ?)
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   705
    "
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   706
    con isNil ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   707
	"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   708
	 debugging ...
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   709
	"
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   710
"
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   711
	'unwind: context not on calling chain' errorPrintNL.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   712
	^ self error:'unwind: context not on calling chain'.
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   713
"
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   714
	"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   715
	 tried to return to a context which is already dead
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   716
	 (i.e. the method/block has already executed a return)
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   717
	"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   718
	^ InvalidReturnSignal 
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   719
	      raiseRequestWith:value 
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   720
	      errorString:'unwind: context not on calling chain'
69
4564b6328136 *** empty log message ***
claus
parents: 54
diff changeset
   721
    ].
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   722
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   723
     now, that all unwind-actions are done, I can use the
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   724
     low-level return ...
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   725
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   726
    ^ self return:value
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   727
!
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   728
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   729
unwindAndRestart
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   730
    "restart the receiver - i.e. the method is evaluated again.
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   731
     if the context to restart already died - do nothing.
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   732
     Evaluate all unwind-blocks as specified in Block>>valueNowOrOnUnwind:
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   733
     and Block>>valueOnUnwindDo: before restarting.
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   734
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   735
     LIMITATION: 
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   736
	 currently a context can only be restarted by
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   737
	 the owning process - not from outside."
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   738
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   739
    |con sel|
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   740
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   741
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   742
     start with this context, moving up, looking for unwind actions
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   743
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   744
    con := thisContext.
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   745
    [con notNil and:[con ~~ self]] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   746
	con isBlockContext ifFalse:[
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   747
	    "
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   748
	     the way we find those unwind contexts seems kludgy ...
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   749
	    "
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   750
	    sel := con selector.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   751
	    ((sel == #valueNowOrOnUnwindDo:) or:[sel == #valueOnUnwindDo:]) ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   752
		"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   753
		 ... the way we evaluate the unwind blocks too
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   754
		"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   755
		(con argAt:1) value
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   756
	    ]
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   757
	].
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   758
	con := con sender
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   759
    ].
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   760
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   761
    "oops, I am not on the calling chain
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   762
     (should we check for this situation first and NOT evaluate
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   763
      the unwind actions in this case ?)
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   764
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   765
    con isNil ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   766
	"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   767
	 debugging ...
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   768
	"
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   769
"
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   770
	'unwindAndRestart: context not on calling chain' errorPrintNL.
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   771
	^ self error:'unwindAndRestart: context not on calling chain'.
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   772
"
154
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   773
	"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   774
	 tried to return to a context which is already dead
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   775
	 (i.e. the method/block has already executed a return)
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   776
	"
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   777
	^ InvalidReturnSignal 
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   778
	      raiseRequestWith:nil 
d4236ec280a6 *** empty log message ***
claus
parents: 141
diff changeset
   779
	      errorString:'unwindAndRestart: context not on calling chain'
141
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   780
    ].
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   781
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   782
     now, that all unwind-actions are done, I can use the
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   783
     low-level restart ...
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   784
    "
b530e69052e4 better unwind & new unwindAndRestart
claus
parents: 105
diff changeset
   785
    ^ self restart
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   786
! !