Parser.st
author claus
Sun, 31 Jul 1994 00:27:01 +0200
changeset 21 338c3cfeffbf
parent 20 f8dd8ba75205
child 23 1f7bcfff8d39
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
     1
"
4
f6fd83437415 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
     3
              All Rights Reserved
7ad01559b262 Initial revision
claus
parents:
diff changeset
     4
7ad01559b262 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
7ad01559b262 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
7ad01559b262 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
7ad01559b262 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
7ad01559b262 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
7ad01559b262 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    11
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
    12
7ad01559b262 Initial revision
claus
parents:
diff changeset
    13
Scanner subclass:#Parser
7ad01559b262 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:'classToCompileFor selfValue
7ad01559b262 Initial revision
claus
parents:
diff changeset
    15
                              contextToEvaluateIn
7ad01559b262 Initial revision
claus
parents:
diff changeset
    16
                              selector
7ad01559b262 Initial revision
claus
parents:
diff changeset
    17
                              methodArgs methodArgNames 
7ad01559b262 Initial revision
claus
parents:
diff changeset
    18
                              methodVars methodVarNames 
7ad01559b262 Initial revision
claus
parents:
diff changeset
    19
                              tree
7ad01559b262 Initial revision
claus
parents:
diff changeset
    20
                              currentBlock
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
    21
                              usedInstVars usedClassVars usedVars
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    22
                              modifiedInstVars modifiedClassVars
7ad01559b262 Initial revision
claus
parents:
diff changeset
    23
                              localVarDefPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
    24
                              evalExitBlock
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    25
                              selfNode superNode 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    26
                              hasPrimitiveCode primitiveNr logged
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    27
                              warnedUndefVars
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    28
                              correctedSource'
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
    29
       classVariableNames:'PrevClass PrevInstVarNames 
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    30
                           PrevClassVarNames PrevClassInstVarNames
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    31
                           LazyCompilation'
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    32
       poolDictionaries:''
7ad01559b262 Initial revision
claus
parents:
diff changeset
    33
       category:'System-Compiler'
7ad01559b262 Initial revision
claus
parents:
diff changeset
    34
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    35
7ad01559b262 Initial revision
claus
parents:
diff changeset
    36
Parser comment:'
4
f6fd83437415 *** empty log message ***
claus
parents: 3
diff changeset
    37
COPYRIGHT (c) 1989 by Claus Gittinger
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    38
             All Rights Reserved
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    39
'!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    40
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    41
!Parser class methodsFor:'documentation'!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    42
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    43
copyright
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    44
"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    45
 COPYRIGHT (c) 1989 by Claus Gittinger
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    46
              All Rights Reserved
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    47
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    48
 This software is furnished under a license and may be used
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    49
 only in accordance with the terms of that license and with the
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    50
 inclusion of the above copyright notice.   This software may not
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    51
 be provided or otherwise made available to, or used by, any
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    52
 other person.  No title to or ownership of the software is
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    53
 hereby transferred.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    54
"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    55
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    56
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    57
version
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    58
"
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
    59
$Header: /cvs/stx/stx/libcomp/Parser.st,v 1.12 1994-07-30 22:27:01 claus Exp $
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    60
"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    61
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    62
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    63
documentation
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    64
"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    65
    Parser is used for both parsing and evaluating smalltalk expressions;
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    66
    it first builds a parseTree which is then interpreted (evaluate) or
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    67
    compiled. Compilation is done in the subclass ByteCodeCompiler and/or
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    68
    the (planned) MachineCodeCompiler.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    69
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    70
    methods of main interrest are:
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    71
        Parser evaluateExpression:...
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    72
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    73
    and:
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    74
        Parser parseExpression:...
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    75
        Parser parseMethod:...
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    76
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    77
    there is protocol to parse complete methods, selector specs, body only etc.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    78
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    79
    Parser is also used to find the referenced/modified inst/classvars of
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    80
    a method - this is done by sending parseXXX message to a parser and asking
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    81
    the parser for referencedXVars or modifiedXVars (see SystemBrowser).
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    82
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    83
    You can also use parsers for all kinds of other things (ChangesBrowser for
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    84
    example analyzes the expressions in the changelist ...) by looking at the
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    85
    parsers tree. (Although this is somewhat dangerous, since it exports the
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    86
    compilers internals ... better style is to add specialized query methods here,
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    87
    which will be done incrementally.)
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    88
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    89
    One instance of Parser is created to parse one method or expression - i.e.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    90
    its not suggested to reuse parsers.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    91
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    92
    Instance variables:
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    93
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    94
        classToCompileFor   <Class>             the class (or nil) we are compiling for
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    95
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    96
        selfValue           <any>               value to use as self when interpreting
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    97
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    98
        contextToEvaluateIn <Context>           the context (or nil) when interpreting
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    99
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   100
        selector            <Symbol>            the selector of the parsed method
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   101
                                                (valid after parseMethodSpecification)
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   102
        methodArgs                              internal
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   103
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   104
        methodArgNames      <Collection>        the names of the arguments
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   105
                                                (valid after parseMethodSpecification)
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   106
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   107
        methodVars                              internal
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   108
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   109
        methodVarNames      <Collection>        the names of the method locals
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   110
                                                (valid after parseMethodBodyVarSpec)
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   111
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   112
        tree                <ParseTree>         the parse tree - valid after parsing
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   113
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   114
        currentBlock                            if currently parsing for a block
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   115
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   116
        usedInstVars                            set of all accessed instances variables
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   117
                                                (valid after parsing)
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   118
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   119
        usedClassVars                           same for classVars
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   120
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   121
        usedVars                                all used variables (inst, class & globals)
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   122
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   123
        modifiedInstVars                        set of all modified instance variables
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   124
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   125
        modifiedClassVars                       same for clasVars
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   126
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   127
        localVarDefPosition <Integer>           the character offset of the local variable
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   128
                                                def. (i.e. the first '|' if any)
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   129
                                                Not yet used - prepared for automatic add of
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   130
                                                undefined variables
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   131
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   132
        evalExitBlock                           internal for interpretation
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   133
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   134
        selfNode            <Node>              cached one-and-only 'self' node
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   135
        superNode           <Node>              cached one-and-only 'super' node
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   136
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   137
        hasPrimitiveCode    <Boolean>           true, if it contains ST/X style primitive code
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   138
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   139
        primitiveNr         <Integer>           the parsed ST-80 type primitive number (or nil)
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   140
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   141
        logged
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   142
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   143
        warnedUndefVars     <Set>               set of all variables which the parser has
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   144
                                                already output a warning (to avoid multiple
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   145
                                                warnings about the same variable)
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   146
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   147
    Class variables:
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   148
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   149
        PrevClass           <Class>             class, of which properties are
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   150
                                                cached in:
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   151
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   152
        PrevInstVarNames      <Collection>      instance variablenames of cached class
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   153
        PrevClassVarNames     <Collection>      class variablenames of cached class
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   154
        PrevClassInstVarNames <Collection>      class instance variablenames of cached class
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   155
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   156
        LazyCompilation     <Boolean>           EXPERIMENTAL: lazy compilation
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   157
"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   158
! !
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   159
7ad01559b262 Initial revision
claus
parents:
diff changeset
   160
!Parser class methodsFor:'evaluating expressions'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   161
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   162
evaluate:aStringOrStream
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   163
    "return the result of evaluating an expression in aStringOrStream"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   164
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   165
    ^ self 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   166
        evaluate:aStringOrStream 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   167
        in:nil 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   168
        receiver:nil 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   169
        notifying:nil 
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   170
        logged:false
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   171
        ifFail:nil 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   172
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   173
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   174
     Compiler evaluate:'1 + 2'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   175
     Compiler evaluate:'''hello world'' asSortedCollection displayString printNL'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   176
     Compiler evaluate:'''hello world'' asSortedCollection printNL'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   177
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   178
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   179
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   180
evaluate:aStringOrStream ifFail:failBlock
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   181
    "return the result of evaluating an expression in aStringOrStream.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   182
     In case of any syntax errors, return the value of failBlock."
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   183
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   184
    ^ self 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   185
        evaluate:aStringOrStream 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   186
        in:nil 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   187
        receiver:nil 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   188
        notifying:nil 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   189
        logged:false
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   190
        ifFail:failBlock 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   191
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   192
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   193
     Compiler evaluate:'1 +' ifFail:['oops']   
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   194
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   195
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   196
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   197
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   198
evaluate:aStringOrStream logged:logged
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   199
    "return the result of evaluating an expression in aStringOrStream"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   200
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   201
    ^ self 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   202
        evaluate:aStringOrStream 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   203
        in:nil 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   204
        receiver:nil 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   205
        notifying:nil 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   206
        logged:logged
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   207
        ifFail:nil 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   208
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   209
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   210
evaluate:aStringOrStream notifying:requestor
7ad01559b262 Initial revision
claus
parents:
diff changeset
   211
    "return the result of evaluating aString, 
7ad01559b262 Initial revision
claus
parents:
diff changeset
   212
     errors are reported to requestor"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   213
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   214
    ^ self 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   215
        evaluate:aStringOrStream 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   216
        in:nil 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   217
        receiver:nil 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   218
        notifying:requestor
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   219
        logged:false
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   220
        ifFail:nil 
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   221
7ad01559b262 Initial revision
claus
parents:
diff changeset
   222
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   223
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   224
evaluate:aStringOrStream receiver:anObject notifying:requestor
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   225
    "return the result of evaluating aString, 
7ad01559b262 Initial revision
claus
parents:
diff changeset
   226
     errors are reported to requestor. Allow access to
7ad01559b262 Initial revision
claus
parents:
diff changeset
   227
     anObject as self and to its instVars (used in the inspector)"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   228
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   229
    ^ self 
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   230
        evaluate:aStringOrStream
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   231
        in:nil
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   232
        receiver:anObject
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   233
        notifying:requestor
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   234
        logged:false
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   235
        ifFail:nil
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   236
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   237
7ad01559b262 Initial revision
claus
parents:
diff changeset
   238
evaluate:aStringOrStream in:aContext receiver:anObject 
7ad01559b262 Initial revision
claus
parents:
diff changeset
   239
                                    notifying:requestor
7ad01559b262 Initial revision
claus
parents:
diff changeset
   240
                                       ifFail:failBlock
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   241
    ^ self 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   242
        evaluate:aStringOrStream
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   243
        in:nil
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   244
        receiver:anObject
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   245
        notifying:requestor
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   246
        logged:false
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   247
        ifFail:nil
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   248
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   249
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   250
evaluate:aStringOrStream in:aContext receiver:anObject notifying:requestor logged:logged ifFail:failBlock
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   251
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   252
     Allow access to anObject as self and to its instVars (used in the inspector).
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   253
     If logged is true, an entry is added to the change-file. If the failBlock argument
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   254
     is non-nil, it is evaluated if an error occurs."
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   255
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   256
    "XXX: logging is not yet implemented"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   257
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   258
    |parser tree mustBackup|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   259
7ad01559b262 Initial revision
claus
parents:
diff changeset
   260
    aStringOrStream isNil ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   261
    aStringOrStream isStream ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   262
        parser := self for:aStringOrStream.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   263
        mustBackup := true
7ad01559b262 Initial revision
claus
parents:
diff changeset
   264
    ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   265
        parser := self for:(ReadStream on:aStringOrStream).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   266
        mustBackup := false
7ad01559b262 Initial revision
claus
parents:
diff changeset
   267
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   268
    parser setSelf:anObject.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   269
    parser setContext:aContext.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   270
    parser notifying:requestor.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   271
    parser nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   272
    tree := parser parseMethodBodyOrNil.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   273
