Method.st
author claus
Mon, 04 Oct 1993 11:32:33 +0100
changeset 2 6526dde5f3ac
parent 1 a27a279701f8
child 3 24d81bf47225
permissions -rw-r--r--
2.7.2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
     1
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1989-93 by Claus Gittinger
a27a279701f8 Initial revision
claus
parents:
diff changeset
     3
              All Rights Reserved
a27a279701f8 Initial revision
claus
parents:
diff changeset
     4
a27a279701f8 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
a27a279701f8 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
a27a279701f8 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
a27a279701f8 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
a27a279701f8 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
a27a279701f8 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    11
"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    12
a27a279701f8 Initial revision
claus
parents:
diff changeset
    13
Object subclass:#Method
a27a279701f8 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:'code flags byteCode literals
a27a279701f8 Initial revision
claus
parents:
diff changeset
    15
                              source sourcePosition category'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    16
       classVariableNames:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    17
       poolDictionaries:''
a27a279701f8 Initial revision
claus
parents:
diff changeset
    18
       category:'Kernel-Methods'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    19
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    20
a27a279701f8 Initial revision
claus
parents:
diff changeset
    21
Method comment:'
a27a279701f8 Initial revision
claus
parents:
diff changeset
    22
a27a279701f8 Initial revision
claus
parents:
diff changeset
    23
COPYRIGHT (c) 1989-93 by Claus Gittinger
a27a279701f8 Initial revision
claus
parents:
diff changeset
    24
             All Rights Reserved
a27a279701f8 Initial revision
claus
parents:
diff changeset
    25
a27a279701f8 Initial revision
claus
parents:
diff changeset
    26
this class defines protocol for executable methods;
a27a279701f8 Initial revision
claus
parents:
diff changeset
    27
both compiled and interpreted methods are represented by this class.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    28
Compiled code has a non-nil code field, while interpreted methods have
a27a279701f8 Initial revision
claus
parents:
diff changeset
    29
a nil code field and non-nil byteCode field.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    30
a27a279701f8 Initial revision
claus
parents:
diff changeset
    31
The methods source-code is represented by source and sourcePosition: 
a27a279701f8 Initial revision
claus
parents:
diff changeset
    32
if sourcePosition is a Number, the source-field is the fileName and
a27a279701f8 Initial revision
claus
parents:
diff changeset
    33
sourcePosition is the character offset of the source-chunk in this source file.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    34
If sourcePosition is nil, the source is the string in the source field.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    35
a27a279701f8 Initial revision
claus
parents:
diff changeset
    36
The flags field defines things like the number of method-locals,
a27a279701f8 Initial revision
claus
parents:
diff changeset
    37
method arguments and stack size need (for interpreted methods).
a27a279701f8 Initial revision
claus
parents:
diff changeset
    38
a27a279701f8 Initial revision
claus
parents:
diff changeset
    39
WARNING: layout known by compiler and runtime system - dont change
a27a279701f8 Initial revision
claus
parents:
diff changeset
    40
a27a279701f8 Initial revision
claus
parents:
diff changeset
    41
%W% %E%
a27a279701f8 Initial revision
claus
parents:
diff changeset
    42
written spring 89 by claus
a27a279701f8 Initial revision
claus
parents:
diff changeset
    43
'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    44
a27a279701f8 Initial revision
claus
parents:
diff changeset
    45
!Method methodsFor:'accessing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    46
a27a279701f8 Initial revision
claus
parents:
diff changeset
    47
instVarAt:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
    48
    "redefined to catch access to code-field - it is a non-object"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    49
