Block.st
author Claus Gittinger <cg@exept.de>
Thu, 23 Nov 1995 02:16:37 +0100
changeset 605 8b17f96bf05a
parent 552 694ecccaa1a0
child 623 6795a71e39d1
permissions -rw-r--r--
checkin from browser
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) 1989 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
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
249
claus
parents: 222
diff changeset
    13
CompiledCode subclass:#Block
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    14
       instanceVariableNames:'home nargs sourcePos initialPC'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
       classVariableNames:'InvalidNewSignal'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    16
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       category:'Kernel-Methods'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
!Block class methodsFor:'documentation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
92
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    22
copyright
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    23
"
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    24
 COPYRIGHT (c) 1989 by Claus Gittinger
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    25
	      All Rights Reserved
92
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    26
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    27
 This software is furnished under a license and may be used
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    28
 only in accordance with the terms of that license and with the
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    30
 be provided or otherwise made available to, or used by, any
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    31
 other person.  No title to or ownership of the software is
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    32
 hereby transferred.
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    33
"
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    34
!
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    35
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    36
version
552
694ecccaa1a0 only evaluate unwind blocks once
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
    37
    ^ '$Header: /cvs/stx/stx/libbasic/Block.st,v 1.41 1995-11-15 10:39:54 cg Exp $'
92
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    38
!
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
    39
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    40
documentation
a27a279701f8 Initial revision
claus
parents:
diff changeset
    41
"
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    42
    Blocks are pieces of executable code which can be evaluated by sending
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    43
    them a value-message (''value'', ''value:'', ''value:value:'' etc).
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    44
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    45
    Blocks with arguments need a message of type ''value:arg1 ... value:argn''
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    46
    for evaluation; the number of arguments passed when evaluating must match
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    47
    the number of arguments the block was declared with otherwise an error is
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    48
    raised. Blocks without args need a ''value'' message for evaluation.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    49
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    50
    Blocks keep a reference to the context where the block was declared -
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    51
    this allows blocks to access the methods arguments and/or variables.
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    52
    This is still true after the method has returned - since the
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    53
    block keeps this reference, the methods context will NOT die in this case.
222
85fee82884dd commenting
claus
parents: 216
diff changeset
    54
    (i.e. Blocks are closures in Smalltalk/X)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    55
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    56
    A return (via ^-statement) out of a block will force a return from the
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    57
    blocks method context (if it is still living) - this make the implementation
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    58
    of long-jumps and control structures possible.
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    59
    (If the method is not alive (i.e. has already returned), a return out of the 
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    60
     block will trigger an error)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    61
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    62
    Long-jump is done by defining a catchBlock as ''[^ self]''
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    63
    somewhere up in the calling-tree. Then, to do the long-jump from out of some 
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    64
    deeply nested method, simply do: ''catchBlock value''.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    65
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    66
    Instance variables:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
222
85fee82884dd commenting
claus
parents: 216
diff changeset
    68
      home        <Context>         the context where this block was created (i.e. defined)
85fee82884dd commenting
claus
parents: 216
diff changeset
    69
				    this may be a blockContext or a methodContext
85fee82884dd commenting
claus
parents: 216
diff changeset
    70
      nargs       <SmallInteger>    the number of arguments the block expects
85fee82884dd commenting
claus
parents: 216
diff changeset
    71
      sourcePos   <SmallInteger>    the character position of its source, in chars
85fee82884dd commenting
claus
parents: 216
diff changeset
    72
				    relative to methods source beginning
85fee82884dd commenting
claus
parents: 216
diff changeset
    73
      initialPC   <SmallInteger>    the start position within the byteCode
85fee82884dd commenting
claus
parents: 216
diff changeset
    74
				    for compiled blocks, this is nil.
85fee82884dd commenting
claus
parents: 216
diff changeset
    75
85fee82884dd commenting
claus
parents: 216
diff changeset
    76
85fee82884dd commenting
claus
parents: 216
diff changeset
    77
    Class variables:
85fee82884dd commenting
claus
parents: 216
diff changeset
    78
85fee82884dd commenting
claus
parents: 216
diff changeset
    79
      InvalidNewSignal              raised if a Block is tried to be created
85fee82884dd commenting
claus
parents: 216
diff changeset
    80
				    with new (which is not allowed).
85fee82884dd commenting
claus
parents: 216
diff changeset
    81
				    Only the VM is allowed to create Blocks.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    82
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
    83
    NOTICE: layout known by runtime system and compiler - do not change
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    84
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    85
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
!Block class methodsFor:'initialization' !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    88
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
initialize
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
    "setup the signals"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
48
9f68393bea3c *** empty log message ***
claus
parents: 46
diff changeset
    92
    InvalidNewSignal isNil ifTrue:[
302
1f76060d58a4 *** empty log message ***
claus
parents: 249
diff changeset
    93
	InvalidNewSignal := ErrorSignal newSignalMayProceed:false.
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    94
	InvalidNewSignal nameClass:self message:#invalidNewSignal.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    95
	InvalidNewSignal notifierString:'blocks are only created by the system'.
48
9f68393bea3c *** empty log message ***
claus
parents: 46
diff changeset
    96
    ]
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
    97
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
    98
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
    99
!Block methodsFor:'copying'!
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   100
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   101
deepCopy
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   102
    "raise an error - deepCopy is not allowed for blocks"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   103
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   104
    ^ self deepCopyError
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   105
! !
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   106
3
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   107
!Block class methodsFor:'queries'!
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   108
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   109
isBuiltInClass
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   110
    "this class is known by the run-time-system"
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   111
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   112
    ^ true
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   113
! !
24d81bf47225 *** empty log message ***
claus
parents: 2
diff changeset
   114
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   115
!Block class methodsFor:'instance creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   116
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   117
code:codeAddress byteCode:bCode numArgs:numArgs sourcePosition:sourcePos initialPC:initialPC literals:literals dynamic:dynamic
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   118
    "create a new cheap (homeless) block.
222
85fee82884dd commenting
claus
parents: 216
diff changeset
   119
     Not for public use - this is a special hook for the compiler."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   120
a27a279701f8 Initial revision
claus
parents:
diff changeset
   121
    |newBlock|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   122
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   123
    newBlock := super basicNew code:codeAddress 
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   124
			   byteCode:bCode
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   125
			   numArgs:numArgs
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   126
		     sourcePosition:sourcePos
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   127
			  initialPC:initialPC
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   128
			   literals:literals
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   129
			    dynamic:dynamic.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   130
    ^ newBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   131
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   132
22
847106305963 *** empty log message ***
claus
parents: 11
diff changeset
   133
new
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   134
    "catch creation of blocks - only the system creates blocks"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   135