7ad01559b262 Initial revision
claus
parents:
diff changeset
   274
    "if reading from a stream, backup for next expression"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   275
    mustBackup ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   276
        parser backupPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
   277
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   278
7ad01559b262 Initial revision
claus
parents:
diff changeset
   279
    (parser errorFlag or:[tree == #Error]) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   280
        failBlock notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   281
            ^ failBlock value
7ad01559b262 Initial revision
claus
parents:
diff changeset
   282
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   283
        ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
   284
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   285
    tree notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   286
        parser evalExitBlock:[:value | ^ value].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   287
        ^ tree evaluate
7ad01559b262 Initial revision
claus
parents:
diff changeset
   288
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   289
    ^ nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
   290
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   291
7ad01559b262 Initial revision
claus
parents:
diff changeset
   292
!Parser class methodsFor:'instance creation'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   293
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   294
for:aStringOrStream in:aClass
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   295
    "return a new parser, reading code for aClass from aStringOrStream"
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   296
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   297
    |parser|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   298
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   299
    parser := self for:aStringOrStream.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   300
    parser setClassToCompileFor:aClass.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   301
    ^ parser
7ad01559b262 Initial revision
claus
parents:
diff changeset
   302
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   303
7ad01559b262 Initial revision
claus
parents:
diff changeset
   304
!Parser class methodsFor:'parsing'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   305
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   306
selectorInExpression:aString
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   307
    "parse an expression - return the selector. 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   308
     Used for SystemBrowsers implementors/senders query-box initial text.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   309
     Returns nil if unparsable."
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   310
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   311
    |tree parser|
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   312
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   313
    (aString isNil or:[aString isEmpty]) ifTrue:[^ nil].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   314
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   315
    tree := self withSelf:nil 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   316
                 parseExpression:aString 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   317
                 notifying:nil 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   318
                 ignoreErrors:true 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   319
                 ignoreWarnings:true. 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   320
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   321
    "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   322
     special: take the expression of the right side, if its an
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   323
     assignment or return
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   324
    "
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   325
    (tree notNil and:[tree ~~ #Error]) ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   326
        tree isAssignment ifTrue:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   327
            tree expression isMessage ifTrue:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   328
                tree := tree expression
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   329
            ]
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   330
        ].
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   331
        tree isReturnNode ifTrue:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   332
            tree expression isMessage ifTrue:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   333
                tree := tree expression
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   334
            ]
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   335
        ].
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   336
9
a855c33612fb *** empty log message ***
claus
parents: 7
diff changeset
   337
        tree isMessage ifTrue:[
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   338
            ^ tree selector
9
a855c33612fb *** empty log message ***
claus
parents: 7
diff changeset
   339
        ].
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   340
    ].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   341
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   342
    "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   343
     mhmh, try expression without receiver
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   344
    "
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   345
    parser := self for:(ReadStream on:aString).
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   346
    parser ignoreErrors.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   347
    parser nextToken.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   348
    ^ parser degeneratedKeywordExpressionForSelector
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   349
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   350
"
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   351
    Parser selectorInExpression:'foo at:1 put:(5 * bar)'     
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   352
    Parser selectorInExpression:'(foo at:1) at:1'           
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   353
    Parser selectorInExpression:'1 + 4'                     
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   354
    Parser selectorInExpression:'1 negated'                 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   355
    Parser selectorInExpression:'at:1 put:5'            
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   356
    Parser selectorInExpression:'a := foo at:1 put:5'    
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   357
"
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   358
!
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   359
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   360
parseExpression:aString
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   361
    "parse aString as an expression; 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   362
     Return the parseTree (if ok), nil (for an empty string 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   363
     or comment only) or #Error (syntactic error)."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   364
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   365
    ^ self withSelf:nil 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   366
           parseExpression:aString 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   367
           notifying:nil 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   368
           ignoreErrors:true       "silence on Transcript"
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   369
           ignoreWarnings:true 
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   370
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   371
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   372
withSelf:anObject parseExpression:aString notifying:someOne 
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   373
    "parse aString as an expression with self set to anObject;
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   374
     Return the parseTree (if ok), nil (for an empty string 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   375
     or comment only ) or #Error (syntactic error).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   376
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   377
     Errors and warnings are forwarded to someOne (usually some
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   378
     codeView) which can highlight it and show a popup box."
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   379
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   380
    ^ self withSelf:anObject 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   381
           parseExpression:aString 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   382
           notifying:someOne 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   383
           ignoreErrors:false 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   384
           ignoreWarnings:false 
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   385
!
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   386
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   387
withSelf:anObject parseExpression:aString notifying:someOne ignoreErrors:ignore
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   388
    "parse aString as an expression with self set to anObject;
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   389
     Return the parseTree (if ok), nil (for an empty string 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   390
     or comment only ) or #Error (syntactic error).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   391
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   392
     Errors and warnings are forwarded to someOne (usually some
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   393
     codeView) which can highlight it and show a popup box."
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   394
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   395
    ^ self withSelf:anObject
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   396
           parseExpression:aString 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   397
           notifying:someOne 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   398
           ignoreErrors:ignore 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   399
           ignoreWarnings:ignore 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   400
!
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   401
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   402
withSelf:anObject parseExpression:aString notifying:someOne ignoreErrors:ignoreErrors ignoreWarnings:ignoreWarnings
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   403
    "parse aString as an expression with self set to anObject;
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   404
     Return the parseTree (if ok), nil (for an empty string 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   405
     or comment only ) or #Error (syntactic error).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   406
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   407
     Errors and warnings are forwarded to someOne (usually some
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   408
     codeView) which can highlight it and show a popup box,
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   409
     iff ignoreErrors/ignoreWarnings is true respectively."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   410
7ad01559b262 Initial revision
claus
parents:
diff changeset
   411
    |parser tree|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   412