a27a279701f8 Initial revision
claus
parents:
diff changeset
    50
    index == 1 ifTrue:[^ nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
    51
    ^ super instVarAt:index
a27a279701f8 Initial revision
claus
parents:
diff changeset
    52
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    53
a27a279701f8 Initial revision
claus
parents:
diff changeset
    54
instVarAt:index put:value
a27a279701f8 Initial revision
claus
parents:
diff changeset
    55
    "redefined to catch access to code-field - it is a non-object"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    56
a27a279701f8 Initial revision
claus
parents:
diff changeset
    57
    index == 1 ifTrue:[^ nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
    58
    ^ super instVarAt:index put:value
a27a279701f8 Initial revision
claus
parents:
diff changeset
    59
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    60
a27a279701f8 Initial revision
claus
parents:
diff changeset
    61
code
a27a279701f8 Initial revision
claus
parents:
diff changeset
    62
    "return code field - since its a non-object return address as integer"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    63
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
    64
    RETURN ( _MKSMALLINT((int)(_MethodInstPtr(self)->m_code)) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
    65
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
    66
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    67
a27a279701f8 Initial revision
claus
parents:
diff changeset
    68
code:anAddress
a27a279701f8 Initial revision
claus
parents:
diff changeset
    69
    "set the code field - you should know what you do if doing this -
a27a279701f8 Initial revision
claus
parents:
diff changeset
    70
     should only be done by compiler.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    71
     Smalltalk can crash badly if playing around here ..."
a27a279701f8 Initial revision
claus
parents:
diff changeset
    72
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
    73
    if (_isSmallInteger(anAddress)) {
a27a279701f8 Initial revision
claus
parents:
diff changeset
    74
        _MethodInstPtr(self)->m_code = (OBJFUNC)_intVal(anAddress);
a27a279701f8 Initial revision
claus
parents:
diff changeset
    75
        RETURN ( self );
a27a279701f8 Initial revision
claus
parents:
diff changeset
    76
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
    77
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
    78
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    79
    self primitiveFailed
a27a279701f8 Initial revision
claus
parents:
diff changeset
    80
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    81
a27a279701f8 Initial revision
claus
parents:
diff changeset
    82
source
a27a279701f8 Initial revision
claus
parents:
diff changeset
    83
    "return the sourcestring for the receiver"
a27a279701f8 Initial revision
claus
parents:
diff changeset
    84
a27a279701f8 Initial revision
claus
parents:
diff changeset
    85
    |aStream junk|
a27a279701f8 Initial revision
claus
parents:
diff changeset
    86
a27a279701f8 Initial revision
claus
parents:
diff changeset
    87
    source notNil ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
    88
        sourcePosition isNil ifTrue:[^ source].
a27a279701f8 Initial revision
claus
parents:
diff changeset
    89
        aStream := Smalltalk systemFileStreamFor:('source/' , source).
a27a279701f8 Initial revision
claus
parents:
diff changeset
    90
        aStream notNil ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
    91
            aStream position:sourcePosition.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    92
            junk := aStream nextChunk.
a27a279701f8 Initial revision
claus
parents:
diff changeset
    93
            aStream close
a27a279701f8 Initial revision
claus
parents:
diff changeset
    94
        ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
    95
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
    96
    ^ junk
a27a279701f8 Initial revision
claus
parents:
diff changeset
    97
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
    98
a27a279701f8 Initial revision
claus
parents:
diff changeset
    99
source:aString
a27a279701f8 Initial revision
claus
parents:
diff changeset
   100
    "set the methods sourcestring"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   101
a27a279701f8 Initial revision
claus
parents:
diff changeset
   102
    source := aString.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   103
    sourcePosition := nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
   104
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   105
a27a279701f8 Initial revision
claus
parents:
diff changeset
   106
sourceFileName
a27a279701f8 Initial revision
claus
parents:
diff changeset
   107
    "return the sourcefilename if source is extern; nil otherwise"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   108
a27a279701f8 Initial revision
claus
parents:
diff changeset
   109
    sourcePosition notNil ifTrue:[^ source].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   110
    ^ nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
   111
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   112
a27a279701f8 Initial revision
claus
parents:
diff changeset
   113
sourcePosition
a27a279701f8 Initial revision
claus
parents:
diff changeset
   114
    "return the sourceposition if source is extern; nil otherwise"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   115
a27a279701f8 Initial revision
claus
parents:
diff changeset
   116
    ^ sourcePosition
a27a279701f8 Initial revision
claus
parents:
diff changeset
   117
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   118
a27a279701f8 Initial revision
claus
parents:
diff changeset
   119
sourceFileName:aFileName position:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   120
    "set the methods sourcefile/position"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   121
a27a279701f8 Initial revision
claus
parents:
diff changeset
   122
    source := aFileName.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   123
    sourcePosition := aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   124
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   125
a27a279701f8 Initial revision
claus
parents:
diff changeset
   126
literals
a27a279701f8 Initial revision
claus
parents:
diff changeset
   127
    "return the methods literal array"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   128
a27a279701f8 Initial revision
claus
parents:
diff changeset
   129
    ^ literals
a27a279701f8 Initial revision
claus
parents:
diff changeset
   130
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   131
a27a279701f8 Initial revision
claus
parents:
diff changeset
   132
literals:anArray
a27a279701f8 Initial revision
claus
parents:
diff changeset
   133
    "set the methods literal array"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   134
a27a279701f8 Initial revision
claus
parents:
diff changeset
   135
    literals := anArray
a27a279701f8 Initial revision
claus
parents:
diff changeset
   136
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   137
a27a279701f8 Initial revision
claus
parents:
diff changeset
   138
byteCode
a27a279701f8 Initial revision
claus
parents:
diff changeset
   139
    "return the methods byteCode array"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   140
a27a279701f8 Initial revision
claus
parents:
diff changeset
   141
    ^ byteCode
a27a279701f8 Initial revision
claus
parents:
diff changeset
   142
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   143
a27a279701f8 Initial revision
claus
parents:
diff changeset
   144
byteCode:aByteArray
a27a279701f8 Initial revision
claus
parents:
diff changeset
   145
    "set the methods byteCode array"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   146
a27a279701f8 Initial revision
claus
parents:
diff changeset
   147
    byteCode := aByteArray
a27a279701f8 Initial revision
claus
parents:
diff changeset
   148
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   149
a27a279701f8 Initial revision
claus
parents:
diff changeset
   150
category
a27a279701f8 Initial revision
claus
parents:
diff changeset
   151
    "return the methods category or nil"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   152
a27a279701f8 Initial revision
claus
parents:
diff changeset
   153
    ^ category
a27a279701f8 Initial revision
claus
parents:
diff changeset
   154
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   155
a27a279701f8 Initial revision
claus
parents:
diff changeset
   156
category:aStringOrSymbol
a27a279701f8 Initial revision
claus
parents:
diff changeset
   157
    "set the methods category"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   158
a27a279701f8 Initial revision
claus
parents:
diff changeset
   159
    category := aStringOrSymbol asSymbol
a27a279701f8 Initial revision
claus
parents:
diff changeset
   160
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   161
a27a279701f8 Initial revision
claus
parents:
diff changeset
   162
flags
a27a279701f8 Initial revision
claus
parents:
diff changeset
   163
    "return the flags (number of method variables, stacksize)"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   164
a27a279701f8 Initial revision
claus
parents:
diff changeset
   165
    ^ flags
a27a279701f8 Initial revision
claus
parents:
diff changeset
   166
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   167
a27a279701f8 Initial revision
claus
parents:
diff changeset
   168
flags:newFlags
a27a279701f8 Initial revision
claus
parents:
diff changeset
   169
    "set the flags (number of method variables, stacksize)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   170
     - should only be done by the compiler"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   171
a27a279701f8 Initial revision
claus
parents:
diff changeset
   172
    flags := newFlags
a27a279701f8 Initial revision
claus
parents:
diff changeset
   173
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   174
a27a279701f8 Initial revision
claus
parents:
diff changeset
   175
numberOfMethodVars:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   176
    "set the number of method variables
a27a279701f8 Initial revision
claus
parents:
diff changeset
   177
     - should only be done by the compiler"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   178
a27a279701f8 Initial revision
claus
parents:
diff changeset
   179
    |newFlags|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   180
a27a279701f8 Initial revision
claus
parents:
diff changeset
   181
    newFlags := flags.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   182
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
   183
    /* made this a primitive to get define in stc.h */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   184
    newFlags = _MKSMALLINT((_intVal(newFlags) & ~F_NVARS)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   185
                           | (_intVal(aNumber) << F_NVARSHIFT));
a27a279701f8 Initial revision
claus
parents:
diff changeset
   186
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   187
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   188
    flags := newFlags
a27a279701f8 Initial revision
claus
parents:
diff changeset
   189
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   190
a27a279701f8 Initial revision
claus
parents:
diff changeset
   191
stackSize:aNumber
a27a279701f8 Initial revision
claus
parents:
diff changeset
   192
    "set the depth of the local stack
a27a279701f8 Initial revision
claus
parents:
diff changeset
   193
     - should only be done by the compiler"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   194
a27a279701f8 Initial revision
claus
parents:
diff changeset
   195
    |newFlags|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   196
a27a279701f8 Initial revision
claus
parents:
diff changeset
   197
    newFlags := flags.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   198
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
   199
    /* made this a primitive to get define in stc.h */
a27a279701f8 Initial revision
claus
parents:
diff changeset
   200
    newFlags = _MKSMALLINT((_intVal(newFlags) & ~F_NSTACK) 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   201
                           | (_intVal(aNumber) << F_NSTACKSHIFT));
a27a279701f8 Initial revision
claus
parents:
diff changeset
   202
%}
a27a279701f8 Initial revision
claus
parents:
diff changeset
   203
.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   204
    flags := newFlags
a27a279701f8 Initial revision
claus
parents:
diff changeset
   205
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   206
a27a279701f8 Initial revision
claus
parents:
diff changeset
   207
!Method methodsFor:'queries'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   208
a27a279701f8 Initial revision
claus
parents:
diff changeset
   209
containingClass
a27a279701f8 Initial revision
claus
parents:
diff changeset
   210
    "return the class I am defined in"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   211
2
claus
parents: 1
diff changeset
   212
    Smalltalk allBehaviorsDo:[:aClass |
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   213
        (aClass containsMethod:self) ifTrue:[^ aClass]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   214
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   215
    ^ nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
   216
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   217
a27a279701f8 Initial revision
claus
parents:
diff changeset
   218
methodArgNames
a27a279701f8 Initial revision
claus
parents:
diff changeset
   219
    "return a collection with the methods argument names.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   220
     Uses Parser to parse methods source."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   221
a27a279701f8 Initial revision
claus
parents:
diff changeset
   222
    |parser sourceString|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   223
a27a279701f8 Initial revision
claus
parents:
diff changeset
   224
    sourceString := self source.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   225
    sourceString notNil ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   226
        parser := Parser parseMethodSpecification:sourceString.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   227
        parser isNil ifTrue:[^ nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   228
        ^ parser methodArgs
a27a279701f8 Initial revision
claus
parents:
diff changeset
   229
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   230
    ^ nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
   231
a27a279701f8 Initial revision
claus
parents:
diff changeset
   232
    "(Method compiledMethodAt:#printOn:) methodArgNames"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   233
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   234
a27a279701f8 Initial revision
claus
parents:
diff changeset
   235
methodVarNames
a27a279701f8 Initial revision
claus
parents:
diff changeset
   236
    "return a collection with the methods local-variable names.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   237
     Uses Parser to parse methods source."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   238
a27a279701f8 Initial revision
claus
parents:
diff changeset
   239
    |parser sourceString|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   240
a27a279701f8 Initial revision
claus
parents:
diff changeset
   241
    sourceString := self source.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   242
    sourceString notNil ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   243
        parser := Parser parseMethodArgAndVarSpecification:sourceString.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   244
        parser isNil ifTrue:[^ nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   245
        ^ parser methodVars
a27a279701f8 Initial revision
claus
parents:
diff changeset
   246
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   247
    ^ nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
   248
a27a279701f8 Initial revision
claus
parents:
diff changeset
   249
    "(Method compiledMethodAt:#printOn:) methodVarNames"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   250
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   251
a27a279701f8 Initial revision
claus
parents:
diff changeset
   252
methodArgAndVarNames
a27a279701f8 Initial revision
claus
parents:
diff changeset
   253
    "return a collection with the methods argument and variable names.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   254
     Uses Parser to parse methods source."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   255
a27a279701f8 Initial revision
claus
parents:
diff changeset
   256
    |parser sourceString argNames varNames|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   257
a27a279701f8 Initial revision
claus
parents:
diff changeset
   258
    sourceString := self source.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   259
    sourceString notNil ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   260
        parser := Parser parseMethodArgAndVarSpecification:sourceString.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   261
        parser isNil ifTrue:[^ nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   262
        argNames := parser methodArgs.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   263
        varNames := parser methodVars.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   264
        argNames isNil ifTrue:[^ varNames].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   265
        varNames isNil ifTrue:[^ argNames].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   266
        ^ (argNames , varNames)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   267
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   268
    ^ nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
   269
a27a279701f8 Initial revision
claus
parents:
diff changeset
   270
    "(Method compiledMethodAt:#printOn:) methodArgAndVarNames"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   271
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   272
a27a279701f8 Initial revision
claus
parents:
diff changeset
   273
methodComment
a27a279701f8 Initial revision
claus
parents:
diff changeset
   274
    "return the methods comment, nil if there is none"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   275
a27a279701f8 Initial revision
claus
parents:
diff changeset
   276
    |text line nQuote index qIndex qIndex2 comment|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   277
a27a279701f8 Initial revision
claus
parents:
diff changeset
   278
    text := self source asText.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   279
    (text size < 2) ifTrue:[^nil].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   280
a27a279701f8 Initial revision
claus
parents:
diff changeset
   281
    line := (text at:2).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   282
    nQuote := line occurrencesOf:(Character doubleQuote).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   283
    (nQuote == 2) ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   284
        qIndex := line indexOf:(Character doubleQuote).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   285
        qIndex2 := line indexOf:(Character doubleQuote) startingAt:(qIndex + 1).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   286
        ^ line copyFrom:(qIndex + 1) to:(qIndex2 - 1)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   287
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   288
    (nQuote == 1) ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   289
        qIndex := line indexOf:(Character doubleQuote).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   290
        comment := line copyFrom:(qIndex + 1).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   291
a27a279701f8 Initial revision
claus
parents:
diff changeset
   292
        index := 3.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   293
        line := text at:index.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   294
        nQuote := line occurrencesOf:(Character doubleQuote).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   295
        [nQuote ~~ 1] whileTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   296
            comment := comment , Character cr asString , line withoutSpaces.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   297
            index := index + 1.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   298
            line := text at:index.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   299
            nQuote := line occurrencesOf:(Character doubleQuote)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   300
        ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   301
        qIndex := line indexOf:(Character doubleQuote).
a27a279701f8 Initial revision
claus
parents:
diff changeset
   302
        ^ comment , Character cr asString , (line copyTo:(qIndex - 1)) withoutSpaces
a27a279701f8 Initial revision
claus
parents:
diff changeset
   303
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   304
    ^ nil
a27a279701f8 Initial revision
claus
parents:
diff changeset
   305
a27a279701f8 Initial revision
claus
parents:
diff changeset
   306
    "(Method compiledMethodAt:#methodComment) methodComment"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   307
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   308
a27a279701f8 Initial revision
claus
parents:
diff changeset
   309
referencesGlobal:aGlobalSymbol
a27a279701f8 Initial revision
claus
parents:
diff changeset
   310
    "return true, if this method references the global
a27a279701f8 Initial revision
claus
parents:
diff changeset
   311
     bound to aGlobalSymbol."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   312
a27a279701f8 Initial revision
claus
parents:
diff changeset
   313
    literals isNil ifTrue:[^ false].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   314
    ^ (literals identityIndexOf:aGlobalSymbol startingAt:1) ~~ 0
a27a279701f8 Initial revision
claus
parents:
diff changeset
   315
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   316
a27a279701f8 Initial revision
claus
parents:
diff changeset
   317
sends:aSelectorSymbol
a27a279701f8 Initial revision
claus
parents:
diff changeset
   318
    "return true, if this method contains a message-send
a27a279701f8 Initial revision
claus
parents:
diff changeset
   319
     with aSelectorSymbol as selector. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   320
     - due to the simple check in the literal array, also simple uses 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   321
     of aSelectorSymbol as symbol will return true."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   322
a27a279701f8 Initial revision
claus
parents:
diff changeset
   323
    ^ self referencesGlobal:aSelectorSymbol
a27a279701f8 Initial revision
claus
parents:
diff changeset
   324
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   325
a27a279701f8 Initial revision
claus
parents:
diff changeset
   326
!Method methodsFor:'error handling'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   327
a27a279701f8 Initial revision
claus
parents:
diff changeset
   328
invalidMethod
a27a279701f8 Initial revision
claus
parents:
diff changeset
   329
    "this error is triggered by the interpreter when an invalid method
a27a279701f8 Initial revision
claus
parents:
diff changeset
   330
     is about to be executed.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   331
     When recompiling classes after a definition-change, all
a27a279701f8 Initial revision
claus
parents:
diff changeset
   332
     uncompilable methods will be bound to this method here,
a27a279701f8 Initial revision
claus
parents:
diff changeset
   333
     so that evaluating such an uncompilable method will trigger an error.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   334
     Can also happen when Compiler/runtime system is broken."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   335
a27a279701f8 Initial revision
claus
parents:
diff changeset
   336
    self error:'invalid method - not executable'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   337
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   338
a27a279701f8 Initial revision
claus
parents:
diff changeset
   339
invalidByteCode
a27a279701f8 Initial revision
claus
parents:
diff changeset
   340
    "this error is triggered when the bytecode-interpreter tries to
a27a279701f8 Initial revision
claus
parents:
diff changeset
   341
     execute an invalid bytecode.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   342
     Can only happen when Compiler/runtime system is broken."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   343
a27a279701f8 Initial revision
claus
parents:
diff changeset
   344
    self error:'invalid byteCode in method - not executable'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   345
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   346
a27a279701f8 Initial revision
claus
parents:
diff changeset
   347
receiverNotBoolean
a27a279701f8 Initial revision
claus
parents:
diff changeset
   348
    "this error is triggered when the bytecode-interpreter tries to
a27a279701f8 Initial revision
claus
parents:
diff changeset
   349
     execute ifTrue:/ifFalse or whileTrue: type of expressions where the
a27a279701f8 Initial revision
claus
parents:
diff changeset
   350
     receiver is neither true nor false."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   351
a27a279701f8 Initial revision
claus
parents:
diff changeset
   352
    self error:'if/while on non-boolean receiver'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   353
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   354
a27a279701f8 Initial revision
claus
parents:
diff changeset
   355
!Method methodsFor:'executing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   356
a27a279701f8 Initial revision
claus
parents:
diff changeset
   357
valueWithReceiver:anObject arguments:argArray
2
claus
parents: 1
diff changeset
   358
    "low level call of a methods code - BIG DANGER ALERT.
claus
parents: 1
diff changeset
   359
     Perform the receiver-method on anObject as receiver and argArray as
claus
parents: 1
diff changeset
   360
     arguments. This does NO message lookup at all and mimics a
claus
parents: 1
diff changeset
   361
     traditional function call.
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   362
     This method is provided for debugging- and breakpoint-support;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   363
     not for general use. The receiver must be a method compiled in
a27a279701f8 Initial revision
claus
parents:
diff changeset
   364
     anObjects class or one of its superclasses 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   365
     - otherwise strange things (and also strange crashes) can occur. 
a27a279701f8 Initial revision
claus
parents:
diff changeset
   366
     Be warned."
a27a279701f8 Initial revision
claus
parents:
diff changeset
   367
2
claus
parents: 1
diff changeset
   368
    |a1 a2 a3 a4 a5 a6 a7 a8 a9 a10 a11 a12|
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   369
a27a279701f8 Initial revision
claus
parents:
diff changeset
   370
%{
a27a279701f8 Initial revision
claus
parents:
diff changeset
   371
    OBJFUNC code;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   372
    OBJ searchClass;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   373
    static struct inlineCache dummy = _DUMMYILC0;
2
claus
parents: 1
diff changeset
   374
    int nargs;
claus
parents: 1
diff changeset
   375
    OBJ *ap;
claus
parents: 1
diff changeset
   376
claus
parents: 1
diff changeset
   377
    if (_isArray(argArray)) {
claus
parents: 1
diff changeset
   378
        nargs = _arraySize(argArray);
claus
parents: 1
diff changeset
   379
	ap = _ArrayInstPtr(argArray)->a_element;
claus
parents: 1
diff changeset
   380
    } else {
claus
parents: 1
diff changeset
   381
	if (argArray == nil) {
claus
parents: 1
diff changeset
   382
	    nargs = 0;
claus
parents: 1
diff changeset
   383
	} else
claus
parents: 1
diff changeset
   384
	    nargs = -1;
claus
parents: 1
diff changeset
   385
    }
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   386
a27a279701f8 Initial revision
claus
parents:
diff changeset
   387
    code = _MethodInstPtr(self)->m_code;
a27a279701f8 Initial revision
claus
parents:
diff changeset
   388
    searchClass = dummy.ilc_class = _Class(anObject);
2
claus
parents: 1
diff changeset
   389
    switch (nargs) {
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   390
        case 0:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   391
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   392
a27a279701f8 Initial revision
claus
parents:
diff changeset
   393
        case 1:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   394
#ifdef PASS_ARG_REF
2
claus
parents: 1
diff changeset
   395
            a1 = ap[0];
claus
parents: 1
diff changeset
   396
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, &a1 );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   397
#else
2
claus
parents: 1
diff changeset
   398
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, ap[0]) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   399
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   400
a27a279701f8 Initial revision
claus
parents:
diff changeset
   401
        case 2:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   402
#ifdef PASS_ARG_REF
2
claus
parents: 1
diff changeset
   403
            a1 = ap[0];
claus
parents: 1
diff changeset
   404
            a2 = ap[1];
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   405
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, &a1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   406
#else
2
claus
parents: 1
diff changeset
   407
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, ap[0], ap[1]) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   408
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   409
a27a279701f8 Initial revision
claus
parents:
diff changeset
   410
        case 3:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   411
#ifdef PASS_ARG_REF
2
claus
parents: 1
diff changeset
   412
            a1 = ap[0];
claus
parents: 1
diff changeset
   413
            a2 = ap[1];
claus
parents: 1
diff changeset
   414
            a3 = ap[2];
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   415
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, &a1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   416
#else
2
claus
parents: 1
diff changeset
   417
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, ap[0], ap[1], ap[2]) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   418
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   419
a27a279701f8 Initial revision
claus
parents:
diff changeset
   420
        case 4:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   421
#ifdef PASS_ARG_REF
2
claus
parents: 1
diff changeset
   422
            a1 = ap[0];
claus
parents: 1
diff changeset
   423
            a2 = ap[1];
claus
parents: 1
diff changeset
   424
            a3 = ap[2];
claus
parents: 1
diff changeset
   425
            a4 = ap[3];
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   426
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, &a1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   427
#else
2
claus
parents: 1
diff changeset
   428
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, ap[0], ap[1], ap[2], ap[3]) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   429
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   430
a27a279701f8 Initial revision
claus
parents:
diff changeset
   431
        case 5:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   432
#ifdef PASS_ARG_REF
2
claus
parents: 1
diff changeset
   433
            a1 = ap[0];
claus
parents: 1
diff changeset
   434
            a2 = ap[1];
claus
parents: 1
diff changeset
   435
            a3 = ap[2];
claus
parents: 1
diff changeset
   436
            a4 = ap[3];
claus
parents: 1
diff changeset
   437
            a5 = ap[4];
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   438
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, &a1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   439
#else
2
claus
parents: 1
diff changeset
   440
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, ap[0], ap[1], ap[2], ap[3], ap[4]) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   441
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   442
a27a279701f8 Initial revision
claus
parents:
diff changeset
   443
        case 6:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   444
#ifdef PASS_ARG_REF
2
claus
parents: 1
diff changeset
   445
            a1 = ap[0];
claus
parents: 1
diff changeset
   446
            a2 = ap[1];
claus
parents: 1
diff changeset
   447
            a3 = ap[2];
claus
parents: 1
diff changeset
   448
            a4 = ap[3];
claus
parents: 1
diff changeset
   449
            a5 = ap[4];
claus
parents: 1
diff changeset
   450
            a6 = ap[5];
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   451
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, &a1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   452
#else
2
claus
parents: 1
diff changeset
   453
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, ap[0], ap[1], ap[2], ap[3], ap[4], 
claus
parents: 1
diff changeset
   454
									   ap[5]) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   455
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   456
a27a279701f8 Initial revision
claus
parents:
diff changeset
   457
        case 7:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   458
#ifdef PASS_ARG_REF
2
claus
parents: 1
diff changeset
   459
            a1 = ap[0];
claus
parents: 1
diff changeset
   460
            a2 = ap[1];
claus
parents: 1
diff changeset
   461
            a3 = ap[2];
claus
parents: 1
diff changeset
   462
            a4 = ap[3];
claus
parents: 1
diff changeset
   463
            a5 = ap[4];
claus
parents: 1
diff changeset
   464
            a6 = ap[5];
claus
parents: 1
diff changeset
   465
            a7 = ap[6];
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   466
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, &a1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   467
#else
2
claus
parents: 1
diff changeset
   468
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, ap[0], ap[1], ap[2], ap[3], ap[4], 
claus
parents: 1
diff changeset
   469
									   ap[5], ap[6]) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   470
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   471
a27a279701f8 Initial revision
claus
parents:
diff changeset
   472
        case 8:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   473
#ifdef PASS_ARG_REF
2
claus
parents: 1
diff changeset
   474
            a1 = ap[0];
claus
parents: 1
diff changeset
   475
            a2 = ap[1];
claus
parents: 1
diff changeset
   476
            a3 = ap[2];
claus
parents: 1
diff changeset
   477
            a4 = ap[3];
claus
parents: 1
diff changeset
   478
            a5 = ap[4];
claus
parents: 1
diff changeset
   479
            a6 = ap[5];
claus
parents: 1
diff changeset
   480
            a7 = ap[6];
claus
parents: 1
diff changeset
   481
            a8 = ap[7];
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   482
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, &a1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   483
#else
2
claus
parents: 1
diff changeset
   484
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, ap[0], ap[1], ap[2], ap[3], ap[4], 
claus
parents: 1
diff changeset
   485
									   ap[5], ap[6], ap[7]) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   486
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   487
a27a279701f8 Initial revision
claus
parents:
diff changeset
   488
        case 9:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   489
