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