128
c50a2157883e return value of signal raise
claus
parents: 103
diff changeset
   136
    ^ InvalidNewSignal raise.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   137
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   138
22
847106305963 *** empty log message ***
claus
parents: 11
diff changeset
   139
new:size
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   140
    "catch creation of blocks - only the system creates blocks"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   141
128
c50a2157883e return value of signal raise
claus
parents: 103
diff changeset
   142
    ^ InvalidNewSignal raise.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   143
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   144
a27a279701f8 Initial revision
claus
parents:
diff changeset
   145
!Block methodsFor:'testing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   146
a27a279701f8 Initial revision
claus
parents:
diff changeset
   147
isBlock
48
9f68393bea3c *** empty log message ***
claus
parents: 46
diff changeset
   148
    "return true, if this is a block - yes I am"
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   149
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   150
    ^ true
a27a279701f8 Initial revision
claus
parents:
diff changeset
   151
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   152
a27a279701f8 Initial revision
claus
parents:
diff changeset
   153
!Block methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   154
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   155
numArgs
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   156
    "return the number of arguments I expect for evaluation"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   157
a27a279701f8 Initial revision
claus
parents:
diff changeset
   158
    ^ nargs
a27a279701f8 Initial revision
claus
parents:
diff changeset
   159
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   160
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   161
methodHome
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   162
    "return the receivers method home context (the context where it was
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   163
     defined). For cheap blocks, nil is returned"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   164
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   165
    home notNil ifTrue:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   166
	^ home methodHome
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   167
    ].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   168
    ^ home
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   169
!
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   170
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   171
home
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   172
    "return the receivers home context (the context where it was
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   173
     created). For cheap blocks, nil is returned"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   174
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   175
    ^ home
161
ed36169f354d *** empty log message ***
claus
parents: 154
diff changeset
   176
!
ed36169f354d *** empty log message ***
claus
parents: 154
diff changeset
   177
ed36169f354d *** empty log message ***
claus
parents: 154
diff changeset
   178
method
ed36169f354d *** empty log message ***
claus
parents: 154
diff changeset
   179
    "return the receivers method 
ed36169f354d *** empty log message ***
claus
parents: 154
diff changeset
   180
     (the method where the block was created)."
ed36169f354d *** empty log message ***
claus
parents: 154
diff changeset
   181
ed36169f354d *** empty log message ***
claus
parents: 154
diff changeset
   182
    home notNil ifTrue:[
ed36169f354d *** empty log message ***
claus
parents: 154
diff changeset
   183
	^ home method
ed36169f354d *** empty log message ***
claus
parents: 154
diff changeset
   184
    ].
ed36169f354d *** empty log message ***
claus
parents: 154
diff changeset
   185
    ^ nil
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   186
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   187
a27a279701f8 Initial revision
claus
parents:
diff changeset
   188
!Block methodsFor:'private accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   189
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   190
code:codeAddress byteCode:bCode numArgs:numArgs sourcePosition:srcPos initialPC:iPC literals:lits dynamic:dynamic
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   191
    "set all relevant internals"
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   192
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   193
    self code:codeAddress.
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   194
    byteCode := bCode.
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   195
    nargs := numArgs.
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   196
    sourcePos := srcPos.
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   197
    initialPC := iPC.
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   198
    literals := lits.
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   199
    self dynamic:dynamic
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   200
!
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   201
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   202
numArgs:numArgs
48
9f68393bea3c *** empty log message ***
claus
parents: 46
diff changeset
   203
    "set the number of arguments I expect for evaluation - DANGER ALERT"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   204
a27a279701f8 Initial revision
claus
parents:
diff changeset
   205
    nargs := numArgs
a27a279701f8 Initial revision
claus
parents:
diff changeset
   206
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   207
a27a279701f8 Initial revision
claus
parents:
diff changeset
   208
sourcePosition:position 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   209
    "set the position of the source within my method"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   210
a27a279701f8 Initial revision
claus
parents:
diff changeset
   211
    sourcePos := position
a27a279701f8 Initial revision
claus
parents:
diff changeset
   212
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   213
a27a279701f8 Initial revision
claus
parents:
diff changeset
   214
initialPC:initial 
48
9f68393bea3c *** empty log message ***
claus
parents: 46
diff changeset
   215
    "set the initial pc for evaluation - DANGER ALERT"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   216
a27a279701f8 Initial revision
claus
parents:
diff changeset
   217
    initialPC := initial
a27a279701f8 Initial revision
claus
parents:
diff changeset
   218
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   219
a27a279701f8 Initial revision
claus
parents:
diff changeset
   220
!Block methodsFor:'error handling'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   221
103
de0f8152878f errors now raise a signal
claus
parents: 98
diff changeset
   222
wrongNumberOfArguments:numberGiven
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   223
    "report that the number of arguments given does not match the number expected"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   224
128
c50a2157883e return value of signal raise
claus
parents: 103
diff changeset
   225
    ^ ArgumentSignal
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   226
	raiseRequestWith:self
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   227
	errorString:('block got ' , numberGiven printString ,
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   228
		     ' args while ' , nargs printString , ' where expected')
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   229
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   230
328
claus
parents: 326
diff changeset
   231
invalidCodeObject
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   232
    "this error is triggered by the interpreter when a non-Block object
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   233
     is about to be executed.
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   234
     In this case, the VM sends this to the bad method (the receiver).
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   235
     Can only happen when the Compiler/runtime system is broken or
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   236
     someone played around."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   237
128
c50a2157883e return value of signal raise
claus
parents: 103
diff changeset
   238
    ^ InvalidCodeSignal
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   239
	raiseRequestWith:self
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   240
	errorString:'invalid block - not executable'
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   241
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   242
a27a279701f8 Initial revision
claus
parents:
diff changeset
   243
!Block methodsFor:'evaluation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   244
a27a279701f8 Initial revision
claus
parents:
diff changeset
   245
value
a27a279701f8 Initial revision
claus
parents:
diff changeset
   246
    "evaluate the receiver with no block args. The receiver must be a block without arguments."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   247
a27a279701f8 Initial revision
claus
parents:
diff changeset
   248
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   249
a27a279701f8 Initial revision
claus
parents:
diff changeset
   250
    REGISTER OBJFUNC thecode;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   251
    OBJ home;