#ifdef PASS_ARG_REF
2
claus
parents: 1
diff changeset
   490
            a1 = ap[0];
claus
parents: 1
diff changeset
   491
            a2 = ap[1];
claus
parents: 1
diff changeset
   492
            a3 = ap[2];
claus
parents: 1
diff changeset
   493
            a4 = ap[3];
claus
parents: 1
diff changeset
   494
            a5 = ap[4];
claus
parents: 1
diff changeset
   495
            a6 = ap[5];
claus
parents: 1
diff changeset
   496
            a7 = ap[6];
claus
parents: 1
diff changeset
   497
            a8 = ap[7];
claus
parents: 1
diff changeset
   498
            a9 = ap[8];
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   499
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, &a1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   500
#else
2
claus
parents: 1
diff changeset
   501
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, ap[0], ap[1], ap[2], ap[3], ap[4], 
claus
parents: 1
diff changeset
   502
									   ap[5], ap[6], ap[7], ap[8]) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   503
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   504
a27a279701f8 Initial revision
claus
parents:
diff changeset
   505
        case 10:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   506
#ifdef PASS_ARG_REF
2
claus
parents: 1
diff changeset
   507
            a1 = ap[0];
claus
parents: 1
diff changeset
   508
            a2 = ap[1];
claus
parents: 1
diff changeset
   509
            a3 = ap[2];