7ad01559b262 Initial revision
claus
parents:
diff changeset
   413
    aString isNil ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   414
    parser := self for:(ReadStream on:aString).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   415
    parser setSelf:anObject.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   416
    parser notifying:someOne.
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   417
    ignoreErrors ifTrue:[parser ignoreErrors].
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   418
    ignoreWarnings ifTrue:[parser ignoreWarnings].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   419
    parser nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   420
    tree := parser expression.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   421
    (parser errorFlag or:[tree == #Error]) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   422
    ^ tree
7ad01559b262 Initial revision
claus
parents:
diff changeset
   423
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   424
7ad01559b262 Initial revision
claus
parents:
diff changeset
   425
parseMethodSpecification:aString
7ad01559b262 Initial revision
claus
parents:
diff changeset
   426
    "parse a methods selector & arg specification; 
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   427
     Return a parser (if ok), nil (empty) or #Error (syntax).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   428
     The parser can be queried for selector, receiver etc."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   429
7ad01559b262 Initial revision
claus
parents:
diff changeset
   430
    ^ self parseMethodSpecification:aString in:nil
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   431
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   432
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   433
     |p|
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   434
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   435
     p := Parser parseMethodSpecification:'foo:arg1 bar:arg2 baz:arg3'.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   436
     'nArgs: ' print. p numberOfMethodArgs printNL.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   437
     'args:  ' print. p methodArgs printNL.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   438
     'sel:   ' print. p selector printNL
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   439
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   440
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   441
7ad01559b262 Initial revision
claus
parents:
diff changeset
   442
parseMethodSpecification:aString in:aClass
7ad01559b262 Initial revision
claus
parents:
diff changeset
   443
    "parse a methods selector & arg spec for a given class;
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   444
     Return a parser (if ok), nil (empty) or #Error (syntax).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   445
     The parser can be queried for selector, receiver etc."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   446
7ad01559b262 Initial revision
claus
parents:
diff changeset
   447
    |parser tree|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   448
7ad01559b262 Initial revision
claus
parents:
diff changeset
   449
    aString isNil ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   450
    parser := self for:(ReadStream on:aString) in:aClass.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   451
    parser nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   452
    tree := parser parseMethodSpec.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   453
    (parser errorFlag or:[tree == #Error]) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   454
    ^ parser
7ad01559b262 Initial revision
claus
parents:
diff changeset
   455
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   456
7ad01559b262 Initial revision
claus
parents:
diff changeset
   457
parseMethodArgAndVarSpecification:aString
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   458
    "parse a methods selector, arg and var spec (i.e. locals);
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   459
     Return a parser (if ok), nil (empty) or #Error (syntax).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   460
     The parser can be queried for selector, receiver etc."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   461
7ad01559b262 Initial revision
claus
parents:
diff changeset
   462
    ^ self parseMethodArgAndVarSpecification:aString in:nil
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   463
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   464
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   465
     |p|
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   466
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   467
     p := Parser 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   468
             parseMethodArgAndVarSpecification:'
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   469
                      foo:arg1 bar:arg2 baz:arg3 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   470
                      |l1 l2|'.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   471
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   472
     'nArgs:  ' print. p numberOfMethodArgs printNL.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   473
     'args:   ' print. p methodArgs printNL.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   474
     'sel:    ' print. p selector printNL.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   475
     'nLocal: ' print. p numberOfMethodVars printNL.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   476
     'locals: ' print. p methodVars printNL.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   477
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   478
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   479
7ad01559b262 Initial revision
claus
parents:
diff changeset
   480
parseMethodArgAndVarSpecification:aString in:aClass
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   481
    "parse a methods selector, arg and var spec in a given class;
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   482
     Return a parser (if ok), nil (empty) or #Error (syntax).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   483
     The parser can be queried for selector, receiver, args and locals"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   484
7ad01559b262 Initial revision
claus
parents:
diff changeset
   485
    |parser|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   486
7ad01559b262 Initial revision
claus
parents:
diff changeset
   487
    aString isNil ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   488
    parser := self for:(ReadStream on:aString) in:aClass.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   489
    parser nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   490
    (parser parseMethodSpec == #Error) ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   491
    (parser parseMethodBodyVarSpec == #Error) ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   492
    parser errorFlag ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   493
    ^ parser
7ad01559b262 Initial revision
claus
parents:
diff changeset
   494
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   495
7ad01559b262 Initial revision
claus
parents:
diff changeset
   496
parseMethod:aString
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   497
    "parse a method.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   498
     Return a parser (if ok), nil (empty) or #Error (syntax).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   499
     The parser can be queried for selector, receiver, args, locals,
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   500
     used selectors etc."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   501
7ad01559b262 Initial revision
claus
parents:
diff changeset
   502
    ^ self parseMethod:aString in:nil
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   503
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   504
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   505
     |p|
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   506
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   507
     p := Parser 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   508
             parseMethod:'
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   509
                 foo:arg1 bar:arg2 baz:arg3 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   510
                     |l1 l2| 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   511
                     l1 := 0. 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   512
                     l2 := arg1. 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   513
                     ^ self'.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   514
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   515
     'nArgs:  ' print. p numberOfMethodArgs printNL.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   516
     'args:   ' print. p methodArgs printNL.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   517
     'sel:    ' print. p selector printNL.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   518
     'nLocal: ' print. p numberOfMethodVars printNL.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   519
     'locals: ' print. p methodVars printNL.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   520
     'tree:   ' printNL. p tree printAllOn:Stdout. Stdout cr.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   521
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   522
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   523
7ad01559b262 Initial revision
claus
parents:
diff changeset
   524
parseMethod:aString in:aClass
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   525
    "parse a method in a given class.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   526
     Return a parser (if ok), nil (empty) or #Error (syntax).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   527
     The parser can be queried for selector, receiver, args, locals,
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   528
     used selectors, modified instvars, referenced classvars etc."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   529
7ad01559b262 Initial revision
claus
parents:
diff changeset
   530
    |parser tree|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   531
7ad01559b262 Initial revision
claus
parents:
diff changeset
   532
    aString isNil ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   533
    parser := self for:(ReadStream on:aString) in:aClass.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   534
    tree := parser parseMethod.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   535
    (parser errorFlag or:[tree == #Error]) ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   536
    ^ parser
7ad01559b262 Initial revision
claus
parents:
diff changeset
   537
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   538
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   539
!Parser class methodsFor:'unparsing'!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   540
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   541
methodSpecificationForSelector:aSelector
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   542
    "given a selector such as #foo:bar:, return a string that could
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   543
     serve as a methods specification source code.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   544
     To be used for code generators"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   545
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   546
    ^ self methodSpecificationForSelector:aSelector 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   547
                                 argNames:#('arg1' 'arg2' 'arg3' 'arg4' 'arg5' 'arg6'
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   548
                                            'arg7' 'arg8' 'arg9' 'arg10' 'arg11' 'arg12'
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   549
                                            'arg13' 'arg14' 'arg15')
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   550
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   551
     Parser methodSpecificationForSelector:#foo:bar:   
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   552
     Parser methodSpecificationForSelector:#+       
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   553
     Parser methodSpecificationForSelector:#negated   
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   554
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   555
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   556
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   557
methodSpecificationForSelector:aSelector argNames:argNames
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   558
    "given a selector such as #foo:bar:, return a string that could
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   559
     serve as a methods specification source code.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   560
     To be used for code generators"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   561
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   562
    |s nargs parts|
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   563
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   564
    s := WriteStream on:String new.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   565
    nargs := aSelector nArgsIfSelector.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   566
    nargs == 0 ifTrue:[
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   567
        s nextPutAll:aSelector
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   568
    ] ifFalse:[
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   569
        parts := aSelector partsIfSelector.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   570
        1 to:nargs do:[:i |
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   571
            s nextPutAll:(parts at:i); space;
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   572
              nextPutAll:(argNames at:i); space.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   573
        ]
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   574
    ].
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   575
    ^ s contents
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   576
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   577
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   578
     Parser methodSpecificationForSelector:#foo:bar: argNames:#('one' 'two' 'three')  
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   579
     Parser methodSpecificationForSelector:#+ argNames:#('one')  
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   580
     Parser methodSpecificationForSelector:#negated   
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   581
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   582
! !
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   583
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   584
!Parser class methodsFor:'controlling compilation'!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   585
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   586
compileLazy:aBoolean
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   587
    "turn on/off lazy compilation - return previous setting.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   588
     Actually this flag belongs into the ByteCodeCompiler subclass,
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   589
     but it also controls the reporting of some errors here; therefore
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   590
     its located here"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   591
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   592
    |oldLazy|
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   593
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   594
    oldLazy := LazyCompilation.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   595
    LazyCompilation := aBoolean.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   596
    ^ oldLazy
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   597
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   598
    "Compiler compileLazy:false"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   599
! !
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   600
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   601
!Parser methodsFor:'ST-80 compatibility'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   602
7ad01559b262 Initial revision
claus
parents:
diff changeset
   603
evaluate:aString in:aClass to:to notifying:aRequestor ifFail:failBlock
7ad01559b262 Initial revision
claus
parents:
diff changeset
   604
    |parseTree|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   605
7ad01559b262 Initial revision
claus
parents:
diff changeset
   606
    aString isNil ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   607
    self initializeFor:(ReadStream on:aString).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   608
    self setClassToCompileFor:aClass.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   609
    selfValue := nil.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   610
    requestor := aRequestor.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   611
7ad01559b262 Initial revision
claus
parents:
diff changeset
   612
    self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   613
    parseTree := self parseMethodBody.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   614
    (errorFlag or:[tree == #Error]) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   615
    parseTree notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   616
        self evalExitBlock:[:value | ^ failBlock value].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   617
        ^ parseTree evaluate
7ad01559b262 Initial revision
claus
parents:
diff changeset
   618
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   619
    ^ nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
   620
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   621
7ad01559b262 Initial revision
claus
parents:
diff changeset
   622
!Parser class methodsFor:'changes'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   623
7ad01559b262 Initial revision
claus
parents:
diff changeset
   624
update:aClass
7ad01559b262 Initial revision
claus
parents:
diff changeset
   625
    "aClass has changed its definition - flush name caches if we have to"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   626
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   627
    (aClass == PrevClass) ifTrue:[
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   628
        PrevClass := nil.
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   629
        PrevInstVarNames := nil.
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   630
        PrevClassVarNames := nil.
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   631
        PrevClassInstVarNames := nil.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   632
        aClass removeDependent:Parser
7ad01559b262 Initial revision
claus
parents:
diff changeset
   633
    ]
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   634
!
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   635
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   636
flush
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   637
    "unconditional flush name caches"
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   638
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   639
    PrevClass notNil ifTrue:[
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   640
        PrevClass removeDependent:Parser
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   641
    ].
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   642
    PrevClass := nil.
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   643
    PrevInstVarNames := nil.
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   644
    PrevClassVarNames := nil.
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   645
    PrevClassInstVarNames := nil.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   646
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   647
    "Parser flush"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   648
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   649
7ad01559b262 Initial revision
claus
parents:
diff changeset
   650
!Parser methodsFor:'setup'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   651
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   652
initialize
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   653
    super initialize.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   654
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   655
    hasPrimitiveCode := false
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   656
!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   657
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   658
initializeFor:aStringOrStream
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   659
    super initializeFor:aStringOrStream.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   660
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   661
    hasPrimitiveCode := false
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   662
!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   663
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   664
setClassToCompileFor:aClass
7ad01559b262 Initial revision
claus
parents:
diff changeset
   665
    "set the class to be used for parsing/evaluating"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   666
7ad01559b262 Initial revision
claus
parents:
diff changeset
   667
    classToCompileFor := aClass.
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   668
    (classToCompileFor ~~ PrevClass) ifTrue:[
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   669
        PrevClass notNil ifTrue:[
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   670
            Parser update:PrevClass
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   671
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   672
    ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   673
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   674
7ad01559b262 Initial revision
claus
parents:
diff changeset
   675
setSelf:anObject
7ad01559b262 Initial revision
claus
parents:
diff changeset
   676
    "set the value to be used for self while evaluating"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   677
7ad01559b262 Initial revision
claus
parents:
diff changeset
   678
    selfValue := anObject.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   679
    classToCompileFor := anObject class.
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   680
    (classToCompileFor ~~ PrevClass) ifTrue:[
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   681
        PrevClass notNil ifTrue:[
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
   682
            Parser update:PrevClass
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   683
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   684
    ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   685
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   686
7ad01559b262 Initial revision
claus
parents:
diff changeset
   687
setContext:aContext
7ad01559b262 Initial revision
claus
parents:
diff changeset
   688
    "set the context used while evaluating"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   689
7ad01559b262 Initial revision
claus
parents:
diff changeset
   690
    contextToEvaluateIn := aContext
7ad01559b262 Initial revision
claus
parents:
diff changeset
   691
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   692
7ad01559b262 Initial revision
claus
parents:
diff changeset
   693
!Parser methodsFor:'accessing'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   694
7ad01559b262 Initial revision
claus
parents:
diff changeset
   695
tree
7ad01559b262 Initial revision
claus
parents:
diff changeset
   696
    "return the parsetree"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   697
7ad01559b262 Initial revision
claus
parents:
diff changeset
   698
    ^tree
7ad01559b262 Initial revision
claus
parents:
diff changeset
   699
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   700
7ad01559b262 Initial revision
claus
parents:
diff changeset
   701
tree:aTree
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   702
    "private: set the tree - for internal use only"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   703
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   704
    tree := aTree
7ad01559b262 Initial revision
claus
parents:
diff changeset
   705
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   706
7ad01559b262 Initial revision
claus
parents:
diff changeset
   707
selector
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   708
    "return the selector (valid after parsing spec)"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   709
7ad01559b262 Initial revision
claus
parents:
diff changeset
   710
    ^ selector
7ad01559b262 Initial revision
claus
parents:
diff changeset
   711
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   712
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   713
correctedSource
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   714
    ^ correctedSource
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   715
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   716
7ad01559b262 Initial revision
claus
parents:
diff changeset
   717
numberOfMethodArgs
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   718
    "return the number of methodargs (valid after parsing spec)"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   719
7ad01559b262 Initial revision
claus
parents:
diff changeset
   720
    ^ methodArgs size
7ad01559b262 Initial revision
claus
parents:
diff changeset
   721
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   722
7ad01559b262 Initial revision
claus
parents:
diff changeset
   723
methodArgs
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   724
    "return an array with methodarg names (valid after parsing spec)"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   725
7ad01559b262 Initial revision
claus
parents:
diff changeset
   726
    ^ methodArgNames
7ad01559b262 Initial revision
claus
parents:
diff changeset
   727
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   728
7ad01559b262 Initial revision
claus
parents:
diff changeset
   729
numberOfMethodVars
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   730
    "return the number of method variables (valid after parsing)"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   731
7ad01559b262 Initial revision
claus
parents:
diff changeset
   732
    ^ methodVars size
7ad01559b262 Initial revision
claus
parents:
diff changeset
   733
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   734
7ad01559b262 Initial revision
claus
parents:
diff changeset
   735
methodVars
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   736
    "return a collection with method variablenames (valid after parsing)"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   737
7ad01559b262 Initial revision
claus
parents:
diff changeset
   738
    ^ methodVarNames
7ad01559b262 Initial revision
claus
parents:
diff changeset
   739
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   740
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   741
usedVars
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   742
    "return a collection with variablenames refd by method (valid after parsing)"
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   743
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   744
    ^ usedVars
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   745
!
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   746
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   747
usedInstVars
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   748
    "return a collection with instvariablenames refd by method (valid after parsing)"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   749
7ad01559b262 Initial revision
claus
parents:
diff changeset
   750
    ^ usedInstVars
7ad01559b262 Initial revision
claus
parents:
diff changeset
   751
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   752
7ad01559b262 Initial revision
claus
parents:
diff changeset
   753
usedClassVars
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   754
    "return a collection with classvariablenames refd by method (valid after parsing)"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   755
7ad01559b262 Initial revision
claus
parents:
diff changeset
   756
    ^ usedClassVars
7ad01559b262 Initial revision
claus
parents:
diff changeset
   757
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   758
7ad01559b262 Initial revision
claus
parents:
diff changeset
   759
modifiedInstVars
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   760
    "return a collection with instvariablenames modified by method (valid after parsing)"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   761
7ad01559b262 Initial revision
claus
parents:
diff changeset
   762
    ^ modifiedInstVars
7ad01559b262 Initial revision
claus
parents:
diff changeset
   763
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   764
7ad01559b262 Initial revision
claus
parents:
diff changeset
   765
modifiedClassVars
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   766
    "return a collection with classvariablenames modified by method (valid after parsing)"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   767
7ad01559b262 Initial revision
claus
parents:
diff changeset
   768
    ^ modifiedClassVars
7ad01559b262 Initial revision
claus
parents:
diff changeset
   769
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   770
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   771
primitiveNumber
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   772
    "return the ST-80 style primitiveNumber or nil (valid after parsing)"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   773
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   774
    ^ primitiveNr
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   775
!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   776
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   777
hasPrimitiveCode
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   778
    "return true if there was any ST/X style primitive code (valid after parsing)"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   779
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   780
    ^ hasPrimitiveCode
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   781
!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   782
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   783
errorFlag
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   784
    "return true if there where any errors (valid after parsing)"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   785
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   786
    ^ errorFlag
7ad01559b262 Initial revision
claus
parents:
diff changeset
   787
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   788
7ad01559b262 Initial revision
claus
parents:
diff changeset
   789
evalExitBlock:aBlock
7ad01559b262 Initial revision
claus
parents:
diff changeset
   790
    "when evaluating a return expression, this block is evaluated"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   791
7ad01559b262 Initial revision
claus
parents:
diff changeset
   792
    evalExitBlock := aBlock
7ad01559b262 Initial revision
claus
parents:
diff changeset
   793
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   794
7ad01559b262 Initial revision
claus
parents:
diff changeset
   795
!Parser methodsFor:'error handling'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   796
7ad01559b262 Initial revision
claus
parents:
diff changeset
   797
showErrorMessage:aMessage position:pos
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   798
    "redefined since parser can give more detailed info about
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   799
     the class & selector where the error occured."
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   800
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   801
    ignoreErrors ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   802
        Smalltalk silentLoading == true ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   803
            Transcript show:(pos printString).
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   804
            Transcript show:' '.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   805
            selector notNil ifTrue:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   806
                Transcript show:aMessage.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   807
                classToCompileFor notNil ifTrue:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   808
                    Transcript showCr:(' in ' , classToCompileFor name , '>>' , selector)
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   809
                ] ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   810
                    Transcript showCr:(' in ' , selector)
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   811
                ]
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   812
            ] ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   813
                classToCompileFor notNil ifTrue:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   814
                    Transcript showCr:aMessage , ' (' , classToCompileFor name , ')'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   815
                ] ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   816
                    Transcript showCr:aMessage
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   817
                ]
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   818
            ]
11
60691e5007e3 *** empty log message ***
claus
parents: 10
diff changeset
   819
        ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   820
    ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   821
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   822
7ad01559b262 Initial revision
claus
parents:
diff changeset
   823
parseError:aMessage position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   824
    "report a syntax error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   825
7ad01559b262 Initial revision
claus
parents:
diff changeset
   826
    |m|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   827
7ad01559b262 Initial revision
claus
parents:
diff changeset
   828
    errorFlag := true.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   829
    m := ' Error:' , aMessage.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   830
    self notifyError:m position:position to:endPos.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   831
    exitBlock notNil ifTrue:[exitBlock value].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   832
    ^ false
7ad01559b262 Initial revision
claus
parents:
diff changeset
   833
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   834
7ad01559b262 Initial revision
claus
parents:
diff changeset
   835
parseError:aMessage position:position
7ad01559b262 Initial revision
claus
parents:
diff changeset
   836
    "report a syntax error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   837
7ad01559b262 Initial revision
claus
parents:
diff changeset
   838
    ^ self parseError:aMessage position:position to:nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
   839
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   840
7ad01559b262 Initial revision
claus
parents:
diff changeset
   841
parseError:aMessage
7ad01559b262 Initial revision
claus
parents:
diff changeset
   842
    "report a syntax error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   843
7ad01559b262 Initial revision
claus
parents:
diff changeset
   844
    ^ self parseError:aMessage position:tokenPosition to:nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
   845
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   846
7ad01559b262 Initial revision
claus
parents:
diff changeset
   847
correctableError:message position:pos1 to:pos2
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   848
    "report an error which can be corrected by compiler -
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   849
     return true if correction is wanted"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   850
7ad01559b262 Initial revision
claus
parents:
diff changeset
   851
    |correctIt|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   852
7ad01559b262 Initial revision
claus
parents:
diff changeset
   853
    requestor isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   854
        self showErrorMessage:message position:pos1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   855
        correctIt := false
7ad01559b262 Initial revision
claus
parents:
diff changeset
   856
    ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   857
        correctIt := requestor correctableError:message position:pos1 to:pos2
7ad01559b262 Initial revision
claus
parents:
diff changeset
   858
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   859
    correctIt ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   860
        exitBlock notNil ifTrue:[exitBlock value]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   861
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   862
    ^ correctIt
7ad01559b262 Initial revision
claus
parents:
diff changeset
   863
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   864
7ad01559b262 Initial revision
claus
parents:
diff changeset
   865
undefError:aName position:pos1 to:pos2
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   866
    "report an undefined variable error - return true, if it should be
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   867
     corrected"
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   868
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   869
    requestor isNil ifTrue:[
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   870
        warnedUndefVars notNil ifTrue:[
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   871
            (warnedUndefVars includes:aName) ifTrue:[
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   872
                "already warned about this one"
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   873
                ^ false
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   874
            ].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   875
        ].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   876
        self showErrorMessage:('Error: ' , aName , ' is undefined') position:pos1.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   877
        warnedUndefVars isNil ifTrue:[
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   878
            warnedUndefVars := Set new.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   879
        ].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   880
        warnedUndefVars add:aName.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   881
        ^ false
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   882
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   883
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   884
    ^ self correctableError:('Error: ' , aName , ' is undefined') position:pos1 to:pos2
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   885
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   886
7ad01559b262 Initial revision
claus
parents:
diff changeset
   887
exitWith:something
7ad01559b262 Initial revision
claus
parents:
diff changeset
   888
    "this is the longjump out of evaluation via a return expression"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   889
7ad01559b262 Initial revision
claus
parents:
diff changeset
   890
    evalExitBlock value:something
7ad01559b262 Initial revision
claus
parents:
diff changeset
   891
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   892
7ad01559b262 Initial revision
claus
parents:
diff changeset
   893
!Parser methodsFor:'parsing'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   894
7ad01559b262 Initial revision
claus
parents:
diff changeset
   895
parseMethod
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   896
    "parse a method.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   897
     Return the parseTree or #Error.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   898
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   899
     method ::= methodSpec methodBody
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   900
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   901
7ad01559b262 Initial revision
claus
parents:
diff changeset
   902
    |parseTree|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   903
7ad01559b262 Initial revision
claus
parents:
diff changeset
   904
    self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   905
    (self parseMethodSpec == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   906
    parseTree := self parseMethodBody.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   907
    (parseTree == #Error) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   908
        self tree:parseTree
7ad01559b262 Initial revision
claus
parents:
diff changeset
   909
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   910
    ^ parseTree
7ad01559b262 Initial revision
claus
parents:
diff changeset
   911
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   912
7ad01559b262 Initial revision
claus
parents:
diff changeset
   913
parseMethodSpec
7ad01559b262 Initial revision
claus
parents:
diff changeset
   914
    "parse a methods selector & arg specification;
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   915
     Set selector and methodArgs in the receiver as a side effect.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   916
     Return the receiver or #Error.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   917
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   918
     methodSpec ::= { KEYWORD IDENTIFIER }
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   919
                    | binaryOperator IDENTIFIER
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   920
                    | IDENTIFIER
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   921
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   922
7ad01559b262 Initial revision
claus
parents:
diff changeset
   923
    |var|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   924
7ad01559b262 Initial revision
claus
parents:
diff changeset
   925
    (tokenType == #Keyword) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   926
        selector := ''.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   927
        [tokenType == #Keyword] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   928
            selector := selector , tokenName.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   929
            self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   930
            (tokenType ~~ #Identifier) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   931
            var := Variable name:tokenName.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   932
            methodArgs isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   933
                methodArgs := Array with:var.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   934
                methodArgNames := Array with:tokenName
7ad01559b262 Initial revision
claus
parents:
diff changeset
   935
            ] ifFalse:[
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   936
                (methodArgNames includes:tokenName) ifTrue:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   937
                    self syntaxError:'redefinition of ''' , tokenName , ''' in argument list.'
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   938
                            position:tokenPosition 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   939
                                  to:(tokenPosition + tokenName size - 1)
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   940
                ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   941
                methodArgs := methodArgs copyWith:var.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   942
                methodArgNames := methodArgNames copyWith:tokenName
7ad01559b262 Initial revision
claus
parents:
diff changeset
   943
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   944
            self nextToken
7ad01559b262 Initial revision
claus
parents:
diff changeset
   945
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   946
        selector := selector asSymbol.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   947
        ^ self
7ad01559b262 Initial revision
claus
parents:
diff changeset
   948
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   949
    (tokenType == #Identifier) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   950
        selector := tokenName asSymbol.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   951
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   952
        ^ self
7ad01559b262 Initial revision
claus
parents:
diff changeset
   953
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   954
    (tokenType == #BinaryOperator) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   955
        selector := tokenName asSymbol.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   956
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   957
        (tokenType ~~ #Identifier) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   958
        var := Variable name:tokenName.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   959
        methodArgs isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   960
            methodArgs := Array with:var.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   961
            methodArgNames := Array with:tokenName
7ad01559b262 Initial revision
claus
parents:
diff changeset
   962
        ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   963
            methodArgs := methodArgs copyWith:var.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   964
            methodArgNames := methodArgNames copyWith:tokenName
7ad01559b262 Initial revision
claus
parents:
diff changeset
   965
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   966
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   967
        ^ self
7ad01559b262 Initial revision
claus
parents:
diff changeset
   968
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   969
    ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
   970
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   971
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   972
parseMethodBody
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   973
    "parse a methods body (locals & statements). 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   974
     No more tokens may follow.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   975
     Return a node-tree, or #Error
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   976
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   977
     methodBody ::= '<' st80Primitive '>' #EOF
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   978
                    | '<' st80Primitive '>' methodBodyVarSpec statementList #EOF
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   979
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   980
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   981
    |stats|
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   982
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   983
    stats := self parseMethodBodyOrNil.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   984
    (stats == #Error) ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   985
        (tokenType ~~ #EOF) ifTrue:[
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   986
            "/ just for the nicer error message
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   987
            (#(Self Nil True False Super) includes:tokenType) ifTrue:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   988
                self parseError:tokenName , ' unexpected (missing ''.'' before ' , tokenName , ' ?)' 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   989
                       position:tokenPosition to:(tokenPosition + tokenName size - 1)
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   990
            ] ifFalse:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   991
                self parseError:(tokenType printString , ' unexpected').
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   992
            ].
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   993
            ^#Error
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   994
        ]
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   995
    ].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   996
    ^ stats
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   997
!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   998
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   999
parseMethodBodyOrNil
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1000
    "parse a methods body (locals & statements);
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1001
     return  a node-tree, nil or #Error. 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1002
     empty (or comment only) input is accepted and returns nil.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1003
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1004
     methodBodyOrNil ::= '<' st80Primitive '>'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1005
                         | '<' st80Primitive '>' methodBodyVarSpec statementList
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1006
                         | <empty>
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1007
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1008
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1009
    |stats|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1010
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1011
    ((tokenType == #BinaryOperator) and:[tokenName = '<']) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1012
        "an ST-80 primitive - parsed but ignored"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1013
        self nextToken.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1014
        primitiveNr := self parseST80Primitive.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1015
        (primitiveNr == #Error) ifTrue:[^ #Error].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1016
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1017
        self warning:'ST-80 primitives not supported - ignored'
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1018
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1019
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1020
    (self parseMethodBodyVarSpec == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1021
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1022
    (tokenType ~~ #EOF) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1023
        stats := self statementList
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1024
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1025
    ^ stats
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1026
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1027
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1028
parseMethodBodyVarSpec
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1029
    "parse a methods local variable specification. 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1030
     Leave spec of locals in methodLocals as a side effect.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1031
     Return #Error or nil.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1032
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1033
     methodBodyVarSpec ::= '|' { IDENTIFIER } '|'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1034
                            | <empty>
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1035
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1036
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1037
    |var|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1038
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1039
    (tokenType == $|) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1040
        "memorize position for declaration in correction"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1041
        localVarDefPosition := tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1042
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1043
        [tokenType == #Identifier] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1044
            var := Variable name:tokenName.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1045
            methodVars isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1046
                methodVars := Array with:var.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1047
                methodVarNames := Array with:tokenName
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1048
            ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1049
                methodVars := methodVars copyWith:var.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1050
                methodVarNames := methodVarNames copyWith:tokenName
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1051
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1052
            self nextToken
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1053
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1054
        (tokenType ~~ $|) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1055
            self syntaxError:'error in local var specification; | expected.'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1056
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1057
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1058
        self nextToken
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1059
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1060
    ^ nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1061
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1062
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1063
parseST80Primitive
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1064
    "parse an ST-80 type primitive as '< primitive: nr >';
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1065
     return primitive number or #Error.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1066
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1067
     st80Primitive ::= 'primitive:' INTEGER
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1068
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1069
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1070
    |primNumber|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1071
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1072
    ((tokenType == #Keyword) and:[tokenName = 'primitive:']) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1073
        self parseError:'bad primitive definition (primitive: expected)'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1074
        ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1075
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1076
    self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1077
    (tokenType == #Integer) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1078
        self parseError:'primitive number expected'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1079
        ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1080
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1081
    primNumber := tokenValue.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1082
    self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1083
    ((tokenType == #BinaryOperator) and:[tokenName = '>']) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1084
        self parseError:'bad primitive definition (> expected)'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1085
        ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1086
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1087
    self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1088
    ^ primNumber
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1089
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1090
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1091
statementList
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1092
    "parse a statementlist; return a node-tree, nil or #Error.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1093
     Statements must be separated by periods."
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1094
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1095
    |thisStatement prevStatement firstStatement correctIt periodPos|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1096
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1097
    thisStatement := self statement.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1098
    (thisStatement == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1099
    firstStatement := thisStatement.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1100
    [tokenType == $.] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1101
        periodPos := tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1102
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1103
        (tokenType == $]) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1104
            currentBlock isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1105
                self parseError:'block nesting error'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1106
                errorFlag := true
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1107
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1108
            *** I had a warning here (since it was not defined
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1109
            *** in the blue-book; but PD-code contains a lot of
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1110
            *** code with periods at the end so that the warnings
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1111
            *** became annoying
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1112
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1113
            ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1114
                self warning:'period after last statement' position:periodPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1115
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1116
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1117
            ^ firstStatement
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1118
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1119
        (tokenType == #EOF) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1120
            currentBlock notNil ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1121
                self parseError:'block nesting error (expected '']'')'.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1122
                errorFlag := true
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1123
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1124
            *** I had a warning here (since it was not defined
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1125
            *** in the blue-book; but PD-code contains a lot of
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1126
            *** code with periods at the end so that the warnings
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1127
            *** became annoying
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1128
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1129
            ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1130
                self warning:'period after last statement' position:periodPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1131
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1132
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1133
            ^ firstStatement
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1134
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1135
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1136
        prevStatement := thisStatement.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1137
        (prevStatement isKindOf:ReturnNode) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1138
            self warning:'statements after return' position:tokenPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1139
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1140
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1141
        periodPos := tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1142
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1143
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1144
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1145
        ((tokenType == $]) or:[tokenType == #EOF]) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1146
            (currentBlock isNil and:[tokenType == $]]) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1147
                self parseError:'block nesting error'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1148
                errorFlag := true
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1149
            ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1150
                correctIt := self correctableError:'period after last statement in block'
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1151
                                          position:periodPos to:(periodPos + 1).
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1152
                correctIt ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1153
                    (self correctByDeleting == #Error) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1154
                        errorFlag := true
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1155
                    ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1156
                ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1157
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1158
            ^ firstStatement
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1159
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1160
        thisStatement := self statement.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1161
        (thisStatement == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1162
        prevStatement nextStatement:thisStatement
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1163
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1164
    ^ firstStatement
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1165
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1166
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1167
statement
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1168
    "parse a statement; return a node-tree or #Error.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1169
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1170
     statement ::= '^' expression
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1171
                   | PRIMITIVECODE
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1172
                   | expression
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1173
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1174
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1175
    |expr node|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1176
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1177
    (tokenType == $^) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1178
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1179
        expr := self expression.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1180
        (expr == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1181
        node := ReturnNode expression:expr.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1182
        node home:self blockHome:currentBlock.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1183
        ^ node
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1184
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1185
    (tokenType == #Primitive) ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1186
"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1187
        self parseError:'cannot compile primitives (yet)'.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1188
"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1189
        self nextToken.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1190
        hasPrimitiveCode := true.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1191
        ^ PrimitiveNode code:''
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1192
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1193
    (tokenType == #EOF) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1194
        self syntaxError:'period after last statement'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1195
        ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1196
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1197
    expr := self expression.
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1198
    (expr == #Error) ifTrue:[^ #Error].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1199
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1200
    classToCompileFor notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1201
        currentBlock isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1202
            (expr isKindOf:PrimaryNode) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1203
                self warning:'useless computation - missing ^ ?'
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1204
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1205
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1206
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1207
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1208
    ^ StatementNode expression:expr
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1209
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1210
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1211
expression
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1212
    "parse a cascade-expression; return a node-tree, nil or #Error.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1213
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1214
     expression ::= keywordExpression
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1215
                    | keywordExpression cascade
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1216
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1217
     cascade ::= ';' expressionSendPart
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1218
                 | cascade ';' expressionSendPart
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1219
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1220
     expressionSendPart ::= { KEYWORD binaryExpression }
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1221
                            | BINARYOPERATOR unaryExpression
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1222
                            | IDENTIFIER
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1223
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1224
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1225
    |receiver arg sel args pos pos2 lno|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1226
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1227
    pos := tokenPosition.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1228
    receiver := self keywordExpression.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1229
    (receiver == #Error) ifTrue:[^ #Error].
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1230
    (tokenType == $;) ifTrue:[
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1231
        [tokenType == $;] whileTrue:[
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1232
            receiver isMessage ifFalse:[
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1233
                self syntaxError:'left side of cascade must be a message expression'
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1234
                        position:pos to:tokenPosition
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1235
            ].
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1236
            self nextToken.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1237
            (tokenType == #Identifier) ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1238
                sel := self selectorCheck:tokenName for:receiver position:tokenPosition to:(tokenPosition + tokenName size - 1).
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1239
                receiver := CascadeNode receiver:receiver selector:sel.
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1240
                receiver lineNumber:tokenLineNr.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1241
                self nextToken.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1242
            ] ifFalse:[
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1243
                (tokenType == #BinaryOperator) ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1244
                    sel := self selectorCheck:tokenName for:receiver position:tokenPosition to:(tokenPosition + tokenName size - 1).
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1245
                    lno := tokenLineNr. 
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1246
                    self nextToken.
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1247
                    arg := self unaryExpression.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1248
                    (arg == #Error) ifTrue:[^ #Error].
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1249
                    receiver := CascadeNode receiver:receiver selector:sel arg:arg.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1250
                    receiver lineNumber:lno.
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1251
                ] ifFalse:[
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1252
                    (tokenType == #Keyword) ifTrue:[
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1253
                        pos := tokenPosition. 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1254
                        lno := tokenLineNr. 
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1255
                        sel := tokenName.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1256
                        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1257
                        arg := self binaryExpression.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1258
                        (arg == #Error) ifTrue:[^ #Error].
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1259
                        args := Array with:arg.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1260
                        [tokenType == #Keyword] whileTrue:[
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1261
                            sel := sel , tokenName.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1262
                            self nextToken.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1263
                            arg := self binaryExpression.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1264
                            (arg == #Error) ifTrue:[^ #Error].
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1265
                            args := args copyWith:arg.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1266
                            pos2 := tokenPosition
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1267
                        ].
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1268
                        sel := self selectorCheck:sel for:receiver position:pos to:pos2.
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1269
                        receiver := CascadeNode receiver:receiver selector:sel args:args.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1270
                        receiver lineNumber:lno.
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1271
                    ] ifFalse:[
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1272
                        (tokenType == #Error) ifTrue:[^ #Error].
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1273
                        self syntaxError:('invalid cascade; ' , tokenType printString , ' unexpected')
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1274
                                position:tokenPosition to:source position - 1.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1275
                        ^ #Error
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1276
                    ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1277
                ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1278
            ]
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1279
        ].
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1280
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1281
        "obscure (uspecified ?) if selector follows; Question:
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1282
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1283
        is
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1284
                'expr sel1; sel2 sel3'
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1285
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1286
        to be parsed as: 
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1287
                (t := expr.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1288
                 t sel1.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1289
                 t sel2) sel3
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1290
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1291
         or:
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1292
                (t := expr.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1293
                 t sel1.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1294
                 t sel2 sel3)
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1295
        "
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1296
        ((tokenType == #Identifier) 
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1297
         or:[(tokenType == #BinaryOperator)
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1298
             or:[tokenType == #Keyword]]) ifTrue:[
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1299
            self syntaxError:'ambigous cascade - please group using ( ...)'
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1300
                    position:tokenPosition to:source position - 1.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1301
            ^ #Error
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1302
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1303
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1304
    ^ receiver
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1305
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1306
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1307
keywordExpression
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1308
    "parse a keyword-expression; return a node-tree, nil or #Error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1309
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1310
    |receiver sel arg args pos1 pos2 try lno note|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1311
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1312
    receiver := self binaryExpression.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1313
    (receiver == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1314
    (tokenType == #Keyword) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1315
        pos1 := tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1316
        sel := tokenName.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1317
        lno := tokenLineNr.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1318
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1319
        arg := self binaryExpression.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1320
        (arg == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1321
        args := Array with:arg.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1322
        [tokenType == #Keyword] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1323
            sel := sel , tokenName.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1324
            self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1325
            arg := self binaryExpression.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1326
            (arg == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1327
            args := args copyWith:arg.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1328
            pos2 := tokenPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1329
        ].
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1330
        sel := self selectorCheck:sel for:receiver position:pos1 to:pos2.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1331
        try := MessageNode receiver:receiver selector:sel args:args.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1332
        (try isMemberOf:String) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1333
            self parseError:try position:pos1 to:pos2.
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1334
            receiver := MessageNode receiver:receiver selector:sel args:args fold:false.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1335
            note := receiver plausibilityCheck.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1336
            note notNil ifTrue:[
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1337
                self warning:note position:pos1 to:pos2
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1338
            ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1339
        ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1340
            receiver := try
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1341
        ].
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1342
        receiver lineNumber:lno
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1343
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1344
    ^ receiver
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1345
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1346
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1347
degeneratedKeywordExpressionForSelector
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1348
    "parse a keyword-expression without receiver - for the selector
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1349
     only. return the selector or nil"
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1350
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1351
    |sel arg|
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1352
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1353
    (tokenType == #Keyword) ifTrue:[
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1354
        sel := tokenName.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1355
        self nextToken.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1356
        arg := self binaryExpression.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1357
        (arg == #Error) ifTrue:[^ sel].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1358
        [tokenType == #Keyword] whileTrue:[
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1359
            sel := sel , tokenName.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1360
            self nextToken.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1361
            arg := self binaryExpression.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1362
            (arg == #Error) ifTrue:[^ sel].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1363
        ].
9
a855c33612fb *** empty log message ***
claus
parents: 7
diff changeset
  1364
        ^ sel
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1365
    ].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1366
    ^ nil
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1367
!
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1368
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1369
binaryExpression
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1370
    "parse a binary-expression; return a node-tree, nil or #Error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1371
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1372
    |receiver arg sel pos try lno note|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1373
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1374
    receiver := self unaryExpression.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1375
    (receiver == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1376
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1377
    "special kludge: since Scanner cannot know if -digit is a binary
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1378
     expression or a negative constant, handle cases here"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1379
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1380
    [(tokenType == #BinaryOperator) or:[(tokenType == $|)
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1381
     or:[(tokenType == #Integer) and:[tokenValue < 0]]]] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1382
        pos := tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1383
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1384
        lno := tokenLineNr.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1385
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1386
        "kludge here: bar and minus are not scanned as binop "
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1387
        (tokenType == $|) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1388
            sel := '|'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1389
            self nextToken
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1390
        ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1391
            (tokenType == #BinaryOperator) ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1392
                sel := self selectorCheck:tokenName for:receiver position:tokenPosition to:(tokenPosition + tokenName size - 1).
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1393
                self nextToken
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1394
            ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1395
                sel := '-'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1396
                tokenValue := tokenValue negated
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1397
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1398
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1399
        arg := self unaryExpression.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1400
        (arg == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1401
        try := BinaryNode receiver:receiver selector:sel arg:arg.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1402
        (try isMemberOf:String) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1403
            self parseError:try position:pos to:tokenPosition.
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1404
            receiver := BinaryNode receiver:receiver selector:sel arg:arg fold:false.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1405
            note := receiver plausibilityCheck.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1406
            note notNil ifTrue:[
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1407
                self warning:note position:pos to:tokenPosition
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1408
            ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1409
        ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1410
            receiver := try
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1411
        ].
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1412
        receiver lineNumber:lno.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1413
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1414
    ^ receiver
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1415
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1416
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1417
unaryExpression
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1418
    "parse a unary-expression; return a node-tree, nil or #Error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1419
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1420
    |receiver sel pos pos2 try|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1421
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1422
    receiver := self primary.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1423
    (receiver == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1424
    [tokenType == #Identifier] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1425
        pos := tokenPosition.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1426
        pos2 := pos + tokenName size - 1.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1427
        sel := self selectorCheck:tokenName for:receiver position:pos to:pos2.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1428
        try := UnaryNode receiver:receiver selector:sel.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1429
        (try isMemberOf:String) ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1430
            self warning:try position:pos to:pos2.
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1431
            receiver := UnaryNode receiver:receiver selector:sel fold:false.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1432
        ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1433
            receiver := try
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1434
        ].
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1435
        receiver lineNumber:tokenLineNr.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1436
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1437
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1438
    ^ receiver
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1439
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1440
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1441
primary
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1442
    "parse a primary-expression; return a node-tree, nil or #Error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1443
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1444
    |val var expr pos name|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1445
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1446
    pos := tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1447
    (tokenType == #Identifier) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1448
        var := self variable.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1449
        (var == #Error) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1450
            errorFlag := true
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1451
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1452
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1453
        (tokenType == $_) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1454
            ^ var
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1455
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1456
        (var ~~ #Error) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1457
            (var type == #MethodArg) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1458
                self parseError:'assignment to method argument' position:pos to:tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1459
                errorFlag := true
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1460
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1461
            (var type == #BlockArg) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1462
                self parseError:'assignment to block argument' position:pos to:tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1463
                errorFlag := true
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1464
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1465
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1466
            (var type == #InstanceVariable) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1467
                modifiedInstVars isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1468
                    modifiedInstVars := OrderedCollection new
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1469
                ].
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1470
                name := PrevInstVarNames at:(var index).
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1471
                (modifiedInstVars includes:name) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1472
                    modifiedInstVars add:name
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1473
                ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1474
            ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1475
                (var type == #ClassVariable) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1476
                    modifiedClassVars isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1477
                        modifiedClassVars := OrderedCollection new
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1478
                    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1479
                    name := var name.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1480
                    name := name copyFrom:((name indexOf:$:) + 1).
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1481
                    (modifiedClassVars includes:name) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1482
                        modifiedClassVars add:name
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1483
                    ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1484
                ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1485
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1486
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1487
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1488
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1489
        expr := self expression.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1490
        (errorFlag or:[expr == #Error]) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1491
        ^ AssignmentNode variable:var expression:expr
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1492
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1493
    ((tokenType == #Integer) or:
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1494
     [(tokenType == #Character) or:
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1495
      [tokenType == #Float]]) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1496
        val := ConstantNode type:tokenType value:tokenValue.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1497
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1498
        (tokenType == $_) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1499
            self parseError:'assignment to a constant' position:pos to:tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1500
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1501
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1502
        ^ val
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1503
    ].
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1504
    (tokenType == #Self) ifTrue:[
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1505
        self nextToken.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1506
        (tokenType == $_) ifTrue:[
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1507
            self parseError:'assignment to self' position:pos to:tokenPosition.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1508
            ^ #Error
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1509
        ].
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1510
        selfNode isNil ifTrue:[
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1511
            selfNode := SelfNode value:selfValue
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1512
        ].
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1513
        ^ selfNode
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1514
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1515
    (tokenType == #String) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1516
        val := ConstantNode type:tokenType value:tokenValue.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1517
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1518
        (tokenType == $_) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1519
            self parseError:'assignment to a constant' position:pos to:tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1520
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1521
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1522
        ^ val
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1523
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1524
    (tokenType == #Symbol) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1525
        val := ConstantNode type:tokenType value:tokenValue.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1526
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1527
        (tokenType == $_) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1528
            self parseError:'assignment to a constant' position:pos to:tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1529
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1530
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1531
        ^ val
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1532
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1533
    (tokenType == #Nil) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1534
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1535
        (tokenType == $_) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1536
            self parseError:'assignment to nil' position:pos to:tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1537
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1538
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1539
        ^ ConstantNode type:#Nil value:nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1540
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1541
    (tokenType == #True) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1542
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1543
        (tokenType == $_) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1544
            self parseError:'assignment to true' position:pos to:tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1545
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1546
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1547
        ^ ConstantNode type:#True value:true
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1548
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1549
    (tokenType == #False) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1550
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1551
        (tokenType == $_) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1552
            self parseError:'assignment to false' position:pos to:tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1553
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1554
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1555
        ^ ConstantNode type:#False value:false
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1556
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1557
    (tokenType  == #Super) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1558
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1559
        (tokenType == $_) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1560
            self parseError:'assignment to super' position:pos to:tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1561
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1562
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1563
        superNode isNil ifTrue:[
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1564
            superNode := SuperNode value:selfValue inClass:classToCompileFor
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1565
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1566
        ^ superNode
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1567
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1568
    (tokenType == #ThisContext) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1569
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1570
        (tokenType == $_) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1571
            self parseError:'assignment to thisContext' position:pos to:tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1572
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1573
        ].
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1574
        ^ VariableNode type:#ThisContext
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1575
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1576
    (tokenType == #HashLeftParen) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1577
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1578
        val := self array.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1579
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1580
        ^ ConstantNode type:#Array value:val
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1581
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1582
    (tokenType == #HashLeftBrack) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1583
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1584
        val := self byteArray.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1585
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1586
        ^ ConstantNode type:#Array value:val
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1587
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1588
    (tokenType == $() ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1589
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1590
        val := self expression.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1591
        (val == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1592
        (tokenType ~~ $) ) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1593
            (tokenType isMemberOf:Character) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1594
                self syntaxError:'missing '')'' (i.e. ''' , tokenType asString , ''' unexpected)' withCRs position:pos to:tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1595
            ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1596
                self syntaxError:'missing '')''' position:pos to:tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1597
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1598
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1599
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1600
        self nextToken.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1601
        val parenthized:true.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1602
        ^ val
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1603
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1604
    (tokenType == $[ ) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1605
        val := self block.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1606
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1607
        ^ val
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1608
    ].
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1609
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1610
    (tokenType == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1611
    (tokenType isKindOf:Character) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1612
        self syntaxError:('error in primary; ' 
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1613
                           , tokenType printString , 
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1614
                           ' unexpected') position:tokenPosition to:tokenPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1615
    ] ifFalse:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1616
        (#(BinaryOperator Keyword) includes:tokenType) ifTrue:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1617
            self syntaxError:('error in primary; ' 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1618
                               , tokenType printString , '(' , tokenName , ') ' ,
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1619
                               ' unexpected')
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1620
        ] ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1621
            self syntaxError:('error in primary; ' 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1622
                               , tokenType printString ,
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1623
                               ' unexpected') 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1624
        ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1625
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1626
    ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1627
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1628
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1629
variableOrError
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1630
    "parse a variable; return a node-tree, nil or #Error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1631
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1632
    ^ self variableOrError:tokenName
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1633
!
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1634
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1635
variableOrError:varName
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1636
    "parse a variable; return a node-tree, nil or #Error"
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1637
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1638
    |var instIndex aClass searchBlock args vars
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1639
     tokenSymbol className|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1640
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1641
    "is it a block-arg or block-var ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1642
    searchBlock := currentBlock.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1643
    [searchBlock notNil] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1644
        args := searchBlock arguments.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1645
        args notNil ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1646
            instIndex := args findFirst:[:aBlockArg | aBlockArg name = varName].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1647
            instIndex ~~ 0 ifTrue:[
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1648
                ^ VariableNode type:#BlockArg
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1649
                               name:varName
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1650
                              token:(args at:instIndex)
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1651
                              index:instIndex
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1652
                              block:searchBlock
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1653
            ].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1654
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1655
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1656
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1657
        vars := searchBlock variables.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1658
        vars notNil ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1659
            instIndex := vars findFirst:[:aBlockVar | aBlockVar name = varName].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1660
            instIndex ~~ 0 ifTrue:[
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1661
                ^ VariableNode type:#BlockVariable
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1662
                               name:varName
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1663
                              token:(vars at:instIndex)
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1664
                              index:instIndex
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1665
                              block:searchBlock
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1666
            ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1667
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1668
        searchBlock := searchBlock home
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1669
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1670
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1671
    "is it a method-variable ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1672
    methodVars notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1673
        instIndex := methodVarNames indexOf:varName.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1674
        instIndex ~~ 0 ifTrue:[
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1675
            var := methodVars at:instIndex.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1676
            var used:true.
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1677
            ^ VariableNode type:#MethodVariable
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1678
                           name:varName
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1679
                          token:var
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1680
                          index:instIndex
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1681
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1682
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1683
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1684
    "is it a method-argument ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1685
    methodArgs notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1686
        instIndex := methodArgNames indexOf:varName.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1687
        instIndex ~~ 0 ifTrue:[
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1688
            ^ VariableNode type:#MethodArg
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1689
                           name:varName
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1690
                          token:(methodArgs at:instIndex)
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1691
                          index:instIndex
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1692
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1693
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1694
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1695
    "is it an instance-variable ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1696
    classToCompileFor notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1697
        "caching allInstVarNames for next compilation saves time ..."
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1698
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1699
        (PrevInstVarNames isNil or:[PrevClass ~~ classToCompileFor]) ifTrue:[
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1700
            PrevClass notNil ifTrue:[
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1701
                PrevClass removeDependent:Parser
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1702
            ].
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1703
            PrevClass := classToCompileFor.
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1704
            PrevInstVarNames := classToCompileFor allInstVarNames.
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1705
            PrevClassInstVarNames := nil.
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1706
            PrevClassVarNames := nil.
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1707
            PrevClass addDependent:Parser
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1708
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1709
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1710
        instIndex := PrevInstVarNames indexOf:varName startingAt:1.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1711
        instIndex ~~ 0 ifTrue:[
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1712
            usedInstVars isNil ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1713
                usedInstVars := OrderedCollection with:varName
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1714
            ] ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1715
                (usedInstVars includes:varName) ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1716
                    usedInstVars add:varName
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1717
                ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1718
            ].
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1719
            usedVars isNil ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1720
                usedVars := OrderedCollection with:varName
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1721
            ] ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1722
                (usedVars includes:varName) ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1723
                    usedVars add:varName
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1724
                ]
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1725
            ].
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1726
            ^ VariableNode type:#InstanceVariable 
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1727
                           name:varName
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1728
                          index:instIndex
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1729
                      selfValue:selfValue
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1730
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1731
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1732
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1733
    "is it a class-instance-variable ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1734
    classToCompileFor notNil ifTrue:[
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1735
        PrevClassInstVarNames isNil ifTrue:[
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1736
            PrevClassInstVarNames := classToCompileFor class allInstVarNames
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1737
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1738
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1739
        instIndex := PrevClassInstVarNames indexOf:varName startingAt:1.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1740
        instIndex ~~ 0 ifTrue:[
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1741
            aClass := self inWhichClassIsClassInstVar:varName.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1742
            aClass notNil ifTrue:[
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1743
                usedVars isNil ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1744
                    usedVars := OrderedCollection with:varName
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1745
                ] ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1746
                    (usedVars includes:varName) ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1747
                        usedVars add:varName
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1748
                    ]
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1749
                ].
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1750
                ^ VariableNode type:#ClassInstanceVariable
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1751
                               name:varName
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1752
                              index:instIndex
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1753
                          selfClass:aClass
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1754
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1755
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1756
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1757
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1758
    "is it a class-variable ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1759
    classToCompileFor notNil ifTrue:[
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1760
        PrevClassVarNames isNil ifTrue:[
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1761
            aClass := classToCompileFor.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1762
            classToCompileFor isMeta ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1763
                className := aClass name.
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1764
                className := className copyTo:(className size - 5).
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1765
                aClass := Smalltalk at:(className asSymbol).
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1766
                aClass isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1767
                    aClass := classToCompileFor
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1768
                ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1769
            ].
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1770
            PrevClassVarNames := aClass allClassVarNames
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1771
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1772
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  1773
        instIndex := PrevClassVarNames indexOf:varName startingAt:1.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1774
        instIndex ~~ 0 ifTrue:[
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1775
            aClass := self inWhichClassIsClassVar:varName.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1776
            aClass notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1777
                usedClassVars isNil ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1778
                    usedClassVars := OrderedCollection with:varName
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1779
                ] ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1780
                    (usedClassVars includes:varName) ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1781
                        usedClassVars add:varName
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1782
                    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1783
                ].
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1784
                usedVars isNil ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1785
                    usedVars := OrderedCollection with:varName
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1786
                ] ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1787
                    (usedVars includes:varName) ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1788
                        usedVars add:varName
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1789
                    ].
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1790
                ].
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1791
                ^ VariableNode type:#ClassVariable 
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1792
                               name:(aClass name , ':' , varName) asSymbol
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1793
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1794
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1795
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1796
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1797
    "is it a global-variable ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1798
    tokenSymbol := varName asSymbol.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1799
    (Smalltalk includesKey:tokenSymbol) ifTrue:[
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1800
        usedVars isNil ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1801
            usedVars := OrderedCollection with:varName
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1802
        ] ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1803
            (usedVars includes:varName) ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1804
                usedVars add:varName
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1805
            ]
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1806
        ].
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1807
        ^ VariableNode type:#GlobalVariable name:tokenSymbol
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1808
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1809
    ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1810
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1811
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1812
variable
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1813
    "parse a variable; if undefined, notify error and correct if user wants to"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1814
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1815
    |v|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1816
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1817
    v := self variableOrError.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1818
    (v == #Error) ifFalse:[^ v].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1819
    v := self correctVariable.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1820
    (v == #Error) ifFalse:[^ v].
13
30e69e21d1d1 *** empty log message ***
claus
parents: 11
diff changeset
  1821
    ^ VariableNode type:#GlobalVariable name:tokenName asSymbol
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1822
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1823
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1824
inWhichClassIsClassVar:aString
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1825
    "search class-chain for the classvariable named aString
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1826
     - return the class or nil if not found"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1827
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1828
    |aClass className baseClass|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1829
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1830
    aClass := classToCompileFor.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1831
    aClass isMeta ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1832
        className := aClass name.
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  1833
        className := className copyTo:(className size - 5).
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1834
        baseClass := Smalltalk at:(className asSymbol).
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1835
        baseClass notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1836
            aClass := baseClass
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1837
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1838
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1839
    [aClass notNil] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1840
        (aClass classVarNames includes:aString) ifTrue:[ ^ aClass].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1841
        aClass := aClass superclass
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1842
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1843
    ^ nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1844
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1845
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1846
inWhichClassIsClassInstVar:aString
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1847
    "search class-chain for the class-instance variable named aString
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1848
     - return the class or nil if not found"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1849
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1850
    |aClass|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1851
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1852
    aClass := classToCompileFor.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1853
    [aClass notNil] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1854
        (aClass class instVarNames includes:aString) ifTrue:[ ^ aClass].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1855
        aClass := aClass superclass
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1856
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1857
    ^ nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1858
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1859
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1860
block
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1861
    "parse a block; return a node-tree, nil or #Error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1862
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1863
    |stats node args argNames var vars pos lno b|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1864
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1865
    lno := tokenLineNr.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1866
    self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1867
    (tokenType == $: ) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1868
        [tokenType == $:] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1869
            pos := tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1870
            self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1871
            (tokenType == #Identifier) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1872
                self syntaxError:'Identifier expected in block-arg declaration'
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1873
                        position:pos to:tokenPosition-1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1874
                ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1875
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1876
            var := Variable name:tokenName.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1877
            args isNil ifTrue:[
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1878
                args := Array with:var.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1879
                argNames := Array with:tokenName.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1880
            ] ifFalse:[
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1881
                (argNames includes:tokenName) ifTrue:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1882
                    self syntaxError:'redefinition of ''' , tokenName , ''' in argument list.'
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1883
                            position:tokenPosition 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1884
                                   to:(tokenPosition + tokenName size - 1)
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1885
                ].
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1886
                args := args copyWith:var.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1887
                argNames := argNames copyWith:tokenName.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1888
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1889
            self nextToken
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1890
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1891
        (tokenType ~~ $| ) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1892
            "ST-80 allows [:arg ]"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1893
            (tokenType == $] ) ifTrue:[
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1894
                b := BlockNode arguments:args home:currentBlock variables:nil.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1895
                b lineNumber:lno.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1896
                ^ b
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1897
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1898
            self syntaxError:'| expected after block-arg declaration'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1899
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1900
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1901
        self nextToken
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1902
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1903
    (tokenType == $| ) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1904
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1905
        pos := tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1906
        [tokenType == $|] whileFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1907
            (tokenType == #Identifier) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1908
                self syntaxError:'Identifier expected in block-var declaration' position:pos.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1909
                ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1910
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1911
            var := Variable name:tokenName.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1912
            vars isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1913
                vars := Array with:var
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1914
            ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1915
                vars := vars copyWith:var
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1916
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1917
            self nextToken
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1918
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1919
        self nextToken
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1920
    ].
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1921
    node := BlockNode arguments:args home:currentBlock variables:vars.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1922
    node lineNumber:lno.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1923
    currentBlock := node.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1924
    stats := self blockStatementList.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1925
    node statements:stats.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1926
    currentBlock := node home.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1927
    (stats == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1928
    ^ node
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1929
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1930
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1931
blockStatementList
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1932
    "parse a blocks statementlist; return a node-tree, nil or #Error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1933
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1934
    |thisStatement prevStatement firstStatement|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1935
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1936
    (tokenType == $] ) ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1937
    thisStatement := self statement.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1938
    (thisStatement == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1939
    firstStatement := thisStatement.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1940
    [tokenType == $] ] whileFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1941
        (tokenType == $.) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1942
            (tokenType == #EOF) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1943
                self syntaxError:'missing '']'' in block'
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1944
            ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1945
                self syntaxError:'missing ''.'' in block'
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1946
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1947
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1948
        ] ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1949
            prevStatement := thisStatement.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1950
            self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1951
            tokenType == $] ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1952
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1953
                *** I had a warning here (since it was not defined
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1954
                *** in the blue-book; but PD-code contains a lot of
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1955
                *** code with periods at the end so that the warnings
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1956
                *** became annoying
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1957
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1958
                self warning:'period after last statement in block'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1959
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1960
                ^ firstStatement
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1961
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1962
            thisStatement := self statement.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1963
            (thisStatement == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1964
            prevStatement nextStatement:thisStatement
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1965
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1966
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1967
    ^ firstStatement
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1968
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1969
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1970
array
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1971
    |arr elem pos1|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1972
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1973
    pos1 := tokenPosition.
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1974
    arr := OrderedCollection new:20.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1975
    [tokenType ~~ $) ] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1976
        elem := self arrayConstant.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1977
        (elem == #Error) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1978
            (tokenType == #EOF) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1979
                self syntaxError:'unterminated array-constant; '')'' expected' 
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1980
                        position:pos1 to:tokenPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1981
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1982
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1983
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1984
        arr add:elem.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1985
        self nextToken
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1986
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1987
    ^ Array withAll:arr
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1988
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1989
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1990
byteArray
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1991
    "started with ST-80 R4 - allow byteArray constants as #[ ... ]"
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1992
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1993
    |arr elem pos1 pos2|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1994
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1995
    pos1 := tokenPosition.
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1996
    arr := OrderedCollection new:50.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1997
    [tokenType ~~ $] ] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1998
        pos2 := tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1999
        elem := self arrayConstant.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2000
        (elem == #Error) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2001
            (tokenType == #EOF) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2002
                self syntaxError:'unterminated bytearray-constant; '']'' expected' 
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2003
                        position:pos1 to:tokenPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2004
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2005
            ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2006
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2007
        ((elem isMemberOf:SmallInteger) and:
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2008
        [(elem >= 0) and:[elem <= 255]]) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2009
            arr add:elem
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2010
        ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2011
            self parseError:'invalid ByteArray element' position:pos2 to:tokenPosition - 1
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2012
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2013
        self nextToken
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2014
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2015
    ^ ByteArray withAll:arr
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2016
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2017
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2018
arrayConstant
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2019
    (tokenType == #String) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2020
        ^ tokenValue
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2021
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2022
    (tokenType == #Nil) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2023
        ^ nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2024
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2025
    (tokenType == #Integer) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2026
        ^ tokenValue
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2027
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2028
    (tokenType == #Character) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2029
        ^ tokenValue
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2030
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2031
    (tokenType == #Float) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2032
        ^ tokenValue
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2033
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2034
    (tokenType == #True) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2035
        ^ true
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2036
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2037
    (tokenType == #False) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2038
        ^ false
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2039
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2040
    (tokenType == #Error) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2041
        ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2042
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2043
    (tokenType == #BinaryOperator) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2044
        ^ tokenName asSymbol
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2045
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2046
    (tokenType == #Keyword) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2047
        ^ tokenName asSymbol
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2048
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2049
    (tokenType == #Identifier) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2050
        ^ tokenName asSymbol
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2051
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2052
    (tokenType == $() ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2053
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2054
        ^ self array
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2055
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2056
    (tokenType == $[) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2057
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2058
        ^ self byteArray
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2059
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2060
    (tokenType == #Symbol) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2061
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2062
        self warning:'no # for symbols within array-constants'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2063
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2064
        ^ tokenValue
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2065
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2066
    (tokenType == #HashLeftParen) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2067
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2068
        self warning:'no # for arrays within array-constants'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2069
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2070
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2071
        ^ self array
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2072
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2073
    (tokenType == #HashLeftBrack) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2074
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2075
        self warning:'no # for arrays within array-constants'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2076
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2077
        self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2078
        ^ self byteArray
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2079
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2080
    (tokenType == #EOF) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2081
        "just for the better error-hilight; let caller handle error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2082
        ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2083
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2084
    self syntaxError:('error in array-constant; ' 
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2085
                      , tokenType printString 
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2086
                      , ' unexpected').
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2087
    ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2088
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2089
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2090
!Parser methodsFor:'error correction'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2091
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2092
correctByDeleting
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2093
    "correct (by deleting token) if user wants to;
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2094
     return #Error if there was no correction;
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2095
     nil if there was one." 
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2096
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2097
    (self confirm:'confirm deleting') ifFalse:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2098
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2099
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2100
     tell requestor (i.e. CodeView) about the change
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2101
     this will update what the requestor shows.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2102
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2103
    requestor deleteSelection.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2104
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2105
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2106
     get the updated source-string 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2107
     which is needed, when we eventually install the new method
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2108
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2109
    correctedSource := requestor currentSourceCode.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2110
    ^ nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2111
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2112
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2113
findBestVariablesFor:aString
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2114
    "collect known variables with their spelling distances to aString;
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2115
     return the 10 best suggestions"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2116
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2117
    |names dists searchBlock args vars globalVarName aClass className baseClass n|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2118
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2119
    names := OrderedCollection new.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2120
    dists := OrderedCollection new.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2121
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2122
    "block arguments"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2123
    searchBlock := currentBlock.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2124
    [searchBlock notNil] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2125
        args := searchBlock arguments.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2126
        args notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2127
            args do:[:aBlockArg |
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2128
                names add:(aBlockArg name).
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2129
                dists add:(aString spellAgainst: "levenshteinTo:"(aBlockArg name))
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2130
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2131
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2132
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2133
        vars := searchBlock variables.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2134
        vars notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2135
            vars do:[:aBlockVar |
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2136
                names add:(aBlockVar name).
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2137
                dists add:(aString spellAgainst: "levenshteinTo:"(aBlockVar name))
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2138
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2139
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2140
        searchBlock := searchBlock home
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2141
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2142
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2143
    "method-variables"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2144
    methodVars notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2145
        methodVarNames do:[:methodVarName |
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2146
            names add:methodVarName.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2147
            dists add:(aString spellAgainst: "levenshteinTo:"methodVarName)
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2148
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2149
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2150
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2151
    "method-arguments"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2152
    methodArgs notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2153
        methodArgNames do:[:methodArgName |
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2154
            names add:methodArgName.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2155
            dists add:(aString spellAgainst: "levenshteinTo:"methodArgName)
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2156
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2157
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2158
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2159
    "instance-variables"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2160
    classToCompileFor notNil ifTrue:[
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  2161
        PrevInstVarNames do:[:instVarName |
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2162
            names add:instVarName.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2163
            dists add:(aString spellAgainst: "levenshteinTo:"instVarName)
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2164
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2165
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2166
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2167
    "class-variables"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2168
    classToCompileFor notNil ifTrue:[
10
73e97b6175c4 *** empty log message ***
claus
parents: 9
diff changeset
  2169
        PrevClassVarNames do:[:classVarName |
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2170
            names add:classVarName.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2171
            dists add:(aString spellAgainst: "levenshteinTo:"classVarName)
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2172
        ].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2173
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2174
false ifTrue:[
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2175
        aClass := classToCompileFor.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2176
        aClass isMeta ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2177
            className := aClass name.
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2178
            className := className copyTo:(className size - 5).
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2179
            baseClass := Smalltalk at:(className asSymbol).
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2180
            baseClass notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2181
                aClass := baseClass
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2182
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2183
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2184
        [aClass notNil] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2185
            (aClass classVarNames) do:[:classVarName |
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2186
                names add:classVarName.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2187
                dists add:(aString spellAgainst: "levenshteinTo:"classVarName)
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2188
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2189
            aClass := aClass superclass
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2190
        ]
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2191
].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2192
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2193
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2194
    "globals"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2195
    Smalltalk allKeysDo:[:aKey |
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2196
        globalVarName := aKey asString.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2197
        "only compare strings where length is about right"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2198
        ((globalVarName size - aString size) abs < 3) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2199
            names add:globalVarName.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2200
            dists add:(aString spellAgainst: "levenshteinTo:"globalVarName)
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2201
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2202
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2203
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2204
    "misc"
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2205
    #('self' 'super' 'nil' 'thisContext') do:[:name |
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2206
        names add:name.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2207
        dists add:(aString spellAgainst: "levenshteinTo:"name)
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2208
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2209
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2210
    (dists size ~~ 0) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2211
        dists sortWith:names.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2212
        dists := dists reverse.             
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2213
        names := names reverse.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2214
        n := names size min:10.
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2215
        names := names copyTo:n.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2216
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2217
        "if it starts with a lower case character, add all local & instvar names"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2218
        (aString at:1) isLowercase ifTrue:[
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2219
            methodVarNames size > 0 ifTrue:[
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2220
                names add:'---- method locals ----'.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2221
                methodVarNames do:[:methodVarName |
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2222
                    names add:methodVarName.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2223
                ].
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2224
            ].
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2225
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2226
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2227
            methodArgs notNil ifTrue:[
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2228
                names add:'---- method arguments ----'.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2229
                methodArgNames do:[:methodArgName |
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2230
                    names add:methodArgName.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2231
                ]
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2232
            ].
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2233
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2234
            names add:'---- instance variables ----'.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2235
            PrevInstVarNames do:[:instVarName |
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2236
                (names includes:instVarName) ifFalse:[
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2237
                    names add:instVarName.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2238
                ]
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2239
            ]
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2240
        ].
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2241
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  2242
        ^ names
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2243
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2244
    ^ nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2245
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2246
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2247
correctVariable
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2248
    "notify error and correct if user wants to;
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2249
     return #Error if there was no correction 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2250
     or a ParseNode as returned by variable"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2251
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2252
    |correctIt varName suggestedNames newName pos1 pos2|
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2253
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2254
    pos1 := tokenPosition.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2255
    varName := tokenName.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2256
    pos2 := pos1 + varName size - 1.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2257
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2258
"OLD:
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2259
    (varName at:1) isLowercase ifTrue:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2260
        correctIt := self undefError:varName position:pos1 to:pos2.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2261
        correctIt ifFalse:[^ #Error]
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2262
    ] ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2263
        correctIt := self warning:(varName , ' is undefined') position:pos1 to:pos2.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2264
        correctIt ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2265
            ^ VariableNode type:#GlobalVariable name:(varName asSymbol)
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2266
        ]
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2267
    ].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2268
"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2269
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2270
    correctIt := self undefError:varName position:pos1 to:pos2.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2271
    correctIt ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2272
        (varName at:1) isLowercase ifTrue:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2273
            ^ #Error
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2274
        ] ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2275
            ^ VariableNode type:#GlobalVariable name:(varName asSymbol)
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2276
        ]
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2277
    ].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2278
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2279
    suggestedNames := self findBestVariablesFor:varName.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2280
    suggestedNames notNil ifTrue:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2281
        newName := self askForCorrection:'correct variable to: ' fromList:suggestedNames.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2282
        newName isNil ifTrue:[^ #Error].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2283
"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2284
        newName := suggestedNames at:1.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2285
        (self confirm:('confirm correction to: ' , newName)) ifFalse:[^ #Error]
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2286
"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2287
    ] ifFalse:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2288
        self notify:'no good correction found'.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2289
        ^ #Error
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2290
    ].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2291
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2292
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2293
     tell requestor (i.e. CodeView) about the change
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2294
     this will update what the requestor shows.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2295
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2296
    requestor replaceSelectionBy:newName.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2297
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2298
     get the updated source-string 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2299
     which is needed, when we eventually install the new method
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2300
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2301
    correctedSource := requestor currentSourceCode.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2302
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2303
    "redo parse with new value"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2304
    tokenName := newName.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2305
    ^ self variableOrError
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2306
!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2307
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2308
askForCorrection:aString fromList:aList
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2309
    "launch a selection box, which allows user to enter correction.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2310
     return true for yes, false for no"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2311
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2312
    |box|
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2313
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2314
    ListSelectionBox isNil ifTrue:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2315
        ^ self confirm:aString
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2316
    ].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2317
    box := ListSelectionBox new.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2318
    box title:aString.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2319
    box initialText:(aList at:1).
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2320
    box list:aList.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2321
    box okText:'correct'.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2322
    "box abortText:'abort'."
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2323
    box action:[:aString | ^ aString].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2324
    box showAtPointer.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2325
    ^ nil
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2326
!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2327
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2328
findBestSelectorsFor:aString
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2329
    "collect known selectors with their spelling distances to aString;
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2330
     return the 10 best suggestions"
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2331
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2332
    |info n|
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2333
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2334
    info := SortedCollection new.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2335
    info sortBlock:[:a :b | a value > b value].
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2336
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2337
    n := 0.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2338
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2339
    Symbol allInstancesDo:[:sym |
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2340
        |dist|
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2341
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2342
        dist := aString spellAgainst:sym.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2343
        dist > 20 ifTrue:[
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2344
            info add:(sym -> dist).
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2345
            n := n + 1.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2346
            n > 10 ifTrue:[
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2347
                info removeLast.
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2348
            ]
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2349
        ]
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2350
    ].
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2351
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2352
    ^ info asOrderedCollection collect:[:a | a key]
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2353
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2354
    "Time millisecondsToRun:[Parser new findBestSelectorsFor:'foo']"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2355
    "Parser new findBestSelectorsFor:'findBestSel'"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2356
    "Parser new findBestSelectorsFor:'fildBestSelectrFr'"
15
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2357
!
992c3d87edbf *** empty log message ***
claus
parents: 13
diff changeset
  2358
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2359
correctSelector:aSelectorString message:msg position:pos1 to:pos2
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2360
    "notify error and correct if user wants to;
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2361
     return #Error if there was no correction 
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2362
     or a ParseNode as returned by variable"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2363
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2364
    |correctIt suggestedNames newSelector l c|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2365
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2366
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2367
     sorry, but I cannot handle keywords with more than one-part
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2368
     currently (too much work - maybe Ill do it later when everything else works :-)
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2369
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2370
    (aSelectorString occurrencesOf:$:) > 1 ifTrue:[
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2371
        self warning:msg position:pos1 to:pos2.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2372
        ^ aSelectorString
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2373
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2374
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2375
    correctIt := self correctableError:msg position:pos1 to:pos2.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2376
    correctIt ifFalse:[^ aSelectorString].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2377
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2378
    suggestedNames := self findBestSelectorsFor:aSelectorString.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2379
    suggestedNames notNil ifTrue:[
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2380
        newSelector := self askForCorrection:'correct selector to: ' fromList:suggestedNames.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2381
        newSelector isNil ifTrue:[^ aSelectorString].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2382
    ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2383
        self notify:'no good correction found'.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2384
        ^ aSelectorString
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2385
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2386
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2387
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2388
     tell requestor (i.e. CodeView) about the change
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2389
     this will update what the requestor shows.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2390
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2391
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2392
    requestor replaceSelectionBy:newSelector keepCursor:false.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2393
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2394
     get the updated source-string 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2395
     which is needed, when we eventually install the new method
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2396
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2397
    correctedSource := requestor currentSourceCode.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2398
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2399
    ^ newSelector
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2400
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2401
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2402
selectorCheck:aSelectorString for:receiver position:pos1 to:pos2
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2403
    "just a quick check: if the selector is totally unknown
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2404
     as a symbol, it cannot possibly be understood.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2405
     Simple, but catches many typos"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2406
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2407
    |ok err sym node|
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2408
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2409
    (LazyCompilation == true) ifTrue:[^ aSelectorString].
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2410
    (ignoreErrors or:[ignoreWarnings]) ifTrue:[^ aSelectorString].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2411
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2412
    err := ' is currently nowhere implemented'.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2413
    "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2414
     check if the selector is known at all
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2415
     - if not, it cannot be understood
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2416
    "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2417
    ok := aSelectorString knownAsSymbol.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2418
    ok ifTrue:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2419
        sym := aSelectorString asSymbol.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2420
        receiver notNil ifTrue:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2421
            "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2422
             if the receiver is a constant, we can check if it responds
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2423
             to this selector
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2424
            "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2425
            receiver isConstant ifTrue:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2426
                ok := receiver evaluate respondsTo:sym.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2427
                err := ' will not be understood here'.
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2428
            ] ifFalse:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2429
                "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2430
                 if the receiver is a global, we check it too ...
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2431
                "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2432
                receiver type == #GlobalVariable ifTrue:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2433
                    ok := receiver evaluate respondsTo:sym.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2434
                    err := ' may not be understood here'.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2435
                ] ifFalse:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2436
                    aSelectorString nArgsIfSelector == 0 ifTrue:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2437
                        "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2438
                         if the (unary) selector is the name of a variable,
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2439
                         check more (usually, there is a missing '.' somewhere)
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2440
                        "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2441
                        err := ' is currently nowhere implemented (''.'' missing ?)'.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2442
                        node := self variableOrError:aSelectorString.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2443
                        node ~~ #Error ifTrue:[
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2444
                            "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2445
                             ok, its known as variable too ...
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2446
                            "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2447
                            ok := false.
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2448
                            Smalltalk allClassesDo:[:aClass |
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2449
                                ok := ok or:[aClass implements:sym]
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2450
                            ].
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2451
                        ]
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2452
                    ]
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2453
                ]
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2454
            ]
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2455
        ]
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2456
    ].
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2457
    ok ifFalse:[
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2458
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2459
"OLD: "
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2460
        self warning:('#' , aSelectorString , err) position:pos1 to:pos2
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2461
" "   
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2462
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2463
"NEW:    - not finished - need more interfaces
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2464
   (currently produces warning output on Transcript while filing in
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2465
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2466
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2467
        ^ self correctSelector:aSelectorString message:('#' , aSelectorString , err) position:pos1 to:pos2
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2468
"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2469
    ].
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2470
    ^ aSelectorString
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2471
! !