328
claus
parents: 326
diff changeset
   252
    extern OBJ __interpret(), interpret();
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   253
a27a279701f8 Initial revision
claus
parents:
diff changeset
   254
    if (_INST(nargs) == _MKSMALLINT(0)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   255
#if defined(THIS_CONTEXT)
328
claus
parents: 326
diff changeset
   256
	if (__ISVALID_ILC_LNO(__pilc))
claus
parents: 326
diff changeset
   257
	    _ContextInstPtr(__thisContext)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   258
#endif
328
claus
parents: 326
diff changeset
   259
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   260
	thecode = _BlockInstPtr(self)->b_code;
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   261
#ifdef NEW_BLOCK_CALL
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   262
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   263
	    /* compiled machine code */
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   264
	    RETURN ( (*thecode)(self, COMMA_SND) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   265
	}
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   266
	/* interpreted code */
328
claus
parents: 326
diff changeset
   267
# ifdef PASS_ARG_POINTER
400
claus
parents: 384
diff changeset
   268
	RETURN ( __interpret(self, 0, nil, nil COMMA_SND, nil) );
328
claus
parents: 326
diff changeset
   269
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   270
	RETURN ( interpret(self, 0, nil, nil COMMA_SND, nil) );
328
claus
parents: 326
diff changeset
   271
# endif
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   272
#else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   273
	home = _BlockInstPtr(self)->b_home;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   274
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   275
	    /* compiled machine code */
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   276
	    RETURN ( (*thecode)(home COMMA_SND) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   277
	}
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   278
	/* interpreted code */
328
claus
parents: 326
diff changeset
   279
# ifdef PASS_ARG_POINTER
400
claus
parents: 384
diff changeset
   280
	RETURN ( __interpret(self, 0, nil, home COMMA_SND, nil) );
328
claus
parents: 326
diff changeset
   281
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   282
	RETURN ( interpret(self, 0, nil, home COMMA_SND, nil) );
328
claus
parents: 326
diff changeset
   283
# endif
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   284
#endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   285
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   286
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   287
.
103
de0f8152878f errors now raise a signal
claus
parents: 98
diff changeset
   288
    ^ self wrongNumberOfArguments:0
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   289
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   290
a27a279701f8 Initial revision
claus
parents:
diff changeset
   291
value:arg
a27a279701f8 Initial revision
claus
parents:
diff changeset
   292
    "evaluate the receiver with one argument. The receiver must be a 1-arg block."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   293
a27a279701f8 Initial revision
claus
parents:
diff changeset
   294
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   295
a27a279701f8 Initial revision
claus
parents:
diff changeset
   296
    REGISTER OBJFUNC thecode;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   297
    OBJ home;
328
claus
parents: 326
diff changeset
   298
    extern OBJ __interpret(), interpret();
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   299
a27a279701f8 Initial revision
claus
parents:
diff changeset
   300
    if (_INST(nargs) == _MKSMALLINT(1)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   301
#if defined(THIS_CONTEXT)
328
claus
parents: 326
diff changeset
   302
	if (__ISVALID_ILC_LNO(__pilc))
claus
parents: 326
diff changeset
   303
	    _ContextInstPtr(__thisContext)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   304
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   305
	thecode = _BlockInstPtr(self)->b_code;
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   306
#ifdef NEW_BLOCK_CALL
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   307
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   308
	    RETURN ( (*thecode)(self COMMA_SND, arg) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   309
	}
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   310
	/* interpreted code */
328
claus
parents: 326
diff changeset
   311
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   312
	RETURN ( __interpret(self, 1, nil, nil COMMA_SND, nil, &arg) );
claus
parents: 326
diff changeset
   313
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   314
	RETURN ( interpret(self, 1, nil, nil COMMA_SND, nil, arg) );
328
claus
parents: 326
diff changeset
   315
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   316
#else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   317
	home = _BlockInstPtr(self)->b_home;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   318
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   319
	    RETURN ( (*thecode)(home COMMA_SND, arg) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   320
	}
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   321
	/* interpreted code */
328
claus
parents: 326
diff changeset
   322
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   323
	RETURN ( __interpret(self, 1, nil, home COMMA_SND, nil, &arg) );
claus
parents: 326
diff changeset
   324
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   325
	RETURN ( interpret(self, 1, nil, home COMMA_SND, nil, arg) );
328
claus
parents: 326
diff changeset
   326
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   327
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   328
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   329
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   330
.
103
de0f8152878f errors now raise a signal
claus
parents: 98
diff changeset
   331
    ^ self wrongNumberOfArguments:1
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   332
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   333
a27a279701f8 Initial revision
claus
parents:
diff changeset
   334
value:arg1 value:arg2
a27a279701f8 Initial revision
claus
parents:
diff changeset
   335
    "evaluate the receiver with two arguments. The receiver must be a 2-arg block."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   336
a27a279701f8 Initial revision
claus
parents:
diff changeset
   337
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   338
a27a279701f8 Initial revision
claus
parents:
diff changeset
   339
    REGISTER OBJFUNC thecode;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   340
    OBJ home;
328
claus
parents: 326
diff changeset
   341
    extern OBJ __interpret(), interpret();
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   342
a27a279701f8 Initial revision
claus
parents:
diff changeset
   343
    if (_INST(nargs) == _MKSMALLINT(2)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   344
#if defined(THIS_CONTEXT)
328
claus
parents: 326
diff changeset
   345
	if (__ISVALID_ILC_LNO(__pilc))
claus
parents: 326
diff changeset
   346
	    _ContextInstPtr(__thisContext)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   347
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   348
	thecode = _BlockInstPtr(self)->b_code;
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   349
#ifdef NEW_BLOCK_CALL
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   350
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   351
	    RETURN ( (*thecode)(self COMMA_SND, arg1, arg2) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   352
	}
328
claus
parents: 326
diff changeset
   353
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   354
	RETURN ( __interpret(self, 2, nil, nil COMMA_SND, nil, &arg1) );
claus
parents: 326
diff changeset
   355
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   356
	RETURN ( interpret(self, 2, nil, nil COMMA_SND, nil, arg1, arg2) );
328
claus
parents: 326
diff changeset
   357
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   358
#else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   359
	home = _BlockInstPtr(self)->b_home;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   360
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   361
	    RETURN ( (*thecode)(home COMMA_SND, arg1, arg2) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   362
	}
328
claus
parents: 326
diff changeset
   363
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   364
	RETURN ( __interpret(self, 2, nil, home COMMA_SND, nil, &arg1) );
claus
parents: 326
diff changeset
   365
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   366
	RETURN ( interpret(self, 2, nil, home COMMA_SND, nil, arg1, arg2) );
328
claus
parents: 326
diff changeset
   367
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   368
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   369
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   370
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   371
.
103
de0f8152878f errors now raise a signal
claus
parents: 98
diff changeset
   372
    ^ self wrongNumberOfArguments:2
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   373
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   374
a27a279701f8 Initial revision
claus
parents:
diff changeset
   375
value:arg1 value:arg2 value:arg3
a27a279701f8 Initial revision
claus
parents:
diff changeset
   376
    "evaluate the receiver with three arguments. The receiver must be a 3-arg block."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   377
a27a279701f8 Initial revision
claus
parents:
diff changeset
   378
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   379
a27a279701f8 Initial revision
claus
parents:
diff changeset
   380
    REGISTER OBJFUNC thecode;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   381
    OBJ home;
328
claus
parents: 326
diff changeset
   382
    extern OBJ __interpret(), interpret();
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   383
a27a279701f8 Initial revision
claus
parents:
diff changeset
   384
    if (_INST(nargs) == _MKSMALLINT(3)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   385
#if defined(THIS_CONTEXT)
328
claus
parents: 326
diff changeset
   386
	if (__ISVALID_ILC_LNO(__pilc))
claus
parents: 326
diff changeset
   387
	    _ContextInstPtr(__thisContext)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   388
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   389
	thecode = _BlockInstPtr(self)->b_code;
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   390
#ifdef NEW_BLOCK_CALL
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   391
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   392
	    RETURN ( (*thecode)(self COMMA_SND, arg1, arg2, arg3) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   393
	}
328
claus
parents: 326
diff changeset
   394
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   395
	RETURN ( __interpret(self, 3, nil, nil COMMA_SND, nil, &arg1) );
claus
parents: 326
diff changeset
   396
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   397
	RETURN ( interpret(self, 3, nil, nil COMMA_SND, nil, arg1, arg2, arg3) );
328
claus
parents: 326
diff changeset
   398
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   399
#else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   400
	home = _BlockInstPtr(self)->b_home;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   401
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   402
	    RETURN ( (*thecode)(home COMMA_SND, arg1, arg2, arg3) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   403
	}
328
claus
parents: 326
diff changeset
   404
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   405
	RETURN ( __interpret(self, 3, nil, home COMMA_SND, nil, &arg1) );
claus
parents: 326
diff changeset
   406
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   407
	RETURN ( interpret(self, 3, nil, home COMMA_SND, nil, arg1, arg2, arg3) );
328
claus
parents: 326
diff changeset
   408
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   409
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   410
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   411
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   412
.
103
de0f8152878f errors now raise a signal
claus
parents: 98
diff changeset
   413
    ^ self wrongNumberOfArguments:3
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   414
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   415
a27a279701f8 Initial revision
claus
parents:
diff changeset
   416
value:arg1 value:arg2 value:arg3 value:arg4
a27a279701f8 Initial revision
claus
parents:
diff changeset
   417
    "evaluate the receiver with four arguments. The receiver must be a 4-arg block."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   418
a27a279701f8 Initial revision
claus
parents:
diff changeset
   419
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   420
a27a279701f8 Initial revision
claus
parents:
diff changeset
   421
    REGISTER OBJFUNC thecode;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   422
    OBJ home;
328
claus
parents: 326
diff changeset
   423
    extern OBJ __interpret(), interpret();
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   424
a27a279701f8 Initial revision
claus
parents:
diff changeset
   425
    if (_INST(nargs) == _MKSMALLINT(4)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   426
#if defined(THIS_CONTEXT)
328
claus
parents: 326
diff changeset
   427
	if (__ISVALID_ILC_LNO(__pilc))
claus
parents: 326
diff changeset
   428
	    _ContextInstPtr(__thisContext)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   429
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   430
	thecode = _BlockInstPtr(self)->b_code;
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   431
#ifdef NEW_BLOCK_CALL
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   432
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   433
	    RETURN ( (*thecode)(self COMMA_SND, arg1, arg2, arg3, arg4) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   434
	}
328
claus
parents: 326
diff changeset
   435
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   436
	RETURN ( __interpret(self, 4, nil, nil COMMA_SND, nil, &arg1) );
claus
parents: 326
diff changeset
   437
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   438
	RETURN ( interpret(self, 4, nil, nil COMMA_SND, nil, arg1, arg2, arg3, arg4) );
328
claus
parents: 326
diff changeset
   439
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   440
#else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   441
	home = _BlockInstPtr(self)->b_home;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   442
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   443
	    RETURN ( (*thecode)(home COMMA_SND, arg1, arg2, arg3, arg4) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   444
	}
328
claus
parents: 326
diff changeset
   445
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   446
	RETURN ( __interpret(self, 4, nil, home COMMA_SND, nil, &arg1) );
claus
parents: 326
diff changeset
   447
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   448
	RETURN ( interpret(self, 4, nil, home COMMA_SND, nil, arg1, arg2, arg3, arg4) );
328
claus
parents: 326
diff changeset
   449
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   450
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   451
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   452
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   453
.
103
de0f8152878f errors now raise a signal
claus
parents: 98
diff changeset
   454
    ^ self wrongNumberOfArguments:4
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   455
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   456
a27a279701f8 Initial revision
claus
parents:
diff changeset
   457
value:arg1 value:arg2 value:arg3 value:arg4 value:arg5
a27a279701f8 Initial revision
claus
parents:
diff changeset
   458
    "evaluate the receiver with four arguments. The receiver must be a 5-arg block."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   459
a27a279701f8 Initial revision
claus
parents:
diff changeset
   460
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   461
a27a279701f8 Initial revision
claus
parents:
diff changeset
   462
    REGISTER OBJFUNC thecode;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   463
    OBJ home;
328
claus
parents: 326
diff changeset
   464
    extern OBJ __interpret(), interpret();
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   465
a27a279701f8 Initial revision
claus
parents:
diff changeset
   466
    if (_INST(nargs) == _MKSMALLINT(5)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   467
#if defined(THIS_CONTEXT)
328
claus
parents: 326
diff changeset
   468
	if (__ISVALID_ILC_LNO(__pilc))
claus
parents: 326
diff changeset
   469
	    _ContextInstPtr(__thisContext)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   470
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   471
	thecode = _BlockInstPtr(self)->b_code;
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   472
#ifdef NEW_BLOCK_CALL
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   473
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   474
	    RETURN ( (*thecode)(self COMMA_SND, arg1, arg2, arg3, arg4, arg5) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   475
	}
328
claus
parents: 326
diff changeset
   476
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   477
	RETURN ( __interpret(self, 5, nil, nil COMMA_SND, nil, &arg1) );
claus
parents: 326
diff changeset
   478
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   479
	RETURN ( interpret(self, 5, nil, nil COMMA_SND, nil, arg1, arg2, arg3, arg4, arg5) );
328
claus
parents: 326
diff changeset
   480
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   481
#else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   482
	home = _BlockInstPtr(self)->b_home;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   483
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   484
	    RETURN ( (*thecode)(home COMMA_SND, arg1, arg2, arg3, arg4, arg5) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   485
	}
328
claus
parents: 326
diff changeset
   486
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   487
	RETURN ( __interpret(self, 5, nil, home COMMA_SND, nil, &arg1) );
claus
parents: 326
diff changeset
   488
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   489
	RETURN ( interpret(self, 5, nil, home COMMA_SND, nil, arg1, arg2, arg3, arg4, arg5) );
328
claus
parents: 326
diff changeset
   490
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   491
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   492
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   493
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   494
.
103
de0f8152878f errors now raise a signal
claus
parents: 98
diff changeset
   495
    ^ self wrongNumberOfArguments:5
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   496
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   497
a27a279701f8 Initial revision
claus
parents:
diff changeset
   498
value:arg1 value:arg2 value:arg3 value:arg4 value:arg5 value:arg6
a27a279701f8 Initial revision
claus
parents:
diff changeset
   499
    "evaluate the receiver with four arguments. The receiver must be a 6-arg block."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   500
a27a279701f8 Initial revision
claus
parents:
diff changeset
   501
%{  /* NOCONTEXT */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   502
a27a279701f8 Initial revision
claus
parents:
diff changeset
   503
    REGISTER OBJFUNC thecode;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   504
    OBJ home;
328
claus
parents: 326
diff changeset
   505
    extern OBJ __interpret(), interpret();
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   506
a27a279701f8 Initial revision
claus
parents:
diff changeset
   507
    if (_INST(nargs) == _MKSMALLINT(6)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
   508
#if defined(THIS_CONTEXT)
328
claus
parents: 326
diff changeset
   509
	if (__ISVALID_ILC_LNO(__pilc))
claus
parents: 326
diff changeset
   510
	    _ContextInstPtr(__thisContext)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   511
#endif
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   512
	thecode = _BlockInstPtr(self)->b_code;
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   513
#ifdef NEW_BLOCK_CALL
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   514
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   515
	    RETURN ( (*thecode)(self COMMA_SND, arg1, arg2, arg3, arg4, arg5, arg6) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   516
	}
328
claus
parents: 326
diff changeset
   517
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   518
	RETURN ( __interpret(self, 6, nil, nil COMMA_SND, nil, &arg1) );
claus
parents: 326
diff changeset
   519
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   520
	RETURN ( interpret(self, 6, nil, nil COMMA_SND, nil, arg1, arg2, arg3, arg4, arg5, arg6) );
328
claus
parents: 326
diff changeset
   521
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   522
#else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   523
	home = _BlockInstPtr(self)->b_home;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   524
	if (thecode != (OBJFUNC)nil) {
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   525
	    RETURN ( (*thecode)(home COMMA_SND, arg1, arg2, arg3, arg4, arg5, arg6) );
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   526
	}
328
claus
parents: 326
diff changeset
   527
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   528
	RETURN ( __interpret(self, 6, nil, home COMMA_SND, nil, &arg1) );
claus
parents: 326
diff changeset
   529
# else
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   530
	RETURN ( interpret(self, 6, nil, home COMMA_SND, nil, arg1, arg2, arg3, arg4, arg5, arg6) );
328
claus
parents: 326
diff changeset
   531
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   532
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   533
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   534
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   535
.
103
de0f8152878f errors now raise a signal
claus
parents: 98
diff changeset
   536
    ^ self wrongNumberOfArguments:6
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   537
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   538
a27a279701f8 Initial revision
claus
parents:
diff changeset
   539
valueWithArguments:argArray
a27a279701f8 Initial revision
claus
parents:
diff changeset
   540
    "evaluate the receiver with arguments taken from argArray.
313
83c50ef3886a *** empty log message ***
claus
parents: 306
diff changeset
   541
     ArgArray must be either an Array or nil.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   542
     The size of the argArray must match the number of arguments the receiver expects."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   543
a27a279701f8 Initial revision
claus
parents:
diff changeset
   544
    |a1 a2 a3 a4 a5 a6 a7|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   545
319
claus
parents: 313
diff changeset
   546
    (argArray notNil and:[argArray class ~~ Array]) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   547
	^ self badArgumentArry
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   548
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   549
    (argArray size == nargs) ifFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   550
	^ self wrongNumberOfArguments:(argArray size)
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   551
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   552
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
   553
a27a279701f8 Initial revision
claus
parents:
diff changeset
   554
    REGISTER OBJFUNC thecode;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   555
    OBJ home;
328
claus
parents: 326
diff changeset
   556
    extern OBJ __interpret(), interpret();
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   557
    REGISTER OBJ *ap;
328
claus
parents: 326
diff changeset
   558
    int nargs;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   559
a27a279701f8 Initial revision
claus
parents:
diff changeset
   560
#if defined(THIS_CONTEXT)
328
claus
parents: 326
diff changeset
   561
    if (__ISVALID_ILC_LNO(__pilc))
claus
parents: 326
diff changeset
   562
	    _ContextInstPtr(__thisContext)->c_lineno = __ILC_LNO_AS_OBJ(__pilc);
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   563
#endif
328
claus
parents: 326
diff changeset
   564
    switch (nargs = _intVal(_INST(nargs))) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   565
	default:
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   566
	    goto error;
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   567
	case 7:
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   568
	    a7 = _ArrayInstPtr(argArray)->a_element[6];
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   569
	case 6:
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   570
	    a6 = _ArrayInstPtr(argArray)->a_element[5];
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   571
	case 5:
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   572
	    a5 = _ArrayInstPtr(argArray)->a_element[4];
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   573
	case 4:
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   574
	    a4 = _ArrayInstPtr(argArray)->a_element[3];
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   575
	case 3:
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   576
	    a3 = _ArrayInstPtr(argArray)->a_element[2];
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   577
	case 2:
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   578
	    a2 = _ArrayInstPtr(argArray)->a_element[1];
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   579
	case 1:
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   580
	    a1 = _ArrayInstPtr(argArray)->a_element[0];
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   581
	case 0:
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   582
	    break;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   583
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   584
    thecode = _BlockInstPtr(self)->b_code;
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   585
#ifdef NEW_BLOCK_CALL
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   586
    if (thecode != (OBJFUNC)nil) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   587
	RETURN ( (*thecode)(self COMMA_SND, a1, a2, a3, a4, a5, a6, a7) );
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   588
    }
328
claus
parents: 326
diff changeset
   589
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   590
    RETURN ( __interpret(self, nargs, nil, nil COMMA_SND, nil, &a1) );
claus
parents: 326
diff changeset
   591
# else
claus
parents: 326
diff changeset
   592
    RETURN ( interpret(self, nargs, nil, nil COMMA_SND, nil, 
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   593
		       a1, a2, a3, a4, a5, a6, a7) );
328
claus
parents: 326
diff changeset
   594
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   595
#else
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   596
    home = _BlockInstPtr(self)->b_home;
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   597
    if (thecode != (OBJFUNC)nil) {
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   598
	RETURN ( (*thecode)(home COMMA_SND, a1, a2, a3, a4, a5, a6, a7) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   599
    }
328
claus
parents: 326
diff changeset
   600
# ifdef PASS_ARG_POINTER
claus
parents: 326
diff changeset
   601
    RETURN ( __interpret(self, nargs, nil, home COMMA_SND, nil, &a1) );
claus
parents: 326
diff changeset
   602
# else
claus
parents: 326
diff changeset
   603
    RETURN ( interpret(self, nargs, nil, home COMMA_SND, nil, 
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   604
		       a1, a2, a3, a4, a5, a6, a7) );
328
claus
parents: 326
diff changeset
   605
# endif
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   606
#endif
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   607
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   608
error: ;
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   609
%}
11
6bf3080856be *** empty log message ***
claus
parents: 10
diff changeset
   610
.
138
c9f46b635f98 *** empty log message ***
claus
parents: 128
diff changeset
   611
    "
c9f46b635f98 *** empty log message ***
claus
parents: 128
diff changeset
   612
     the above code only supports up-to 7 arguments
c9f46b635f98 *** empty log message ***
claus
parents: 128
diff changeset
   613
    "
128
c50a2157883e return value of signal raise
claus
parents: 103
diff changeset
   614
    ^ ArgumentSignal
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   615
	raiseRequestWith:self
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   616
	errorString:'only blocks with up-to 7 arguments supported'
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   617
! !
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   618
325
claus
parents: 319
diff changeset
   619
!Block methodsFor:'STV compatibility'!
claus
parents: 319
diff changeset
   620
claus
parents: 319
diff changeset
   621
on:aSignal do:exceptionBlock
claus
parents: 319
diff changeset
   622
    "added for ST/V compatibility; evaluate the receiver,
claus
parents: 319
diff changeset
   623
     handling aSignal. The argument, exceptionBlock is evaluated
claus
parents: 319
diff changeset
   624
     if the signal is raised during evaluation.
claus
parents: 319
diff changeset
   625
     Warning: no warranty, if the code below mimics ST/V's behavior
claus
parents: 319
diff changeset
   626
     correctly - give me a note if it does not ."
claus
parents: 319
diff changeset
   627
claus
parents: 319
diff changeset
   628
    aSignal handle:[:ex |
claus
parents: 319
diff changeset
   629
	exceptionBlock value.
claus
parents: 319
diff changeset
   630
	ex return
claus
parents: 319
diff changeset
   631
    ] do:self
claus
parents: 319
diff changeset
   632
claus
parents: 319
diff changeset
   633
    "
claus
parents: 319
diff changeset
   634
     [
claus
parents: 319
diff changeset
   635
	1 foo
claus
parents: 319
diff changeset
   636
     ] on:MessageNotUnderstoodSignal do:[]
claus
parents: 319
diff changeset
   637
    "
claus
parents: 319
diff changeset
   638
! !
claus
parents: 319
diff changeset
   639
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   640
!Block methodsFor:'privileged evaluation'!
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   641
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   642
valueUninterruptably
213
3b56a17534fd *** empty log message ***
claus
parents: 212
diff changeset
   643
    "evaluate the receiver with interrupts blocked.
348
claus
parents: 328
diff changeset
   644
     This does not prevent preemption by a higher priority processes
claus
parents: 328
diff changeset
   645
     if any becomes runnable due to the evaluation of the receiver
claus
parents: 328
diff changeset
   646
     (i.e. if a semaphore is signalled)."
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   647
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   648
    Processor activeProcess uninterruptablyDo:self
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   649
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   650
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   651
valueUnpreemptively
213
3b56a17534fd *** empty log message ***
claus
parents: 212
diff changeset
   652
    "evaluate the receiver without the possiblity of preemption
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   653
     (i.e. at a very high priority)"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   654
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   655
    |oldPrio activeProcess|
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   656
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   657
    activeProcess := Processor activeProcess.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   658
    oldPrio := activeProcess changePriority:(Processor highestPriority).
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   659
    self valueNowOrOnUnwindDo:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   660
	activeProcess priority:oldPrio
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   661
    ]
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   662
! !
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   663
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   664
!Block methodsFor:'unwinding'!
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   665
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   666
valueNowOrOnUnwindDo:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   667
    "evaluate the receiver - after that, or when some method sent within unwinds (i.e. does
a27a279701f8 Initial revision
claus
parents:
diff changeset
   668
     a long return), evaluate the argument, aBlock.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   669
     This is used to make certain that cleanup actions (for example closing files etc.) are
a27a279701f8 Initial revision
claus
parents:
diff changeset
   670
     executed regardless of error actions"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   671
a27a279701f8 Initial revision
claus
parents:
diff changeset
   672
    |v|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   673
552
694ecccaa1a0 only evaluate unwind blocks once
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   674
    thisContext markForUnwind.
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   675
    v := self value.       "the real logic is in Context>>unwind"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   676
    aBlock value.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   677
    ^ v
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   678
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   679
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   680
     in the following example, f will be closed even if the block
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   681
     returns with 'oops'. There are many more applications of this kind
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   682
     found in the system.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   683
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   684
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   685
     |f|
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   686
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   687
     f := 'Makefile' asFilename readStream.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   688
     [
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   689
	l := f nextLine.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   690
	l isNil ifTrue:[^ 'oops']
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   691
     ] valueNowOrOnUnwindDo:[
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   692
	f close
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   693
     ]
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   694
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   695
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   696
a27a279701f8 Initial revision
claus
parents:
diff changeset
   697
valueOnUnwindDo:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   698
    "evaluate the receiver - when some method sent within unwinds (i.e. does
a27a279701f8 Initial revision
claus
parents:
diff changeset
   699
     a long return), evaluate the argument, aBlock.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   700
     This is used to make certain that cleanup actions (for example closing files etc.) are
a27a279701f8 Initial revision
claus
parents:
diff changeset
   701
     executed regardless of error actions"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   702
552
694ecccaa1a0 only evaluate unwind blocks once
Claus Gittinger <cg@exept.de>
parents: 528
diff changeset
   703
    thisContext markForUnwind.
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   704
    ^ self value        "the real logic is in Context>>unwind"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   705
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   706
a27a279701f8 Initial revision
claus
parents:
diff changeset
   707
!Block methodsFor:'looping'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   708
a27a279701f8 Initial revision
claus
parents:
diff changeset
   709
whileTrue:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   710
    "evaluate the argument, aBlock while the receiver evaluates to true.
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   711
     - usually open coded by compilers, but needed here for #perform 
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   712
       and expression evaluation."
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   713
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   714
    "this implementation is for purists ... :-)"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   715
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   716
    self value ifFalse:[^ nil].
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   717
    aBlock value.
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   718
    thisContext restart
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   719
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   720
    "
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   721
     |n|
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   722
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   723
     n := 1.
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   724
     [n <= 10] whileTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   725
	n printNewline.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   726
	n := n + 1
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   727
     ]
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   728
    "
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   729
!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   730
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   731
whileFalse:aBlock
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   732
    "evaluate the argument, aBlock while the receiver evaluates to false.
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   733
     - usually open coded by compilers, but needed here for #perform 
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   734
       and expression evaluation."
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   735
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   736
    "this implementation is for purists ... :-)"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   737
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   738
    self value ifTrue:[^ nil].
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   739
    aBlock value.
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   740
    thisContext restart
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   741
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   742
    "
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   743
     |n|
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   744
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   745
     n := 1.
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   746
     [n > 10] whileFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   747
	n printNewline.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   748
	n := n + 1
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   749
     ]
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   750
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   751
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   752
a27a279701f8 Initial revision
claus
parents:
diff changeset
   753
whileTrue
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   754
    "evaluate the receiver while it evaluates to true (ST80 compatibility)"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   755
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   756
    "this implementation is for purists ... :-)"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   757
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   758
    self value ifFalse:[^ nil].
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   759
    thisContext restart
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   760
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   761
    "
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   762
     |n|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   763
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   764
     n := 1.
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   765
     [n printNewline. (n := n + 1) <= 10] whileTrue
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   766
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   767
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   768
a27a279701f8 Initial revision
claus
parents:
diff changeset
   769
whileFalse
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   770
    "evaluate the receiver while it evaluates to false (ST80 compatibility)"
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   771
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   772
    "this implementation is for purists ... :-)"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   773
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   774
    self value ifTrue:[^ nil].
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   775
    thisContext restart
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   776
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   777
    "
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   778
     |n|
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   779
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   780
     n := 1.
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   781
     [n printNewline. (n := n + 1) > 10] whileFalse
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   782
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   783
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   784
a27a279701f8 Initial revision
claus
parents:
diff changeset
   785
doWhile:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   786
    "repeat the receiver block until aBlock evaluates to false.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   787
     The receiver is evaluated at least once."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   788
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   789
    "this implementation is for purists ... :-)"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   790
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   791
    self value.
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   792
    aBlock value ifFalse:[^ nil].
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   793
    thisContext restart
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   794
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   795
    "
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   796
     |n|
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   797
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   798
     n := 1.
68
59faa75185ba *** empty log message ***
claus
parents: 67
diff changeset
   799
     [n printNewline] doWhile:[ (n := n + 1) <= 5 ]
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   800
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   801
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   802
a27a279701f8 Initial revision
claus
parents:
diff changeset
   803
doUntil:aBlock
a27a279701f8 Initial revision
claus
parents:
diff changeset
   804
    "repeat the receiver block until aBlock evaluates to true.
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   805
     The receiver is evaluated at least once.
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   806
     This is the same as '... doWhile:[... not]' "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   807
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   808
    "this implementation is for purists ... :-)"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   809
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   810
    self value.
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   811
    aBlock value ifTrue:[^ nil].
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   812
    thisContext restart
68
59faa75185ba *** empty log message ***
claus
parents: 67
diff changeset
   813
59faa75185ba *** empty log message ***
claus
parents: 67
diff changeset
   814
    "
59faa75185ba *** empty log message ***
claus
parents: 67
diff changeset
   815
     |n|
59faa75185ba *** empty log message ***
claus
parents: 67
diff changeset
   816
59faa75185ba *** empty log message ***
claus
parents: 67
diff changeset
   817
     n := 1.
59faa75185ba *** empty log message ***
claus
parents: 67
diff changeset
   818
     [n printNewline] doUntil:[ (n := n + 1) > 5 ]
59faa75185ba *** empty log message ***
claus
parents: 67
diff changeset
   819
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   820
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   821
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   822
repeat
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   823
    "repeat the receiver forever - same as loop, for ST-80 compatibility"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   824
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   825
    self value.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   826
    thisContext restart
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   827
!
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   828
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   829
loop
a27a279701f8 Initial revision
claus
parents:
diff changeset
   830
    "repeat the receiver forever (should contain a return somewhere).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   831
     Inspired by a corresponding Self method."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   832
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   833
    self value.
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   834
    thisContext restart
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   835
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   836
    "
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   837
     |n|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   838
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   839
     n := 1.
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   840
     [
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   841
	n printNewline.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   842
	n >= 10 ifTrue:[^ nil].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   843
	n := n + 1
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   844
     ] loop
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   845
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   846
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   847
a27a279701f8 Initial revision
claus
parents:
diff changeset
   848
valueWithExit
a27a279701f8 Initial revision
claus
parents:
diff changeset
   849
    "the receiver must be a block of one argument.  It is evaluated, and is passed a block,
a27a279701f8 Initial revision
claus
parents:
diff changeset
   850
     which, if sent a value:-message, will exit the receiver block, returning the parameter of the 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   851
     value:-message. Used for premature returns to the caller.
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   852
     Taken from a manchester goody (a similar construct also appears in Self)."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   853
a27a279701f8 Initial revision
claus
parents:
diff changeset
   854
    ^ self value: [:exitValue | ^exitValue]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   855
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   856
    "
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   857
     [:exit |
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   858
	1 to:10 do:[:i |
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   859
	    Transcript showCr:i.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   860
	    i == 5 ifTrue:[exit value:'thats it']
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   861
	].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   862
	'regular block-value; never returned'
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   863
     ] valueWithExit
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   864
    "
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   865
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   866
a27a279701f8 Initial revision
claus
parents:
diff changeset
   867
loopWithExit
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   868
    "the receiver must be a block of one argument.  It is evaluated in a loop forever, 
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   869
     and is passed a block, which, if sent a value:-message, will exit the receiver block, 
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   870
     returning the parameter of the value:-message. Used for loops with exit in the middle.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   871
     Inspired by a corresponding Self method."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   872
a27a279701f8 Initial revision
claus
parents:
diff changeset
   873
    |exitBlock|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   874
a27a279701f8 Initial revision
claus
parents:
diff changeset
   875
    exitBlock := [:exitValue | ^ exitValue].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   876
    [true] whileTrue:[self value:exitBlock]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   877
68
59faa75185ba *** empty log message ***
claus
parents: 67
diff changeset
   878
    "
59faa75185ba *** empty log message ***
claus
parents: 67
diff changeset
   879
     |i|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   880
     i := 1.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   881
     [:exit |
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   882
	Transcript showCr:i.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   883
	i == 5 ifTrue:[exit value:'thats it'].
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   884
	i := i + 1
68
59faa75185ba *** empty log message ***
claus
parents: 67
diff changeset
   885
     ] loopWithExit
59faa75185ba *** empty log message ***
claus
parents: 67
diff changeset
   886
    "
67
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   887
! !
e52341804063 *** empty log message ***
claus
parents: 54
diff changeset
   888
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   889
!Block methodsFor:'process creation'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   890
a27a279701f8 Initial revision
claus
parents:
diff changeset
   891
newProcess
a27a279701f8 Initial revision
claus
parents:
diff changeset
   892
    "create a new (unscheduled) process executing the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   893
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   894
    ^ Process for:self priority:(Processor activePriority)
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   895
!
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   896
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   897
newProcessWithArguments:argArray
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   898
    "create a new (unscheduled) process executing the receiver,
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   899
     passing the elements in argArray as arguments to the receiver block."
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   900
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   901
    ^ [self valueWithArguments:argArray] newProcess
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   902
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   903
a27a279701f8 Initial revision
claus
parents:
diff changeset
   904
fork
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   905
    "create a new process executing the receiver at the current priority."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   906
a27a279701f8 Initial revision
claus
parents:
diff changeset
   907
    ^ self newProcess resume
a27a279701f8 Initial revision
claus
parents:
diff changeset
   908
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   909
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   910
forkWith:argArray
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   911
    "create a new process executing the receiver,
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   912
     passing elements in argArray as arguments to the receiver block."
44
b262907c93ea *** empty log message ***
claus
parents: 22
diff changeset
   913
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   914
    ^ [self valueWithArguments:argArray] fork.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   915
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   916
a27a279701f8 Initial revision
claus
parents:
diff changeset
   917
forkAt:priority
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   918
    "create a new process executing the receiver at a different priority."
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   919
a27a279701f8 Initial revision
claus
parents:
diff changeset
   920
    ^ (self newProcess priority:priority) resume
328
claus
parents: 326
diff changeset
   921
!
claus
parents: 326
diff changeset
   922
claus
parents: 326
diff changeset
   923
promise
claus
parents: 326
diff changeset
   924
    "create a promise on the receiver. The promise will evaluate the
claus
parents: 326
diff changeset
   925
     receiver and promise to return the value with the #value message.
claus
parents: 326
diff changeset
   926
     The evaluation will be performed as a separate process.
claus
parents: 326
diff changeset
   927
     Asking the promise for its value will either block the asking process
claus
parents: 326
diff changeset
   928
     (if the evaluation has not yet been finished) or return the value
claus
parents: 326
diff changeset
   929
     immediately."
claus
parents: 326
diff changeset
   930
claus
parents: 326
diff changeset
   931
    ^ Promise value:self
359
claus
parents: 348
diff changeset
   932
claus
parents: 348
diff changeset
   933
    "
claus
parents: 348
diff changeset
   934
     |p|
claus
parents: 348
diff changeset
   935
claus
parents: 348
diff changeset
   936
     p := [1000 factorial] promise.
claus
parents: 348
diff changeset
   937
     'do something else ...'.
claus
parents: 348
diff changeset
   938
     p value
claus
parents: 348
diff changeset
   939
    "
328
claus
parents: 326
diff changeset
   940
!
claus
parents: 326
diff changeset
   941
claus
parents: 326
diff changeset
   942
promiseAt:prio
claus
parents: 326
diff changeset
   943
    "create a promise on the receiver. The promise will evaluate the
359
claus
parents: 348
diff changeset
   944
     receiver and promise to return the value with the #value message.
328
claus
parents: 326
diff changeset
   945
     The evaluation will be performed as a separate process running at prio.
claus
parents: 326
diff changeset
   946
     Asking the promise for its value will either block the asking process
claus
parents: 326
diff changeset
   947
     (if the evaluation has not yet been finished) or return the value
claus
parents: 326
diff changeset
   948
     immediately."
claus
parents: 326
diff changeset
   949
claus
parents: 326
diff changeset
   950
    ^ Promise value:self priority:prio
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   951
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   952
92
0c73b48551ac *** empty log message ***
claus
parents: 83
diff changeset
   953
!Block methodsFor:'printing & storing'!
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   954
a27a279701f8 Initial revision
claus
parents:
diff changeset
   955
printOn:aStream
44
b262907c93ea *** empty log message ***
claus
parents: 22
diff changeset
   956
    "append a a printed representation of the block to aStream"
b262907c93ea *** empty log message ***
claus
parents: 22
diff changeset
   957
213
3b56a17534fd *** empty log message ***
claus
parents: 212
diff changeset
   958
    |homeClass h sel methodClass|
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   959
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   960
    "cheap blocks have no home context, but a method instead"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   961
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   962
    (home isNil or:[home isContext not]) ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   963
	aStream nextPutAll:'[] in '.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   964
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   965
	"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   966
	 currently, some cheap blocks don't know where they have been created
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   967
	"
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   968
	aStream nextPutAll:' ??? (optimized)'.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   969
	^ self
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   970
    ].
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   971
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   972
    "a full blown block (with home, but without method)"
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   973
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   974
    aStream nextPutAll:'[] in '. 
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   975
    h := self methodHome.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   976
    sel := h selector.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   977
"/ old:
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   978
"/    home receiver class name printOn:aStream.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   979
"/ new:
212
3edd10edefaf *** empty log message ***
claus
parents: 161
diff changeset
   980
"/    (h searchClass whichClassImplements:sel) name printOn:aStream.
213
3b56a17534fd *** empty log message ***
claus
parents: 212
diff changeset
   981
    methodClass := h methodClass.
3b56a17534fd *** empty log message ***
claus
parents: 212
diff changeset
   982
    methodClass isNil ifTrue:[
3b56a17534fd *** empty log message ***
claus
parents: 212
diff changeset
   983
	'UnboundMethod' printOn:aStream.
3b56a17534fd *** empty log message ***
claus
parents: 212
diff changeset
   984
    ] ifFalse:[
3b56a17534fd *** empty log message ***
claus
parents: 212
diff changeset
   985
	methodClass name printOn:aStream.
3b56a17534fd *** empty log message ***
claus
parents: 212
diff changeset
   986
    ].
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   987
    aStream nextPut:$-.
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   988
    sel printOn:aStream.
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   989
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
   990
"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   991
    aStream nextPutAll:'[] in '.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   992
    homeClass := home containingClass.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   993
    homeClass notNil ifTrue:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   994
	homeClass name printOn:aStream.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   995
	aStream space.
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   996
	(homeClass selectorForMethod:home) printOn:aStream
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   997
    ] ifFalse:[
154
d4236ec280a6 *** empty log message ***
claus
parents: 138
diff changeset
   998
	aStream nextPutAll:' ???' 
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   999
    ]
54
06dbdeeed4f9 *** empty log message ***
claus
parents: 48
diff changeset
  1000
"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
  1001
! !