claus
parents: 1
diff changeset
   510
            a4 = ap[3];
claus
parents: 1
diff changeset
   511
            a5 = ap[4];
claus
parents: 1
diff changeset
   512
            a6 = ap[5];
claus
parents: 1
diff changeset
   513
            a7 = ap[6];
claus
parents: 1
diff changeset
   514
            a8 = ap[7];
claus
parents: 1
diff changeset
   515
            a9 = ap[8];
claus
parents: 1
diff changeset
   516
            a10 = ap[9];
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   517
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, &a1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   518
#else
2
claus
parents: 1
diff changeset
   519
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, ap[0], ap[1], ap[2], ap[3], ap[4], 
claus
parents: 1
diff changeset
   520
									   ap[5], ap[6], ap[7], ap[8], ap[9]) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   521
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   522
a27a279701f8 Initial revision
claus
parents:
diff changeset
   523
        case 11:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   524
#ifdef PASS_ARG_REF
2
claus
parents: 1
diff changeset
   525
            a1 = ap[0];
claus
parents: 1
diff changeset
   526
            a2 = ap[1];
claus
parents: 1
diff changeset
   527
            a3 = ap[2];
claus
parents: 1
diff changeset
   528
            a4 = ap[3];
claus
parents: 1
diff changeset
   529
            a5 = ap[4];
