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