claus
parents: 1
diff changeset
   530
            a6 = ap[5];
claus
parents: 1
diff changeset
   531
            a7 = ap[6];
claus
parents: 1
diff changeset
   532
            a8 = ap[7];
claus
parents: 1
diff changeset
   533
            a9 = ap[8];
claus
parents: 1
diff changeset
   534
            a10 = ap[9];
claus
parents: 1
diff changeset
   535
            a11 = ap[10];
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   536
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, &a1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   537
#else
2
claus
parents: 1
diff changeset
   538
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, ap[0], ap[1], ap[2], ap[3], ap[4], 
claus
parents: 1
diff changeset
   539
									   ap[5], ap[6], ap[7], ap[8], ap[9], 
claus
parents: 1
diff changeset
   540
									   ap[10]) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   541
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   542
a27a279701f8 Initial revision
claus
parents:
diff changeset
   543
        case 12:
a27a279701f8 Initial revision
claus
parents:
diff changeset
   544
#ifdef PASS_ARG_REF
2
claus
parents: 1
diff changeset
   545
            a1 = ap[0];
claus
parents: 1
diff changeset
   546
            a2 = ap[1];
claus
parents: 1
diff changeset
   547
            a3 = ap[2];
claus
parents: 1
diff changeset
   548
            a4 = ap[3];
claus
parents: 1
diff changeset
   549
            a5 = ap[4];
claus
parents: 1
diff changeset
   550
            a6 = ap[5];
claus
parents: 1
diff changeset
   551
            a7 = ap[6];
claus
parents: 1
diff changeset
   552
            a8 = ap[7];
claus
parents: 1
diff changeset
   553
            a9 = ap[8];
claus
parents: 1
diff changeset
   554
            a10 = ap[9];
claus
parents: 1
diff changeset
   555
            a11 = ap[10];
claus
parents: 1
diff changeset
   556
            a12 = ap[11];
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   557
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, &a1) );
a27a279701f8 Initial revision
claus
parents:
diff changeset
   558
#else
2
claus
parents: 1
diff changeset
   559
            RETURN ( (*code)(anObject, nil, SND_COMMA searchClass, &dummy, ap[0], ap[1], ap[2], ap[3], ap[4], 
claus
parents: 1
diff changeset
   560
									   ap[5], ap[6], ap[7], ap[8], ap[9], 
claus
parents: 1
diff changeset
   561
									   ap[10], ap[11]) );
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   562
#endif
a27a279701f8 Initial revision
claus
parents:
diff changeset
   563
    }
a27a279701f8 Initial revision
claus
parents:
diff changeset
   564
%}
2
claus
parents: 1
diff changeset
   565
.
claus
parents: 1
diff changeset
   566
    (argArray isMemberOf:Array) ifFalse:[
claus
parents: 1
diff changeset
   567
        ^ self error:'argumentArray must be an Array'
claus
parents: 1
diff changeset
   568
    ].
claus
parents: 1
diff changeset
   569
    ^ self error:'too many arguments'
claus
parents: 1
diff changeset
   570
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   571
    "(String compiledMethodAt:#print) valueWithReceiver:'hello' arguments:#()"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   572
    "(Float compiledMethodAt:#+) valueWithReceiver:1.0 arguments:#(2.0)"
2
claus
parents: 1
diff changeset
   573
    "the next example is a wrong one - but will not crash the system ..."
claus
parents: 1
diff changeset
   574
    "(True compiledMethodAt:#printString) valueWithReceiver:false arguments:nil"
1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   575
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   576
a27a279701f8 Initial revision
claus
parents:
diff changeset
   577
!Method methodsFor:'printing'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   578
a27a279701f8 Initial revision
claus
parents:
diff changeset
   579
printOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   580
    "put a printed representation of the receiver onto aStream"
a27a279701f8 Initial revision
claus
parents:
diff changeset
   581
a27a279701f8 Initial revision
claus
parents:
diff changeset
   582
    |homeClass|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   583
a27a279701f8 Initial revision
claus
parents:
diff changeset
   584
    homeClass := self containingClass.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   585
    homeClass notNil ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   586
        aStream nextPutAll:'a Method in '.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   587
        homeClass name printOn:aStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   588
        aStream nextPutAll:' '.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   589
        (homeClass selectorForMethod:self) printOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   590
    ] ifFalse:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   591
        aStream nextPutAll:'a Method'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   592
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   593
! !
a27a279701f8 Initial revision
claus
parents:
diff changeset
   594
a27a279701f8 Initial revision
claus
parents:
diff changeset
   595
!Method methodsFor:'binary fileOut'!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   596
a27a279701f8 Initial revision
claus
parents:
diff changeset
   597
binaryFileOutLiteralsOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   598
    |index n|
a27a279701f8 Initial revision
claus
parents:
diff changeset
   599
a27a279701f8 Initial revision
claus
parents:
diff changeset
   600
    literals isNil ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   601
        aStream nextPutAll:'0'.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   602
        aStream nextPut:$!!.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   603
        ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   604
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   605
    aStream nextPutAll:literals size printString.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   606
    aStream nextPut:$!!.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   607
a27a279701f8 Initial revision
claus
parents:
diff changeset
   608
    index := 1.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   609
    literals do:[:lit |
a27a279701f8 Initial revision
claus
parents:
diff changeset
   610
        (lit isKindOf:Number) ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   611
            lit storeOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   612
        ] ifFalse:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   613
            ((lit isKindOf:String) or:[lit isKindOf:Character]) ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   614
                lit storeOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   615
            ] ifFalse:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   616
                (lit isKindOf:Array) ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   617
                    aStream nextPut:$(.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   618
                    lit storeOn:aStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   619
                    aStream nextPut:$)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   620
                ] ifFalse:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   621
                    (lit isBehavior "isKindOf:Class") ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   622
                        aStream nextPutAll:'(Smalltalk at:#'.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   623
                        n := lit name.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   624
                        (lit isMeta "isKindOf:Metaclass") ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   625
                            n := (n copyFrom:1 to:(n size - 5)) , ') class'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   626
                        ] ifFalse:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   627
                            n := n , ')'
a27a279701f8 Initial revision
claus
parents:
diff changeset
   628
                        ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   629
                        aStream nextPutAll:n
a27a279701f8 Initial revision
claus
parents:
diff changeset
   630
                    ] ifFalse:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   631
                        self error:('invalid literal ' , lit class name)
a27a279701f8 Initial revision
claus
parents:
diff changeset
   632
                    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   633
                ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   634
            ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   635
        ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   636
        aStream nextPut:$!!.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   637
        index := index + 1
a27a279701f8 Initial revision
claus
parents:
diff changeset
   638
    ]
a27a279701f8 Initial revision
claus
parents:
diff changeset
   639
!
a27a279701f8 Initial revision
claus
parents:
diff changeset
   640
a27a279701f8 Initial revision
claus
parents:
diff changeset
   641
binaryFileOutOn:aStream
a27a279701f8 Initial revision
claus
parents:
diff changeset
   642
    byteCode isNil ifTrue:[
a27a279701f8 Initial revision
claus
parents:
diff changeset
   643
        self notify:'no bytecodes to fileout'.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   644
        ^ self
a27a279701f8 Initial revision
claus
parents:
diff changeset
   645
    ].
a27a279701f8 Initial revision
claus
parents:
diff changeset
   646
    self binaryFileOutLiteralsOn:aStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   647
a27a279701f8 Initial revision
claus
parents:
diff changeset
   648
    flags storeOn:aStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   649
    aStream nextPut:$!!.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   650
a27a279701f8 Initial revision
claus
parents:
diff changeset
   651
    byteCode size storeOn:aStream.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   652
    aStream nextPut:$!!.
a27a279701f8 Initial revision
claus
parents:
diff changeset
   653
    aStream nextPutBytes:(byteCode size) from:byteCode
a27a279701f8 Initial revision
claus
parents:
diff changeset
   654
! !