Parser.st
author Claus Gittinger <cg@exept.de>
Tue, 14 Jan 1997 16:58:44 +0100
changeset 481 187a88a9695d
parent 480 e4ac7e62ca9a
child 486 e894035d5223
permissions -rw-r--r--
care for maxLineNo when looking for a block-by-lineNo
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
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
     3
	      All Rights Reserved
0
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
165
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    14
	instanceVariableNames:'classToCompileFor selfValue contextToEvaluateIn selector
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    15
		methodArgs methodArgNames methodVars methodVarNames tree
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    16
		currentBlock parseForCode usedInstVars usedClassVars usedVars
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    17
		modifiedInstVars modifiedClassVars modifiedGlobals usesSuper
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    18
		usedGlobals usedSymbols usedMessages localVarDefPosition
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    19
		evalExitBlock selfNode superNode hasPrimitiveCode
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    20
		hasNonOptionalPrimitiveCode primitiveNr primitiveResource logged
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
    21
		warnedUndefVars warnSTXHereExtensionUsed correctedSource
454
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
    22
		foldConstants lineNumberInfo currentNamespace
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
    23
		currentUsedNamespaces'
165
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    24
	classVariableNames:'PrevClass PrevInstVarNames PrevClassVarNames
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    25
		PrevClassInstVarNames LazyCompilation ArraysAreImmutable
376
e08bf1a97051 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 364
diff changeset
    26
		ImplicitSelfSends WarnST80Directives FoldConstants LineNumberInfo'
165
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    27
	poolDictionaries:''
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    28
	category:'System-Compiler'
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    29
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    30
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
    31
!Parser class methodsFor:'documentation'!
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    32
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    33
copyright
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    34
"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    35
 COPYRIGHT (c) 1989 by Claus Gittinger
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    36
	      All Rights Reserved
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    37
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    38
 This software is furnished under a license and may be used
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    39
 only in accordance with the terms of that license and with the
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    40
 inclusion of the above copyright notice.   This software may not
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    41
 be provided or otherwise made available to, or used by, any
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    42
 other person.  No title to or ownership of the software is
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    43
 hereby transferred.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    44
"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    45
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    46
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    47
documentation
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    48
"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    49
    Parser is used for both parsing and evaluating smalltalk expressions;
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    50
    it first builds a parseTree which is then interpreted (evaluate) or
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    51
    compiled. Compilation is done in the subclass ByteCodeCompiler and/or
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    52
    the (planned) MachineCodeCompiler.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    53
173
247ae4b8af76 interest is written with one 'r' (shame on me)
Claus Gittinger <cg@exept.de>
parents: 171
diff changeset
    54
    methods of main interest are:
260
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
    55
        Parser evaluateExpression:...
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    56
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    57
    and:
260
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
    58
        Parser parseExpression:...
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
    59
        Parser parseMethod:...
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    60
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    61
    there is protocol to parse complete methods, selector specs, body only etc.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    62
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    63
    Parser is also used to find the referenced/modified inst/classvars of
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    64
    a method - this is done by sending parseXXX message to a parser and asking
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    65
    the parser for referencedXVars or modifiedXVars (see SystemBrowser).
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    66
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    67
    You can also use parsers for all kinds of other things (ChangesBrowser for
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    68
    example analyzes the expressions in the changelist ...) by looking at the
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    69
    parsers tree. (Although this is somewhat dangerous, since it exports the
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    70
    compilers internals ... better style is to add specialized query methods here,
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    71
    which will be done incrementally.)
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    72
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    73
    One instance of Parser is created to parse one method or expression - i.e.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    74
    its not suggested to reuse parsers.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    75
212
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    76
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    77
  Constant folding:
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    78
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    79
    The parser has various modes for constant folding; by default, only numeric
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    80
    expressions involving integers and floats are constant folded
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    81
    (i.e. something like 'Float pi sin' or '1.5 + 0.3' will be reduced to a constant).
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    82
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    83
    Constant folding can be turned off completely (setting FoldConstants to nil)
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    84
    to ``secure folding'', which only folds constant numbers (#level1) or to #full. 
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    85
    In full mode, more constant expressions are folded (for example: '1.0 @ 1.0' is 
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    86
    reduced to a constant point), but the resulting code may not be compatible with other 
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    87
    smalltalk systems (consider the case, where the point is modified using #x: or #y: messages). 
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    88
    Therefore, this mode is a bit dangerous and disabled by default.
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    89
    
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    90
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    91
  Immutable arrays:
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    92
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    93
    Immutable arrays are experimental and being evaluated.
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    94
    Consider the case of a method returning '#(1 2 3 4)', and that array being modified
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    95
    by some other method (using #at:put:). Since the array-return is actually a return of
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    96
    a reference to the compiler created array, the next invokation of the method will
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    97
    return the modified array. These are hard to find bugs.
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    98
    By an option, the compiler can generate immutable arrays, which dont allow modification
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    99
    of its elements. For clean code, you should enable this option during development.
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   100
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   101
    As mentioned above, this is experimental. If it is reported to be a useful feature,
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   102
    the immutable feature will be extended to strings, point-literals etc. in a future version
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   103
    of st/x.
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   104
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   105
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   106
260
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   107
    [Instance variables:]
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   108
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   109
        classToCompileFor   <Class>             the class (or nil) we are compiling for
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   110
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   111
        selfValue           <any>               value to use as self when interpreting
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   112
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   113
        contextToEvaluateIn <Context>           the context (or nil) when interpreting
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   114
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   115
        selector            <Symbol>            the selector of the parsed method
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   116
                                                (valid after parseMethodSpecification)
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   117
        methodArgs                              internal
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   118
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   119
        methodArgNames      <Collection>        the names of the arguments
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   120
                                                (valid after parseMethodSpecification)
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   121
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   122
        methodVars                              internal
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   123
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   124
        methodVarNames      <Collection>        the names of the method locals
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   125
                                                (valid after parseMethodBodyVarSpec)
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   126
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   127
        tree                <ParseTree>         the parse tree - valid after parsing
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   128
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   129
        currentBlock                            if currently parsing for a block
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   130
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   131
        usedInstVars                            set of all accessed instances variables
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   132
                                                (valid after parsing)
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   133
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   134
        usedClassVars                           same for classVars
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   135
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   136
        usedVars                                all used variables (inst, class & globals)
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   137
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   138
        modifiedInstVars                        set of all modified instance variables
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   139
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   140
        modifiedClassVars                       same for clasVars
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   141
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   142
        localVarDefPosition <Integer>           the character offset of the local variable
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   143
                                                def. (i.e. the first '|' if any)
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   144
                                                Not yet used - prepared for automatic add of
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   145
                                                undefined variables
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   146
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   147
        evalExitBlock                           internal for interpretation
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   148
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   149
        selfNode            <Node>              cached one-and-only 'self' node
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   150
        superNode           <Node>              cached one-and-only 'super' node
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   151
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   152
        hasPrimitiveCode    <Boolean>           true, if it contains ST/X style primitive code
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   153
        hasNonOptionalPrimitiveCode    
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   154
                            <Boolean>           true, if it contains ST/X style primitive code
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   155
                                                which is NOT flagged by the OPTIONAL directive.
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   156
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   157
        primitiveNr         <Integer>           the parsed ST-80 type primitive number (or nil)
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   158
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   159
        logged
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   160
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   161
        warnedUndefVars     <Set>               set of all variables which the parser has
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   162
                                                already output a warning (to avoid multiple
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   163
                                                warnings about the same variable)
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   164
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   165
    [Class variables:]
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   166
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   167
        PrevClass           <Class>             class, of which properties are
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   168
                                                cached in:
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   169
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   170
        PrevInstVarNames      <Collection>      instance variablenames of cached class
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   171
        PrevClassVarNames     <Collection>      class variablenames of cached class
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   172
        PrevClassInstVarNames <Collection>      class instance variablenames of cached class
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   173
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   174
        LazyCompilation       <Boolean>         EXPERIMENTAL: lazy compilation
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   175
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   176
        ArraysAreImmutable    <Boolean>         if true, create array literals
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   177
                                                as instances of ImmutableArray,
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   178
                                                which cannot be stored into.
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   179
                                                Default is false, for compatibility.
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   180
                                                Can be turned on while developping
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   181
                                                new code to make certain that side
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   182
                                                effects are avoided.
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   183
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   184
        WarnST80Directives    <Boolean>         if true, give warnings about
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   185
                                                ST-80 directives (resource defs)
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   186
                                                which are ignored in st/x.
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   187
                                                defaults to false.
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   188
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   189
        FoldConstants         <Symbol>          controls how constant folding should be
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   190
                                                done.
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   191
                                                Can be one of:
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   192
                                                        nil      - no constant folding
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   193
                                                        #level1  - numeric optimizations only
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   194
                                                        #level2  - secure optimizations only
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   195
                                                        #full    - full folding
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   196
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   197
                                                level1:   arithmetic on constant numbers
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   198
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   199
                                                level2:   above PLUS array conversions with #asFloatArray,
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   200
                                                          #asDoubleArray, string concatenation
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   201
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   202
                                                full:     constant points.
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   203
                                                          
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   204
    [see also:]
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   205
        ByteCodeCompiler Scanner ObjectFileLoader
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   206
        Workspace
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   207
        SystemBrowser
263
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 260
diff changeset
   208
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 260
diff changeset
   209
    [author:]
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 260
diff changeset
   210
        Claus Gittinger
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   211
"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   212
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   213
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
   214
!Parser class methodsFor:'instance creation'!
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   215
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   216
for:aStringOrStream in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   217
    "return a new parser, reading code for aClass from aStringOrStream"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   218
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   219
    |parser|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   220
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   221
    parser := self for:aStringOrStream.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   222
    parser setClassToCompileFor:aClass.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   223
    ^ parser
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   224
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   225
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
   226
!Parser class methodsFor:'changes'!
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   227
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   228
flushNameCache
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   229
    "unconditional flush name caches"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   230
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   231
    PrevClass notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   232
	PrevClass removeDependent:Parser
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   233
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   234
    PrevClass := nil.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   235
    PrevInstVarNames := nil.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   236
    PrevClassVarNames := nil.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   237
    PrevClassInstVarNames := nil.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   238
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   239
    "Parser flushNameCache"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   240
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   241
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   242
update:something with:someArgument from:changedObject
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   243
    "aClass has changed its definition - flush name caches if we have to"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   244
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   245
    (changedObject == PrevClass) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   246
	something == #definition ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   247
	    self flushNameCache
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   248
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   249
    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   250
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   251
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
   252
!Parser class methodsFor:'controlling compilation'!
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   253
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   254
arraysAreImmutable
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   255
    "return true if arrays are immutable literals"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   256
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   257
    ^ ArraysAreImmutable
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   258
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   259
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   260
arraysAreImmutable:aBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   261
    "turn on/off immutable array literals - default is false for ST-80 compatibilty."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   262
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   263
    ArraysAreImmutable := aBoolean.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   264
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   265
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   266
     can be added to your private.rc file:
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   267
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   268
     Compiler arraysAreImmutable:true     
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   269
     Compiler arraysAreImmutable:false      
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   270
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   271
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   272
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   273
compileLazy
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   274
    "return true if compiling lazy"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   275
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   276
    ^ LazyCompilation.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   277
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   278
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   279
compileLazy:aBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   280
    "turn on/off lazy compilation - return previous setting.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   281
     Actually this flag belongs into the ByteCodeCompiler subclass,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   282
     but it also controls the reporting of some errors here; therefore
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   283
     its located here"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   284
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   285
    |oldLazy|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   286
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   287
    oldLazy := LazyCompilation.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   288
    LazyCompilation := aBoolean.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   289
    ^ oldLazy
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   290
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   291
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   292
     usually set in your .rc file
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   293
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   294
     Compiler compileLazy:false         
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   295
     Compiler compileLazy:true          
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   296
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   297
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   298
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   299
foldConstants
212
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   300
    "return a symbol describing how constants are to be folded"
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   301
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   302
    ^ FoldConstants
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   303
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   304
    "Created: 9.2.1996 / 17:40:13 / cg"
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   305
!
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   306
212
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   307
foldConstants:aSymbol
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   308
    "set the symbol describing how constants are to be folded.
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   309
     It can be:
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   310
	nil		- no constant folding
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   311
	#level1 	- numeric constants only
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   312
	#level2 	- level1 PLUS array conversions PLUS string concatenation
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   313
	#full		- level2 PLUS constant points, constant rectangles (dangerous)"
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   314
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   315
    FoldConstants := aSymbol
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   316
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   317
    "Created: 9.2.1996 / 17:40:34 / cg"
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   318
!
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   319
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   320
implicitSelfSends
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   321
    "return true if undefined variables with
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   322
     lowercase first character are to be turned
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   323
     into implicit self sends"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   324
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   325
    ^ ImplicitSelfSends
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   326
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   327
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   328
implicitSelfSends:aBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   329
    "turn on/off implicit self sends"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   330
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   331
    ImplicitSelfSends := aBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   332
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   333
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   334
     Compiler implicitSelfSends:true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   335
     Compiler implicitSelfSends:false 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   336
    "
377
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   337
!
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   338
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   339
lineNumberInfo
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   340
    ^ LineNumberInfo
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   341
!
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   342
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   343
lineNumberInfo:aBoolean
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   344
    LineNumberInfo := aBoolean
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   345
! !
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   346
481
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   347
!Parser class methodsFor:'defaults'!
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   348
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   349
maxLineNumber
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   350
    "return the maximum lineNumber that is possibly
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   351
     encoded in a methods byteCode debugging information.
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   352
     Since lineNumber entries only have 1 byte available,
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   353
     this is 255 for byteCode methods."
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   354
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   355
    ^ 255
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   356
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   357
    "Created: 14.2.1997 / 16:52:54 / cg"
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   358
! !
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   359
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
   360
!Parser class methodsFor:'evaluating expressions'!
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   361
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   362
evaluate:aStringOrStream
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   363
    "return the result of evaluating an expression in aStringOrStream.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   364
     No doit-entry is added to the changeLog."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   365
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   366
    ^ self 
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   367
	evaluate:aStringOrStream 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   368
	in:nil 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   369
	receiver:nil 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   370
	notifying:nil 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   371
	logged:false
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   372
	ifFail:nil 
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   373
	compile:true
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   374
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   375
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   376
     Compiler evaluate:'1 + 2'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   377
     Compiler evaluate:'''hello world'' asSortedCollection displayString printNL'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   378
     Compiler evaluate:'''hello world'' asSortedCollection printNL'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   379
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   380
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   381
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   382
evaluate:aStringOrStream compile:compile
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   383
    "return the result of evaluating aString, 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   384
     The compile argument specifies if the string should be compiled down to 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   385
     bytecode or instead be interpreted from the parseTree.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   386
     The first should be done for doIts etc, where a readable walkback is
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   387
     required.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   388
     The latter is better done for constants, styleSheet and resource
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   389
     reading and simple sends, where the overhead of compilation is bigger
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   390
     than the interpretation overhead."
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   391
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   392
    ^ self 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   393
	evaluate:aStringOrStream
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   394
	in:nil
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   395
	receiver:nil 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   396
	notifying:nil 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   397
	logged:false
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   398
	ifFail:nil
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   399
	compile:compile 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   400
!
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   401
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   402
evaluate:aStringOrStream ifFail:failBlock
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   403
    "return the result of evaluating an expression in aStringOrStream.
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   404
     In case of any syntax errors, return the value of failBlock.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   405
     No doit-entry is added to the changeLog."
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   406
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   407
    ^ self 
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   408
	evaluate:aStringOrStream 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   409
	in:nil 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   410
	receiver:nil 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   411
	notifying:nil 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   412
	logged:false
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   413
	ifFail:failBlock 
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   414
	compile:true
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   415
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   416
     Compiler evaluate:'1 +' ifFail:['oops']   
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   417
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   418
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   419
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   420
evaluate:aStringOrStream in:aContext receiver:anObject notifying:requestor ifFail:failBlock
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   421
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   422
     Allow access to anObject as self and to its instVars (used in the inspector).
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   423
     No doIt entry is added to the change-file. 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   424
     If the failBlock argument is non-nil, it is evaluated if an error occurs."
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   425
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   426
    ^ self 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   427
	evaluate:aStringOrStream
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   428
	in:nil
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   429
	receiver:anObject
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   430
	notifying:requestor
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   431
	logged:false
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   432
	ifFail:nil
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   433
	compile:true
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   434
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   435
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   436
evaluate:aStringOrStream in:aContext receiver:anObject notifying:requestor logged:logged ifFail:failBlock
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   437
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   438
     Allow access to anObject as self and to its instVars (used in the inspector).
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   439
     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
   440
     is non-nil, it is evaluated if an error occurs."
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   441
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   442
    ^ self 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   443
	evaluate:aStringOrStream
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   444
	in:aContext
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   445
	receiver:anObject
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   446
	notifying:requestor
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   447
	logged:logged 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   448
	ifFail:failBlock 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   449
	compile:true
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   450
!
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   451
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   452
evaluate:aStringOrStream in:aContext receiver:anObject notifying:requestor logged:logged ifFail:failBlock compile:compile
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   453
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   454
     Allow access to anObject as self and to its instVars (used in the inspector).
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   455
     If logged is true, an entry is added to the change-file. If the failBlock argument
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   456
     is non-nil, it is evaluated if an error occurs.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   457
     Finally, compile specifies if the string should be compiled down to 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   458
     bytecode or instead be interpreted from the parseTree.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   459
     The first should be done for doIts etc, where a readable walkback is
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   460
     required.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   461
     The latter is better done for constants, styleSheet and resource
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   462
     reading and simple sends, where the overhead of compilation is bigger
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   463
     than the interpretation overhead."
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   464
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   465
    |parser tree mustBackup loggedString chgStream value s sReal spc|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   466
7ad01559b262 Initial revision
claus
parents:
diff changeset
   467
    aStringOrStream isNil ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   468
    aStringOrStream isStream ifTrue:[
260
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   469
        s := aStringOrStream.
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   470
        mustBackup := true
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   471
    ] ifFalse:[
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   472
        loggedString := aStringOrStream.
260
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   473
        s := ReadStream on:aStringOrStream.
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   474
        mustBackup := false
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   475
    ].
260
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   476
    parser := self for:s.
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   477
    parser parseForCode.
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   478
    parser foldConstants:nil.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   479
    parser setSelf:anObject.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   480
    parser setContext:aContext.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   481
    parser notifying:requestor.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   482
    parser nextToken.
79
26f81a94a6ea *** empty log message ***
claus
parents: 78
diff changeset
   483
    tree := parser parseMethodBodyOrEmpty.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   484
7ad01559b262 Initial revision
claus
parents:
diff changeset
   485
    "if reading from a stream, backup for next expression"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   486
    mustBackup ifTrue:[
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   487
        parser backupPosition
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   488
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   489
7ad01559b262 Initial revision
claus
parents:
diff changeset
   490
    (parser errorFlag or:[tree == #Error]) ifTrue:[
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   491
        failBlock notNil ifTrue:[
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   492
            ^ failBlock value
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   493
        ].
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   494
        ^ #Error
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   495
    ].
260
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   496
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   497
    tree notNil ifTrue:[
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   498
        (logged
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   499
        and:[loggedString notNil
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   500
        and:[Smalltalk logDoits]]) ifTrue:[
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   501
            chgStream := Class changesStream.
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   502
            chgStream notNil ifTrue:[
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   503
                chgStream nextChunkPut:loggedString.
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   504
                chgStream cr.
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   505
                chgStream close
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   506
            ].
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   507
        ].
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   508
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   509
        "
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   510
         during the evaluation, handle nameSpace queries
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   511
         from the value as defined by any namespace directive.
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   512
         This, if its a class definition expression, the class will
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   513
         be installed there.
260
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   514
        "
454
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
   515
        Class nameSpaceQuerySignal handle:[:ex |
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
   516
            spc isNil ifTrue:[
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
   517
                spc := parser getNameSpace.
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
   518
                spc isNil ifTrue:[
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
   519
                    (requestor respondsTo:#currentNameSpace) ifTrue:[
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
   520
                        spc := requestor currentNameSpace
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
   521
                    ] ifFalse:[
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
   522
                        spc := Class nameSpaceQuerySignal raise.
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
   523
                    ]
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
   524
                ]
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
   525
            ].
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
   526
            ex proceedWith:spc.
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
   527
        ] do:[
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   528
            |method|
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   529
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   530
            "
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   531
             if compile is false, or the parse tree is that of a constant, 
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   532
             or a variable, quickly return its value.
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   533
             This is used for example, when reading simple objects
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   534
             via #readFrom:. 
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   535
             The overhead of compiling a method is avoided in this case.
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   536
            "
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   537
            (compile not 
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   538
             or:[tree isConstant
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   539
             or:[tree isVariable
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   540
             or:[aStringOrStream isStream]]]) ifTrue:[
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   541
                ^ tree evaluate
260
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   542
            ].
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   543
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   544
            "
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   545
             if I am the ByteCodeCompiler,
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   546
             generate a dummy method, execute it and return the value.
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   547
             otherwise, just evaluate the tree; slower, but not too bad ...
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   548
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   549
             This allows systems to be delivered without the ByteCodeCompiler,
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   550
             and still evaluate expressions 
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   551
             (needed to read resource files or to process .rc files).
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   552
            "
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   553
            self == Parser ifTrue:[
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   554
                parser evalExitBlock:[:value | parser release. ^ value].
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   555
                value := tree evaluate.
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   556
                parser evalExitBlock:nil.
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   557
            ] ifFalse:[
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   558
                aStringOrStream isStream ifTrue:[
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   559
                    s := parser collectedSource.  "/ does not work yet ...
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   560
                ] ifFalse:[
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   561
                    s := aStringOrStream
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   562
                ].
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   563
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   564
                "/ actually, its a block, to allow
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   565
                "/ easy return ...
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   566
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   567
                sReal := 'doIt ^[\' withCRs , s , '\] value' withCRs.
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   568
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   569
                method := self 
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   570
                        compile:sReal 
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   571
                        forClass:anObject class
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   572
                        inCategory:'_temporary_' 
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   573
                        notifying:requestor 
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   574
                        install:false 
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   575
                        skipIfSame:false 
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   576
                        silent:true
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   577
                        foldConstants:false.
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   578
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   579
                method notNil ifTrue:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   580
                    method ~~ #Error ifTrue:[
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   581
                        "
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   582
                         fake: patch the source string, to what the user expects
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   583
                         in the browser
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   584
                        "
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   585
                        method source:'       \' withCRs , s .
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   586
                        "
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   587
                         dont do any just-in-time compilation on it.
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   588
                        "
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   589
                        method checked:true.
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   590
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   591
                        value := method 
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   592
                                    valueWithReceiver:anObject 
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   593
                                    arguments:nil  "/ (Array with:m) 
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   594
                                    selector:#doIt "/ #doIt: 
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   595
                                    search:nil
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   596
                                    sender:nil.
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   597
                    ] ifFalse:[
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   598
                        parser evalExitBlock:[:value | parser release. ^ value].
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   599
                        value := tree evaluate.
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   600
                        parser evalExitBlock:nil.
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   601
                    ]
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   602
                ].
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
   603
            ]
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
   604
        ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   605
    ].
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
   606
    parser release.
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
   607
    ^ value
260
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   608
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   609
    "Modified: 11.1.1997 / 23:25:25 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   610
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   611
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   612
evaluate:aStringOrStream logged:logged
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   613
    "return the result of evaluating an expression in aStringOrStream.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   614
     The argument log controls if an entry is added to the changeLog."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   615
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   616
    ^ self 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   617
	evaluate:aStringOrStream 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   618
	in:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   619
	receiver:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   620
	notifying:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   621
	logged:logged
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   622
	ifFail:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   623
	compile:true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   624
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   625
     Compiler evaluate:'''some string''' logged:false   
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   626
     Compiler evaluate:'''some string''' logged:true   
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   627
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   628
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   629
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   630
evaluate:aStringOrStream notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   631
    "return the result of evaluating aString, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   632
     errors are reported to requestor"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   633
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   634
    ^ self 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   635
	evaluate:aStringOrStream 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   636
	in:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   637
	receiver:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   638
	notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   639
	logged:false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   640
	ifFail:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   641
	compile:true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   642
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   643
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   644
evaluate:aStringOrStream notifying:requestor compile:compile
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   645
    "return the result of evaluating aString, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   646
     errors are reported to requestor.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   647
     The compile argument specifies if the string should be compiled down to 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   648
     bytecode or instead be interpreted from the parseTree.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   649
     The first should be done for doIts etc, where a readable walkback is
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   650
     required.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   651
     The latter is better done for constants, styleSheet and resource
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   652
     reading and simple sends, where the overhead of compilation is bigger
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   653
     than the interpretation overhead."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   654
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   655
    ^ self 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   656
	evaluate:aStringOrStream 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   657
	in:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   658
	receiver:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   659
	notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   660
	logged:false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   661
	ifFail:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   662
	compile:compile
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   663
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   664
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   665
evaluate:aStringOrStream receiver:anObject notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   666
    "return the result of evaluating aString, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   667
     errors are reported to requestor. Allow access to
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   668
     anObject as self and to its instVars (used in the inspector)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   669
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   670
    ^ self 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   671
	evaluate:aStringOrStream
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   672
	in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   673
	receiver:anObject
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   674
	notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   675
	logged:false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   676
	ifFail:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   677
	compile:true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   678
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   679
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   680
     Compiler evaluate:'self x' receiver:(1 @ 2) notifying:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   681
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   682
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   683
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   684
evaluate:aStringOrStream receiver:anObject notifying:requestor compile:compile
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   685
    "return the result of evaluating aString, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   686
     errors are reported to requestor. Allow access to
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   687
     anObject as self and to its instVars (used in the inspector).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   688
     The compile argument specifies if the string should be compiled down to 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   689
     bytecode or instead be interpreted from the parseTree.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   690
     The first should be done for doIts etc, where a readable walkback is
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   691
     required.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   692
     The latter is better done for constants, styleSheet and resource
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   693
     reading and simple sends, where the overhead of compilation is bigger
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   694
     than the interpretation overhead."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   695
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   696
    ^ self 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   697
	evaluate:aStringOrStream
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   698
	in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   699
	receiver:anObject
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   700
	notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   701
	logged:false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   702
	ifFail:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   703
	compile:compile 
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   704
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   705
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
   706
!Parser class methodsFor:'initialization '!
66
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   707
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   708
initialize
98
claus
parents: 97
diff changeset
   709
    LazyCompilation := false.      "/ usually set to true in your .rc file
claus
parents: 97
diff changeset
   710
    ArraysAreImmutable := false.   "/ usually left true for ST-80 compatibility
207
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
   711
    ImplicitSelfSends := false.
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
   712
    WarnST80Directives := false.
212
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   713
    FoldConstants := #level1.
377
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   714
    LineNumberInfo := false.
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   715
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   716
    "
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   717
     self initialize
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   718
    "
66
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   719
! !
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   720
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
   721
!Parser class methodsFor:'parsing'!
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   722
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   723
blockAtLine:line in:aMethod orSource:aString numArgs:nA numVars:nV
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   724
    "given a lineNr in some method, 
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   725
     return the containing BlockNode or nil.
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   726
     The given lineNr must be within a block for this to work.
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   727
     This is used by the debugger, to guess reverse from a lineNumber,
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   728
     to the corresponding block, in order to find out the blocks
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   729
     variable names (mhmh - all of this wasnt't needed, if blocks stored
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   730
     their characterPosition internally)."
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   731
429
ffc4e2ab5581 cleanup
Claus Gittinger <cg@exept.de>
parents: 427
diff changeset
   732
    |compiler tree mSource who mClass blocks 
397
118267bf78e5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 391
diff changeset
   733
     maxSoFar innerBlock m|
118267bf78e5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 391
diff changeset
   734
481
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   735
    (line isNil or:[line == self maxLineNumber]) ifTrue:[
457
ad25339043ef care for nil-lineNumber when looking for a block
Claus Gittinger <cg@exept.de>
parents: 455
diff changeset
   736
        ^ nil
ad25339043ef care for nil-lineNumber when looking for a block
Claus Gittinger <cg@exept.de>
parents: 455
diff changeset
   737
    ].
ad25339043ef care for nil-lineNumber when looking for a block
Claus Gittinger <cg@exept.de>
parents: 455
diff changeset
   738
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   739
    aMethod notNil ifTrue:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   740
        m := aMethod.
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   741
        who := m who.
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   742
        who isNil ifTrue:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   743
            m isWrapped ifTrue:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   744
                m := m wrapper.
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   745
                m notNil ifTrue:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   746
                    who := m who.
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   747
                ]
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   748
            ]
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   749
        ].
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   750
        who notNil ifTrue:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   751
            mClass := who methodClass.
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   752
            mClass isNil ifTrue:[ ^ nil].
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   753
        ].
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   754
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   755
        mSource := m source.
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   756
        mSource isNil ifTrue:[^ nil].
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   757
    ] ifFalse:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   758
        aString notNil ifTrue:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   759
            mSource := aString.
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   760
            mClass := UndefinedObject
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   761
        ] ifFalse:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   762
            ^ nil
397
118267bf78e5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 391
diff changeset
   763
        ]
118267bf78e5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 391
diff changeset
   764
    ].
118267bf78e5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 391
diff changeset
   765
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   766
    "create a compiler, let it parse and create the parsetree"
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   767
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   768
    compiler := self for:(ReadStream on:mSource) in:mClass.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   769
    compiler parseForCode.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   770
    compiler notifying:nil.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   771
    compiler ignoreWarnings.
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   772
    compiler ignoreErrors.
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   773
    compiler lineNumberInfo:#full.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   774
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   775
    aMethod notNil ifTrue:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   776
        (compiler parseMethodSpec == #Error) ifTrue:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   777
            ^ nil.
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   778
        ].
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   779
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   780
        who notNil ifTrue:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   781
            compiler selector ~~ (who methodSelector) ifTrue:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   782
                ^ nil
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   783
            ]
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   784
        ].
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   785
    ] ifFalse:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   786
        compiler nextToken.
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   787
    ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   788
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   789
    tree := compiler parseMethodBody.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   790
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   791
    (compiler errorFlag or:[tree == #Error]) ifTrue:[
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   792
        ^ nil
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   793
    ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   794
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   795
    blocks := OrderedCollection new.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   796
    tree collectBlocksInto:blocks.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   797
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   798
    blocks := blocks select:[:aBlock |
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   799
                                line between: aBlock lineNumber and:aBlock endLineNumber
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   800
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   801
                            ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   802
    blocks size == 1 ifTrue:[
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   803
        ^ blocks at:1
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   804
    ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   805
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   806
    nA notNil ifTrue:[
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   807
        blocks := blocks select:[:aBlock |
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   808
                                aBlock numArgs == nA
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   809
                                ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   810
        blocks size == 1 ifTrue:[
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   811
            ^ blocks at:1
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   812
        ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   813
    ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   814
    nV notNil ifTrue:[
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   815
        blocks := blocks select:[:aBlock |
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   816
                                aBlock numVars == nV
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   817
                                ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   818
        blocks size == 1 ifTrue:[
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   819
            ^ blocks at:1
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   820
        ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   821
    ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   822
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   823
    "/ look for the inner one
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   824
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   825
    maxSoFar := 0.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   826
    blocks do:[:aBlock |
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   827
        aBlock lineNumber > maxSoFar ifTrue:[
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   828
            innerBlock := aBlock.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   829
            maxSoFar := aBlock lineNumber
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   830
        ]
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   831
    ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   832
    ^ innerBlock.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   833
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
   834
    "Created: 11.1.1997 / 23:29:13 / cg"
481
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   835
    "Modified: 14.2.1997 / 16:51:25 / cg"
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   836
!
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
   837
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   838
parseExpression:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   839
    "parse aString as an expression; 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   840
     Return the parseTree (if ok), nil (for an empty string 
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   841
     or comment only) or #Error (syntactic error).
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   842
     Error and warning messages are suppressed."
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   843
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   844
    ^ self withSelf:nil 
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   845
           parseExpression:aString 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   846
           notifying:nil 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   847
           ignoreErrors:true       "silence on Transcript"
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   848
           ignoreWarnings:true
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   849
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   850
    "Modified: 24.4.1996 / 13:18:21 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   851
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   852
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   853
parseMethod:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   854
    "parse a method.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   855
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   856
     The parser can be queried for selector, receiver, args, locals,
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   857
     used selectors etc.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   858
     Error and warning messages are sent to the Transcript."
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   859
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   860
    ^ self parseMethod:aString in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   861
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   862
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   863
     |p|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   864
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   865
     p := Parser 
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   866
             parseMethod:'
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   867
                 foo:arg1 bar:arg2 baz:arg3 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   868
                     |l1 l2| 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   869
                     l1 := 0. 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   870
                     l2 := arg1. 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   871
                     ^ self'.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   872
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   873
     'nArgs:  ' print. p numberOfMethodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   874
     'args:   ' print. p methodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   875
     'sel:    ' print. p selector printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   876
     'nLocal: ' print. p numberOfMethodVars printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   877
     'locals: ' print. p methodVars printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   878
     'tree:   ' printNL. p tree printAllOn:Stdout. Stdout cr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   879
    "
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   880
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   881
    "Modified: 24.4.1996 / 13:18:02 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   882
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   883
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   884
parseMethod:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   885
    "parse a method in a given class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   886
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   887
     The parser can be queried for selector, receiver, args, locals,
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   888
     used selectors, modified instvars, referenced classvars etc.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   889
     Error and warning messages are sent to the Transcript."
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   890
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   891
    ^ self 
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   892
        parseMethod:aString 
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   893
        in:aClass 
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   894
        ignoreErrors:false 
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   895
        ignoreWarnings:false
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   896
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   897
    "Modified: 24.4.1996 / 13:18:34 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   898
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   899
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   900
parseMethod:aString in:aClass ignoreErrors:noErrors ignoreWarnings:noWarnings
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   901
    "parse a method in a given class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   902
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   903
     The parser can be queried for selector, receiver, args, locals,
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   904
     used selectors, modified instvars, referenced classvars etc.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   905
     The noErrors and noWarnings arguments specify if error and warning 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   906
     messages should be sent to the Transcript or suppressed."
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   907
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   908
    |parser tree|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   909
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   910
    aString isNil ifTrue:[^ nil].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   911
    parser := self for:(ReadStream on:aString) in:aClass.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   912
    noErrors ifTrue:[
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   913
        parser ignoreErrors
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   914
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   915
    noWarnings ifTrue:[
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   916
        parser ignoreWarnings
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   917
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   918
    tree := parser parseMethod.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   919
    (parser errorFlag or:[tree == #Error]) ifTrue:[^ nil].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   920
    ^ parser
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   921
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   922
    "Modified: 24.4.1996 / 13:19:23 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   923
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   924
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   925
parseMethod:aString in:aClass warnings:warnBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   926
    "parse a method in a given class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   927
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   928
     The parser can be queried for selector, receiver, args, locals,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   929
     used selectors, modified instvars, referenced classvars etc.
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   930
     The warnBoolean arguments specifies if warning 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   931
     messages should be sent to the Transcript or suppressed.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   932
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   933
     This method is OBSOLETE, and left in for backward compatibility."
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   934
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   935
    self obsoleteMethodWarning.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   936
    ^ self
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   937
        parseMethod:aString 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   938
        in:aClass 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   939
        ignoreErrors:false 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   940
        ignoreWarnings:warnBoolean not
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   941
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   942
    "Modified: 24.4.1996 / 13:28:05 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   943
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   944
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   945
parseMethodArgAndVarSpecification:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   946
    "parse a methods selector, arg and var spec (i.e. locals);
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   947
     Return a parser (if ok), nil (empty) or #Error (syntax).
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   948
     The parser can be queried for selector, receiver etc.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   949
     Error and warning messages are sent to the Transcript.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   950
     This method is OBSOLETE."
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   951
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   952
    self obsoleteMethodWarning.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   953
    ^ self parseMethodArgAndVarSpecification:aString in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   954
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   955
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   956
     |p|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   957
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   958
     p := Parser 
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   959
             parseMethodArgAndVarSpecification:'
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   960
                      foo:arg1 bar:arg2 baz:arg3 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   961
                      |l1 l2|'.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   962
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   963
     'nArgs:  ' print. p numberOfMethodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   964
     'args:   ' print. p methodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   965
     'sel:    ' print. p selector printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   966
     'nLocal: ' print. p numberOfMethodVars printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   967
     'locals: ' print. p methodVars printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   968
    "
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   969
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   970
    "Modified: 24.4.1996 / 13:29:43 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   971
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   972
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   973
parseMethodArgAndVarSpecification:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   974
    "parse a methods selector, arg and var spec in a given class;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   975
     Return a parser (if ok), nil (empty) or #Error (syntax).
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   976
     The parser can be queried for selector, receiver, args and locals.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   977
     Error and warning messages are sent to the Transcript.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   978
     This method is OBSOLETE."
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   979
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   980
    self obsoleteMethodWarning.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   981
    ^ self parseMethodArgAndVarSpecification:aString 
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   982
           in:aClass 
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   983
           ignoreErrors:false
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   984
           ignoreWarnings:false 
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   985
           parseBody:false
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   986
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   987
    "Modified: 24.4.1996 / 13:30:03 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   988
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   989
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   990
parseMethodArgAndVarSpecification:aString in:aClass ignoreErrors:noErrors ignoreWarnings:noWarnings parseBody:body
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   991
    "parse a methods selector, arg and var spec in a given class;
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   992
     If parseBody is true, also parse the statements 
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   993
     (for primitives & resourceSpecs).
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   994
     The noErrors and noWarnings arguments specify if error and warning 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
   995
     messages should be sent to the Transcript or suppressed.
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
   996
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   997
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   998
     The parser can be queried for selector, receiver, args and locals"
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   999
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1000
    |parser|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1001
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1002
    aString isNil ifTrue:[^ nil].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1003
    parser := self for:(ReadStream on:aString) in:aClass.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1004
    noErrors ifTrue:[
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1005
        parser ignoreErrors
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1006
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1007
    noWarnings ifTrue:[
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1008
        parser ignoreWarnings
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1009
    ].
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1010
"/    parser nextToken.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1011
    (parser parseMethodSpec == #Error) ifTrue:[^ nil].
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1012
    "/
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1013
    "/ used to be #parseMethodBodyVarSpec
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1014
    "/ - now, alternatively parse body for resource & primitive specs ..
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1015
    "/
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1016
    body ifTrue:[
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1017
        (parser parseMethodBodyOrEmpty == #Error) ifTrue:[^ nil].
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1018
    ] ifFalse:[
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1019
        (parser parseMethodBodyVarSpec == #Error) ifTrue:[^ nil].
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1020
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1021
    parser errorFlag ifTrue:[^ nil].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1022
    ^ parser
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1023
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1024
    "Created: 24.4.1996 / 13:13:06 / cg"
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  1025
    "Modified: 27.4.1996 / 16:58:02 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1026
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1027
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1028
parseMethodArgAndVarSpecificationSilent:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1029
    "parse a methods selector, arg and var spec (i.e. locals);
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1030
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1031
     The parser can be queried for selector, receiver etc.
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1032
     Like #parseMethodArgAndVarSpecification:, but does NOT
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1033
     display error/warning messages on the transcript."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1034
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1035
    ^ self parseMethodArgAndVarSpecificationSilent:aString in:nil
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1036
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1037
    "Modified: 24.4.1996 / 13:30:54 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1038
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1039
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1040
parseMethodArgAndVarSpecificationSilent:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1041
    "parse a methods selector, arg and var spec in a given class;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1042
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1043
     The parser can be queried for selector, receiver, args and locals.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1044
     Like #parseMethodArgAndVarSpecification:in:, but does not
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1045
     display error/warning messages on the transcript."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1046
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1047
    ^ self parseMethodArgAndVarSpecification:aString 
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1048
           in:aClass 
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1049
           ignoreErrors:true 
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1050
           ignoreWarnings:true 
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1051
           parseBody:false
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1052
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1053
    "Modified: 24.4.1996 / 13:14:27 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1054
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1055
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1056
parseMethodSilent:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1057
    "parse a method.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1058
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1059
     The parser can be queried for selector, receiver, args, locals,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1060
     used selectors etc.
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1061
     Like #parseMethod:, but warning/error messages are suppressed."
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1062
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1063
    ^ self parseMethodSilent:aString in:nil
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1064
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1065
    "Modified: 24.4.1996 / 13:32:44 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1066
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1067
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1068
parseMethodSilent:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1069
    "parse a method in a given class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1070
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1071
     The parser can be queried for selector, receiver, args, locals,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1072
     used selectors, modified instvars, referenced classvars etc.
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1073
     Like #parseMethod:in:, but warning/error messages are suppressed."
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1074
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1075
    ^ self 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1076
        parseMethod:aString 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1077
        in:aClass 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1078
        ignoreErrors:true 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1079
        ignoreWarnings:true
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1080
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1081
    "Modified: 24.4.1996 / 13:32:57 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1082
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1083
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1084
parseMethodSpecification:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1085
    "parse a methods selector & arg specification; 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1086
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1087
     The parser can be queried for selector, receiver etc."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1088
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1089
    ^ self parseMethodSpecification:aString in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1090
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1091
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1092
     |p|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1093
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1094
     p := Parser parseMethodSpecification:'foo:arg1 bar:arg2 baz:arg3'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1095
     'nArgs: ' print. p numberOfMethodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1096
     'args:  ' print. p methodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1097
     'sel:   ' print. p selector printNL
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1098
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1099
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1100
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1101
parseMethodSpecification:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1102
    "parse a methods selector & arg spec for a given class;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1103
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1104
     The parser can be queried for selector, receiver etc."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1105
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1106
    ^ self parseMethodSpecification:aString 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1107
	   in:aClass 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1108
	   ignoreErrors:false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1109
	   ignoreWarnings:false 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1110
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1111
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1112
parseMethodSpecification:aString in:aClass ignoreErrors:noErrors ignoreWarnings:noWarnings 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1113
    "parse a methods selector & arg spec for a given class;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1114
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1115
     The parser can be queried for selector, receiver etc.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1116
     noErrors and noWarnings specify if error- and warningMessages are
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1117
     to be output onto the Transcript."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1118
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1119
    |parser tree|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1120
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1121
    aString isNil ifTrue:[^ nil].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1122
    parser := self for:(ReadStream on:aString) in:aClass.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1123
    noErrors ifTrue:[
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1124
        parser ignoreErrors
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1125
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1126
    noWarnings ifTrue:[
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1127
        parser ignoreWarnings
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1128
    ].
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1129
"/    parser nextToken.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1130
    tree := parser parseMethodSpec.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1131
    (parser errorFlag or:[tree == #Error]) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1132
    ^ parser
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1133
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1134
    "Modified: 20.4.1996 / 20:09:48 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1135
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1136
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1137
parseMethodSpecificationSilent:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1138
    "parse a methods selector & arg specification; 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1139
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1140
     The parser can be queried for selector, receiver etc.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1141
     Like #parseMethodSpecification:, but does not display any error/warning Messages on the transcript."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1142
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1143
    ^ self parseMethodSpecificationSilent:aString in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1144
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1145
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1146
parseMethodSpecificationSilent:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1147
    "parse a methods selector & arg spec for a given class;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1148
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1149
     The parser can be queried for selector, receiver etc.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1150
     Like #parseMethodSpecification:in:, but does not display any error/warning Messages on the transcript."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1151
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1152
    ^ self parseMethodSpecification:aString 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1153
	   in:aClass 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1154
	   ignoreErrors:true 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1155
	   ignoreWarnings:true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1156
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1157
    "Created: 31.10.1995 / 14:37:49 / cg"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1158
!
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1159
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1160
selectorInExpression:aString
47
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1161
    "parse an expression - return the selector. Even malformed expressions
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1162
     (such as missing receiver or missing arg are parsed.
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1163
     Used for the SystemBrowsers implementors/senders query-box initial text.
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1164
     Returns nil if unparsable."
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1165
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1166
    |tree parser|
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1167
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1168
    (aString isNil or:[aString isEmpty]) ifTrue:[^ nil].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1169
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1170
    tree := self withSelf:nil 
451
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1171
                 parseExpression:aString 
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1172
                 notifying:nil 
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1173
                 ignoreErrors:true 
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1174
                 ignoreWarnings:true. 
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1175
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1176
    "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1177
     special: take the expression of the right side, if its an
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1178
     assignment or return
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1179
    "
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1180
    (tree notNil and:[tree ~~ #Error]) ifTrue:[
451
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1181
        (tree isAssignment 
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1182
        or:[tree isReturnNode]) ifTrue:[
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1183
            tree expression isMessage ifTrue:[
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1184
                tree := tree expression
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1185
            ]
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1186
        ].
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1187
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1188
        tree isMessage ifTrue:[
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1189
            ^ tree selector
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1190
        ].
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1191
    ].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1192
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1193
    "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1194
     mhmh, try expression without receiver
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1195
    "
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1196
    parser := self for:(ReadStream on:aString).
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1197
    parser ignoreErrors.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1198
    parser nextToken.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1199
    ^ parser degeneratedKeywordExpressionForSelector
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1200
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1201
"
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1202
    Parser selectorInExpression:'foo at:1 put:(5 * bar)'     
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1203
    Parser selectorInExpression:'(foo at:1) at:1'           
47
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1204
    Parser selectorInExpression:'a + 4'                     
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1205
    Parser selectorInExpression:'a negated'                 
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1206
    Parser selectorInExpression:'at:1 put:5'            
47
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1207
    Parser selectorInExpression:'at:1 put:'            
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1208
    Parser selectorInExpression:'a at:1 put:5'            
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1209
    Parser selectorInExpression:'a at:1 put:'            
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1210
    Parser selectorInExpression:'a := foo at:1 put:5'    
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1211
"
451
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1212
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1213
    "Modified: 17.12.1996 / 12:12:47 / cg"
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1214
!
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1215
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1216
withSelf:anObject parseExpression:aString notifying:someOne 
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1217
    "parse aString as an expression with self set to anObject;
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1218
     Return the parseTree (if ok), nil (for an empty string 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1219
     or comment only ) or #Error (syntactic error).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1220
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1221
     Errors and warnings are forwarded to someOne (usually some
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1222
     codeView) which can highlight it and show a popup box."
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1223
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1224
    ^ self withSelf:anObject 
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1225
	   parseExpression:aString 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1226
	   notifying:someOne 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1227
	   ignoreErrors:false 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1228
	   ignoreWarnings:false 
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1229
!
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1230
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1231
withSelf:anObject parseExpression:aString notifying:someOne ignoreErrors:ignore
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1232
    "parse aString as an expression with self set to anObject;
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1233
     Return the parseTree (if ok), nil (for an empty string 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1234
     or comment only ) or #Error (syntactic error).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1235
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1236
     Errors and warnings are forwarded to someOne (usually some
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1237
     codeView) which can highlight it and show a popup box."
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1238
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1239
    ^ self withSelf:anObject
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1240
	   parseExpression:aString 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1241
	   notifying:someOne 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1242
	   ignoreErrors:ignore 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1243
	   ignoreWarnings:ignore 
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1244
!
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1245
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1246
withSelf:anObject parseExpression:aString notifying:someOne ignoreErrors:ignoreErrors ignoreWarnings:ignoreWarnings
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1247
    "parse aString as an expression with self set to anObject;
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1248
     Return the parseTree (if ok), nil (for an empty string 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1249
     or comment only ) or #Error (syntactic error).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1250
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1251
     Errors and warnings are forwarded to someOne (usually some
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1252
     codeView) which can highlight it and show a popup box,
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1253
     iff ignoreErrors/ignoreWarnings is true respectively."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1254
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1255
    |parser tree token|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1256
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1257
    aString isNil ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1258
    parser := self for:(ReadStream on:aString).
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1259
    parser setSelf:anObject.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1260
    parser notifying:someOne.
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1261
    ignoreErrors ifTrue:[parser ignoreErrors].
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1262
    ignoreWarnings ifTrue:[parser ignoreWarnings].
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1263
    token := parser nextToken.
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1264
    (token == $^) ifTrue:[
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1265
        parser nextToken.
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1266
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1267
    tree := parser expression.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1268
    (parser errorFlag or:[tree == #Error]) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1269
    ^ tree
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1270
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1271
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  1272
!Parser class methodsFor:'unparsing'!
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1273
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1274
methodSpecificationForSelector:aSelector
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1275
    "given a selector such as #foo:bar:, return a string that could
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1276
     serve as a methods specification source code.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1277
     To be used for code generators"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1278
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1279
    ^ self methodSpecificationForSelector:aSelector 
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1280
				 argNames:#('arg1' 'arg2' 'arg3' 'arg4' 'arg5' 'arg6'
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1281
					    'arg7' 'arg8' 'arg9' 'arg10' 'arg11' 'arg12'
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1282
					    'arg13' 'arg14' 'arg15')
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1283
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1284
     Parser methodSpecificationForSelector:#foo:bar:   
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1285
     Parser methodSpecificationForSelector:#+       
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1286
     Parser methodSpecificationForSelector:#negated   
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1287
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1288
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1289
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1290
methodSpecificationForSelector:aSelector argNames:argNames
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1291
    "given a selector such as #foo:bar:, return a string that could
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1292
     serve as a methods specification source code.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1293
     To be used for code generators"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1294
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1295
    |s nargs parts|
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1296
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1297
    s := WriteStream on:String new.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1298
    nargs := aSelector numArgs.
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1299
    nargs == 0 ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1300
	s nextPutAll:aSelector
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1301
    ] ifFalse:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1302
	parts := aSelector partsIfSelector.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1303
	1 to:nargs do:[:i |
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1304
	    s nextPutAll:(parts at:i); space;
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1305
	      nextPutAll:(argNames at:i); space.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1306
	]
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1307
    ].
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1308
    ^ s contents
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1309
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1310
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1311
     Parser methodSpecificationForSelector:#foo:bar: argNames:#('one' 'two' 'three')  
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1312
     Parser methodSpecificationForSelector:#+ argNames:#('one')  
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1313
     Parser methodSpecificationForSelector:#negated   
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1314
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1315
! !
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1316
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1317
!Parser methodsFor:'ST-80 compatibility'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1318
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1319
evaluate:aString in:aClass to:to notifying:aRequestor ifFail:failBlock
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1320
    |parseTree value|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1321
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1322
    aString isNil ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1323
    self initializeFor:(ReadStream on:aString).
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1324
    self setClassToCompileFor:aClass.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1325
    selfValue := nil.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1326
    requestor := aRequestor.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1327
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1328
    self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1329
    parseTree := self parseMethodBody.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1330
    (errorFlag or:[tree == #Error]) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1331
    parseTree notNil ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1332
	self evalExitBlock:[:value | ^ failBlock value].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1333
	value := parseTree evaluate
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1334
    ].
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1335
    self release.
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1336
    ^ value
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1337
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1338
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1339
!Parser methodsFor:'accessing'!
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1340
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1341
correctedSource
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1342
    ^ correctedSource
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1343
!
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1344
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1345
errorFlag
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1346
    "return true if there where any errors (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1347
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1348
    ^ errorFlag
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1349
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1350
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1351
evalExitBlock:aBlock
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1352
    "when evaluating a return expression, this block is evaluated"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1353
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1354
    evalExitBlock := aBlock
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1355
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1356
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1357
getNameSpace
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1358
    "retrieve the nameSpace, as found in a Namespace directive"
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1359
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1360
    ^ currentNamespace
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1361
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1362
    "Modified: 8.11.1996 / 13:45:35 / cg"
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1363
!
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1364
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1365
primitiveNumber
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1366
    "return the ST-80 style primitiveNumber or nil (valid after parsing)"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1367
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1368
    ^ primitiveNr
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1369
!
97
claus
parents: 96
diff changeset
  1370
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1371
primitiveResources
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1372
    "return the ST-80 style resource info or nil (valid after parsing)."
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1373
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1374
    ^ primitiveResource
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1375
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1376
    "Created: 29.5.1996 / 17:28:00 / cg"
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1377
!
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1378
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1379
release
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1380
    methodArgs := methodVars := tree := selfNode := superNode := nil.
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1381
    super release.
90
claus
parents: 87
diff changeset
  1382
!
claus
parents: 87
diff changeset
  1383
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1384
setNameSpace:aNameSpaceName
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1385
    currentNamespace := Namespace fullName:aNameSpaceName
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1386
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1387
    "Modified: 8.11.1996 / 13:43:14 / cg"
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1388
!
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1389
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1390
targetClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1391
    ^ classToCompileFor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1392
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1393
90
claus
parents: 87
diff changeset
  1394
targetClass:aClass
117
claus
parents: 103
diff changeset
  1395
    classToCompileFor := aClass
claus
parents: 103
diff changeset
  1396
!
claus
parents: 103
diff changeset
  1397
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1398
tree
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1399
    "return the parsetree"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1400
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1401
    ^tree
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1402
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1403
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1404
tree:aTree
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1405
    "private: set the tree - for internal use only"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1406
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1407
    tree := aTree
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1408
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1409
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1410
!Parser methodsFor:'error correction'!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1411
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1412
askForCorrection:aString fromList:aList
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1413
    "launch a selection box, which allows user to enter correction.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1414
     return newString or nil (for abort)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1415
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1416
    |box|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1417
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1418
    "in systems without widgets ..."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1419
    ListSelectionBox isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1420
	^ self confirm:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1421
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1422
    box := ListSelectionBox title:aString.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1423
    box initialText:(aList at:1).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1424
    box list:aList.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1425
    box okText:'correct'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1426
    box action:[:aString | ^ aString].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1427
    box showAtPointer.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1428
    ^ nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1429
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1430
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1431
correctByDeleting
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1432
    "correct (by deleting token) if user wants to;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1433
     return #Error if there was no correction;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1434
     nil if there was one." 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1435
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1436
    (self confirm:'confirm deleting') ifFalse:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1437
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1438
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1439
     tell requestor (i.e. CodeView) about the change
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1440
     this will update what the requestor shows.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1441
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1442
    requestor deleteSelection.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1443
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1444
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1445
     get the updated source-string 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1446
     which is needed, when we eventually install the new method
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1447
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1448
    correctedSource := requestor currentSourceCode.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1449
    ^ nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1450
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1451
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1452
correctSelector:aSelectorString message:msg position:pos1 to:pos2
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1453
    "notify error and correct if user wants to;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1454
     return #Error if there was no correction 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1455
     or a ParseNode as returned by variable"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1456
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1457
    |correctIt suggestedNames newSelector|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1458
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1459
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1460
     sorry, but I cannot handle keywords with more than one-part
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1461
     currently (too much work - maybe Ill do it later when everything else works :-)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1462
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1463
    (aSelectorString occurrencesOf:$:) > 1 ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1464
	self warning:msg position:pos1 to:pos2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1465
	^ aSelectorString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1466
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1467
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1468
    correctIt := self correctableError:msg position:pos1 to:pos2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1469
    correctIt ifFalse:[^ aSelectorString].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1470
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1471
    suggestedNames := self findBestSelectorsFor:aSelectorString.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1472
    suggestedNames notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1473
	newSelector := self askForCorrection:'correct selector to: ' fromList:suggestedNames.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1474
	newSelector isNil ifTrue:[^ aSelectorString].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1475
    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1476
	self information:'no good correction found'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1477
	^ aSelectorString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1478
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1479
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1480
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1481
     tell requestor (i.e. CodeView) about the change
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1482
     this will update what the requestor shows.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1483
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1484
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1485
    requestor replaceSelectionBy:newSelector keepCursor:false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1486
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1487
     get the updated source-string 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1488
     which is needed, when we eventually install the new method
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1489
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1490
    correctedSource := requestor currentSourceCode.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1491
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1492
    ^ newSelector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1493
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1494
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1495
correctVariable
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1496
    "notify error and correct if user wants to;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1497
     return #Error if there was no correction 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1498
     or a ParseNode as returned by variable"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1499
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1500
    |correctIt varName suggestedNames newName pos1 pos2|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1501
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1502
    pos1 := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1503
    varName := tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1504
    pos2 := pos1 + varName size - 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1505
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1506
"OLD:
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1507
    (varName at:1) isLowercase ifTrue:[
223
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1508
        correctIt := self undefError:varName position:pos1 to:pos2.
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1509
        correctIt ifFalse:[^ #Error]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1510
    ] ifFalse:[
223
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1511
        correctIt := self warning:(varName , ' is undefined') position:pos1 to:pos2.
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1512
        correctIt ifFalse:[
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1513
            ^ VariableNode type:#GlobalVariable name:(varName asSymbol)
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1514
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1515
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1516
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1517
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1518
    correctIt := self undefError:varName position:pos1 to:pos2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1519
    correctIt ifFalse:[
223
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1520
        (varName at:1) isLowercase ifTrue:[
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1521
"/            self warning:'no automatic global declaration of lowercase variables' position:pos1 to:pos2.
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1522
            ^ #Error
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1523
        ] ifFalse:[
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1524
            ^ VariableNode type:#GlobalVariable name:(varName asSymbol)
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1525
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1526
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1527
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1528
    suggestedNames := self findBestVariablesFor:varName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1529
    suggestedNames notNil ifTrue:[
223
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1530
        newName := self askForCorrection:'correct variable to: ' fromList:suggestedNames.
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1531
        newName isNil ifTrue:[^ #Error].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1532
"
223
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1533
        newName := suggestedNames at:1.
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1534
        (self confirm:('confirm correction to: ' , newName)) ifFalse:[^ #Error]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1535
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1536
    ] ifFalse:[
223
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1537
        self information:'no good correction found'.
f1c6e860d495 removed a warning (its annoying)
Claus Gittinger <cg@exept.de>
parents: 221
diff changeset
  1538
        ^ #Error
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1539
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1540
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1541
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1542
     tell requestor (i.e. CodeView) about the change
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1543
     this will update what the requestor shows.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1544
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1545
    requestor replaceSelectionBy:newName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1546
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1547
     get the updated source-string 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1548
     which is needed, when we eventually install the new method
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1549
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1550
    correctedSource := requestor currentSourceCode.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1551
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1552
    "redo parse with new value"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1553
    tokenName := newName.
454
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  1554
    ^ self variableOrError:tokenName
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  1555
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  1556
    "Modified: 19.12.1996 / 22:30:13 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1557
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1558
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1559
findBestSelectorsFor:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1560
    "collect known selectors with their spelling distances to aString;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1561
     return the 10 best suggestions"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1562
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1563
    |info n|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1564
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1565
    info := SortedCollection new.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1566
    info sortBlock:[:a :b | a value > b value].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1567
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1568
    n := 0.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1569
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1570
    Symbol allInstancesDo:[:sym |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1571
	|dist|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1572
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1573
	dist := aString spellAgainst:sym.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1574
	dist > 20 ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1575
	    info add:(sym -> dist).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1576
	    n := n + 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1577
	    n > 10 ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1578
		info removeLast.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1579
	    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1580
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1581
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1582
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1583
    ^ info asOrderedCollection collect:[:a | a key]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1584
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1585
    "Time millisecondsToRun:[Parser new findBestSelectorsFor:'foo']"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1586
    "Parser new findBestSelectorsFor:'findBestSel'"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1587
    "Parser new findBestSelectorsFor:'fildBestSelectrFr'"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1588
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1589
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1590
findBestVariablesFor:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1591
    "collect known variables with their spelling distances to aString;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1592
     return the 10 best suggestions"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1593
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1594
    |names dists searchBlock args vars globalVarName "aClass className baseClass" 
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1595
     n instVarNames|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1596
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1597
    names := OrderedCollection new.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1598
    dists := OrderedCollection new.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1599
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1600
    "block arguments"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1601
    searchBlock := currentBlock.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1602
    [searchBlock notNil] whileTrue:[
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1603
        args := searchBlock arguments.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1604
        args notNil ifTrue:[
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1605
            args do:[:aBlockArg |
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1606
                names add:(aBlockArg name).
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1607
                dists add:(aString spellAgainst: "levenshteinTo:"(aBlockArg name))
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1608
            ]
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1609
        ].
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1610
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1611
        vars := searchBlock variables.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1612
        vars notNil ifTrue:[
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1613
            vars do:[:aBlockVar |
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1614
                names add:(aBlockVar name).
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1615
                dists add:(aString spellAgainst: "levenshteinTo:"(aBlockVar name))
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1616
            ]
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1617
        ].
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1618
        searchBlock := searchBlock home
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1619
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1620
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1621
    "method-variables"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1622
    methodVars notNil ifTrue:[
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1623
        methodVarNames do:[:methodVarName |
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1624
            names add:methodVarName.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1625
            dists add:(aString spellAgainst: "levenshteinTo:"methodVarName)
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1626
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1627
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1628
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1629
    "method-arguments"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1630
    methodArgs notNil ifTrue:[
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1631
        methodArgNames do:[:methodArgName |
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1632
            names add:methodArgName.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1633
            dists add:(aString spellAgainst: "levenshteinTo:"methodArgName)
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1634
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1635
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1636
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1637
    "instance-variables"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1638
    classToCompileFor notNil ifTrue:[
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1639
        self classesInstVarNames do:[:instVarName |
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1640
            names add:instVarName.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1641
            dists add:(aString spellAgainst: "levenshteinTo:"instVarName)
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1642
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1643
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1644
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1645
    "class-variables"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1646
    classToCompileFor notNil ifTrue:[
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1647
        self classesClassVarNames do:[:classVarName |
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1648
            names add:classVarName.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1649
            dists add:(aString spellAgainst: "levenshteinTo:"classVarName)
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1650
        ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1651
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1652
"/        aClass := classToCompileFor.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1653
"/        aClass isMeta ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1654
"/            className := aClass name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1655
"/            className := className copyWithoutLast:5.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1656
"/            baseClass := Smalltalk at:(className asSymbol).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1657
"/            baseClass notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1658
"/                aClass := baseClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1659
"/            ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1660
"/        ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1661
"/        [aClass notNil] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1662
"/            (aClass classVarNames) do:[:classVarName |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1663
"/                names add:classVarName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1664
"/                dists add:(aString spellAgainst: "levenshteinTo:"classVarName)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1665
"/            ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1666
"/            aClass := aClass superclass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1667
"/        ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1668
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1669
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1670
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1671
    "globals"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1672
    Smalltalk keysDo:[:aKey |
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1673
        globalVarName := aKey asString.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1674
        "only compare strings where length is about right"
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1675
        ((globalVarName size - aString size) abs < 3) ifTrue:[
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1676
            names add:globalVarName.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1677
            dists add:(aString spellAgainst: "levenshteinTo:"globalVarName)
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1678
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1679
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1680
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1681
    "misc"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1682
    #('self' 'super' 'nil' 'thisContext') do:[:name |
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1683
        names add:name.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1684
        dists add:(aString spellAgainst: "levenshteinTo:"name)
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1685
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1686
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1687
    (dists size ~~ 0) ifTrue:[
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1688
        dists sortWith:names.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1689
        dists := dists reverse.             
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1690
        names := names reverse.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1691
        n := names size min:10.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1692
        names := names copyTo:n.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1693
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1694
        "if it starts with a lower case character, add all local & instvar names"
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1695
        (aString at:1) isLowercase ifTrue:[
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1696
            methodVarNames size > 0 ifTrue:[
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1697
                names add:'---- method locals ----'.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1698
                methodVarNames asSortedCollection do:[:methodVarName |
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1699
                    names add:methodVarName.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1700
                ].
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1701
            ].
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1702
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1703
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1704
            methodArgs size > 0 ifTrue:[
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1705
                names add:'---- method arguments ----'.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1706
                methodArgNames asSortedCollection do:[:methodArgName |
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1707
                    names add:methodArgName.
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1708
                ]
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1709
            ].
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1710
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1711
            instVarNames := OrderedCollection new.
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1712
            self classesInstVarNames asSortedCollection do:[:instVarName |
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1713
                (instVarNames includes:instVarName) ifFalse:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1714
                    instVarNames add:instVarName.
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1715
                ]
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1716
            ].
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1717
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1718
            instVarNames size > 0 ifTrue:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1719
                names add:'---- instance variables ----'.
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1720
                instVarNames do:[:instVarName |
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1721
                    (names includes:instVarName) ifFalse:[
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1722
                        names add:instVarName.
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1723
                    ]
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1724
                ]
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1725
            ]
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1726
        ].
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1727
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1728
        ^ names
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1729
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1730
    ^ nil
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  1731
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1732
    "Modified: 11.1.1997 / 21:28:28 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1733
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1734
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1735
selectorCheck:aSelectorString for:receiver position:pos1 to:pos2
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1736
    "just a quick check: if a selector is totally unknown as a symbol, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1737
     or has the same name as a variable or cannot be understood.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1738
     Simple, but catches many typos"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1739
466
7f136821cdd2 dont check selector of messages to autoloaded privateClasses.
Claus Gittinger <cg@exept.de>
parents: 463
diff changeset
  1740
    |ok err sym rec superCls names recType|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1741
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1742
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1743
     if compiling lazy, or errors are to be ignored, or there
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1744
     is no requestor, do not check
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1745
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1746
    (LazyCompilation == true) ifTrue:[^ aSelectorString].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1747
    (ignoreErrors or:[ignoreWarnings]) ifTrue:[^ aSelectorString].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1748
    (requestor isNil or:[requestor isStream]) ifTrue:[^ aSelectorString].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1749
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1750
    err := ' is currently nowhere implemented'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1751
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1752
     if the selector has the name of a variable, use another message
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1753
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1754
    ((methodVarNames notNil and:[methodVarNames includes:aSelectorString])
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1755
    or:[(methodArgNames notNil and:[methodArgNames includes:aSelectorString])
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  1756
    or:[((names := self classesInstVarNames) notNil and:[names includes:aSelectorString])
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  1757
    or:[((names := self classesClassInstVarNames) notNil and:[names includes:aSelectorString])
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  1758
    or:[((names := self classesClassVarNames) notNil and:[names includes:aSelectorString])]]]]) ifTrue:[
273
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1759
        err := ' is currently nowhere implemented ..
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1760
.. but a variable with that name is defined. 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1761
143
1008a91b7bc1 better warning message
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  1762
Missing ''.'' after the previous expression 
1008a91b7bc1 better warning message
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  1763
or missing keyword/receiver before that word ?'.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1764
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1765
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1766
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1767
     check if the selector is known at all
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1768
     - if not, it cannot be understood
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1769
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1770
    ok := false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1771
    sym := aSelectorString asSymbolIfInterned.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1772
    sym notNil ifTrue:[
273
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1773
        ok := true.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1774
        receiver notNil ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1775
            "
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1776
             if the receiver is a constant, we can check if it responds
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1777
             to this selector
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1778
            "
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1779
            receiver isConstant ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1780
                rec := receiver evaluate.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1781
                ok := rec respondsTo:sym.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1782
                err := ' will not be understood here (message to ' , rec classNameWithArticle , ')'.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1783
            ] ifFalse:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1784
                receiver isBlock ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1785
                    "/ this should help with typos, sending #ifTrue to blocks ...
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1786
                    ok := [] respondsTo:sym.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1787
                    err := ' will not be understood here (message to a Block)'.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1788
                ] ifFalse:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1789
                    "
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1790
                     if the receiver is a global, we check it too ...
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1791
                    "
466
7f136821cdd2 dont check selector of messages to autoloaded privateClasses.
Claus Gittinger <cg@exept.de>
parents: 463
diff changeset
  1792
                    (((recType := receiver type) == #GlobalVariable)
7f136821cdd2 dont check selector of messages to autoloaded privateClasses.
Claus Gittinger <cg@exept.de>
parents: 463
diff changeset
  1793
                    or:[recType == #PrivateClass]) ifTrue:[
7f136821cdd2 dont check selector of messages to autoloaded privateClasses.
Claus Gittinger <cg@exept.de>
parents: 463
diff changeset
  1794
                        "/ dont check autoloaded classes 
7f136821cdd2 dont check selector of messages to autoloaded privateClasses.
Claus Gittinger <cg@exept.de>
parents: 463
diff changeset
  1795
                        "/ - it may work after loading"
273
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1796
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1797
                        rec := receiver evaluate. 
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1798
                        (rec notNil 
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1799
                         and:[rec isBehavior
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1800
                         and:[rec isLoaded not]]) ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1801
                            ^ aSelectorString
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1802
                        ].
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1803
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1804
                        ok := rec respondsTo:sym.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1805
                        ok ifFalse:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1806
                            "if it implements #doesNotUnderstand, assume its ok"
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1807
                            (rec class implements:#doesNotUnderstand:) ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1808
                                ^ aSelectorString
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1809
                            ]
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1810
                        ].
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1811
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1812
                        err := ' may not be understood here (is currently ' , rec classNameWithArticle , ')'.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1813
                    ] ifFalse:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1814
                        "if its a super send, we can do more checking"
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1815
                        receiver isSuper ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1816
                            receiver isHere ifFalse:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1817
                                ((superCls := classToCompileFor superclass) notNil
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1818
                                and:[(superCls whichClassIncludesSelector:sym) isNil]) ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1819
                                    err := ' is currently not implemented in any superclass'.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1820
                                    ok := false
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1821
                                ]
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1822
                            ] ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1823
                                (classToCompileFor whichClassIncludesSelector:sym) isNil ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1824
                                    err := ' is currently not implemented in this class'.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1825
                                    ok := false
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1826
                                ]
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1827
                            ]
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1828
                        ].
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1829
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1830
                        (receiver isUnaryMessage
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1831
                        and:[receiver selector == #class
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1832
                        and:[receiver receiver type == #Self]]) ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1833
                            "its a message to self class - can check this too ..."
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1834
                            (classToCompileFor class whichClassIncludesSelector:sym) isNil ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1835
                                ok := false.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1836
                                classToCompileFor allSubclasses do:[:subclass |
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1837
                                    (subclass class implements:sym) ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1838
                                        ok := true
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1839
                                    ]
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1840
                                ].
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1841
                                err := ' is currently not implemented in the class'.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1842
                            ]
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1843
                        ]
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1844
                    ]
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1845
                ]
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1846
            ]
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1847
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1848
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1849
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1850
    ok ifFalse:[
423
67352df6730c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  1851
        (receiver notNil
466
7f136821cdd2 dont check selector of messages to autoloaded privateClasses.
Claus Gittinger <cg@exept.de>
parents: 463
diff changeset
  1852
        and:[((recType := receiver type) == #GlobalVariable)
7f136821cdd2 dont check selector of messages to autoloaded privateClasses.
Claus Gittinger <cg@exept.de>
parents: 463
diff changeset
  1853
             or:[recType == #PrivateClass]]) ifTrue:[
7f136821cdd2 dont check selector of messages to autoloaded privateClasses.
Claus Gittinger <cg@exept.de>
parents: 463
diff changeset
  1854
            "/ dont check autoloaded classes 
7f136821cdd2 dont check selector of messages to autoloaded privateClasses.
Claus Gittinger <cg@exept.de>
parents: 463
diff changeset
  1855
            "/ - it may work after loading
423
67352df6730c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  1856
67352df6730c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  1857
            rec := receiver evaluate. 
67352df6730c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  1858
            (rec notNil 
67352df6730c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  1859
             and:[rec isBehavior
67352df6730c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  1860
             and:[rec isLoaded not]]) ifTrue:[
67352df6730c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  1861
                ^ aSelectorString
67352df6730c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  1862
            ].
67352df6730c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 421
diff changeset
  1863
        ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1864
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1865
"OLD: "
341
ae5393a6d63a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 337
diff changeset
  1866
        self warning:('#' , aSelectorString , '\\' , err) withCRs position:pos1 to:pos2
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1867
" "   
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1868
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1869
"NEW:    - not finished - need more interfaces
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1870
   (currently produces warning output on Transcript while filing in
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1871
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1872
273
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1873
        ^ self correctSelector:aSelectorString message:('#' , aSelectorString , err) position:pos1 to:pos2
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1874
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1875
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1876
    ^ aSelectorString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1877
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1878
    "Modified: 5.9.1995 / 17:02:11 / claus"
466
7f136821cdd2 dont check selector of messages to autoloaded privateClasses.
Claus Gittinger <cg@exept.de>
parents: 463
diff changeset
  1879
    "Modified: 5.1.1997 / 16:50:36 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1880
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1881
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1882
!Parser methodsFor:'error handling'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1883
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1884
correctableError:message position:pos1 to:pos2
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1885
    "report an error which can be corrected by compiler -
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1886
     return true if correction is wanted"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1887
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1888
    |correctIt|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1889
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1890
    requestor isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1891
	self showErrorMessage:message position:pos1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1892
	correctIt := false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1893
    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1894
	correctIt := requestor correctableError:message position:pos1 to:pos2 from:self
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1895
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1896
    correctIt ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1897
	exitBlock notNil ifTrue:[exitBlock value]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1898
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1899
    ^ correctIt
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1900
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1901
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1902
exitWith:something
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1903
    "this is the longjump out of evaluation via a return expression"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1904
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1905
    evalExitBlock value:something
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1906
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1907
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1908
identifierExpectedIn:what
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1909
    |msg|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1910
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1911
    (#(True False Self Nil Super ThisContext) includes:tokenType) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1912
	msg := 'Reserved keyword in ' 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1913
    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1914
	msg := 'Identifier expected in ' 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1915
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1916
    self syntaxError:msg , what position:tokenPosition to:source position - 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1917
    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1918
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1919
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1920
parseError:aMessage
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1921
    "report an error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1922
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1923
    ^ self parseError:aMessage position:tokenPosition to:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1924
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1925
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1926
parseError:aMessage position:position
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1927
    "report an error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1928
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1929
    ^ self parseError:aMessage position:position to:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1930
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1931
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1932
parseError:aMessage position:position to:endPos
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1933
    "report an error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1934
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1935
    |m|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1936
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1937
    errorFlag := true.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1938
    m := 'Error: ' , aMessage.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1939
    self notifyError:m position:position to:endPos.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1940
    exitBlock notNil ifTrue:[exitBlock value].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1941
    ^ false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1942
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1943
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1944
showErrorMessage:aMessage position:pos
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1945
    "redefined since parser can give more detailed info about
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1946
     the class & selector where the error occured."
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1947
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  1948
    |text|
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  1949
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1950
    ignoreErrors ifFalse:[
273
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1951
        Smalltalk silentLoading == true ifFalse:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1952
            Transcript show:(pos printString).
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1953
            Transcript show:' '.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1954
            selector notNil ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1955
                Transcript show:aMessage.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1956
                classToCompileFor notNil ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1957
                    text := ' in ' , classToCompileFor name , '>>' , selector
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1958
                ] ifFalse:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1959
                    text := ' in ' , selector
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1960
                ]
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1961
            ] ifFalse:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1962
                classToCompileFor notNil ifTrue:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1963
                    text := aMessage , ' (' , classToCompileFor name , ')'
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1964
                ] ifFalse:[
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1965
                    text := aMessage
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1966
                ]
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1967
            ].
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1968
            Transcript showCR:text.
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1969
        ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1970
    ]
273
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1971
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1972
    "Modified: 18.5.1996 / 15:44:15 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1973
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1974
171
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1975
showErrorMessageForClass:aClass
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1976
"/        compiler parseError:'syntax error'.
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1977
    Transcript show:'    '.
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1978
    aClass notNil ifTrue:[
273
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1979
        Transcript show:aClass name , '>>'
171
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1980
    ].
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1981
    selector notNil ifTrue:[
273
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1982
        Transcript show:(selector)
171
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1983
    ].
273
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1984
    Transcript showCR:' -> Error'.
171
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1985
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1986
    "Created: 13.12.1995 / 20:24:34 / cg"
273
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  1987
    "Modified: 18.5.1996 / 15:44:17 / cg"
171
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1988
!
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1989
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1990
undefError:aName position:pos1 to:pos2
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1991
    "report an undefined variable error - return true, if it should be
86
claus
parents: 85
diff changeset
  1992
     corrected. If not corrected, only one warning is made per undefined
claus
parents: 85
diff changeset
  1993
     variable."
claus
parents: 85
diff changeset
  1994
429
ffc4e2ab5581 cleanup
Claus Gittinger <cg@exept.de>
parents: 427
diff changeset
  1995
    |doCorrect msg idx|
86
claus
parents: 85
diff changeset
  1996
claus
parents: 85
diff changeset
  1997
    "
claus
parents: 85
diff changeset
  1998
     alredy warned about this one ?
claus
parents: 85
diff changeset
  1999
    "
claus
parents: 85
diff changeset
  2000
    warnedUndefVars notNil ifTrue:[
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2001
        (warnedUndefVars includes:aName) ifTrue:[
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2002
            "already warned about this one"
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2003
            ^ false
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2004
        ].
86
claus
parents: 85
diff changeset
  2005
    ].
claus
parents: 85
diff changeset
  2006
131
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  2007
"/    (classToCompileFor notNil 
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  2008
"/    and:[classToCompileFor superclass notNil
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  2009
"/    and:[classToCompileFor superclass instanceVariableString isNil]]) ifTrue:[
132
5be56a5e90b7 added methods for silent parsing (parseMethod / parseMethodSpec)
Claus Gittinger <cg@exept.de>
parents: 131
diff changeset
  2010
"/      self showErrorMessage:'Error: no source information (instvar names)' position:pos1.
5be56a5e90b7 added methods for silent parsing (parseMethod / parseMethodSpec)
Claus Gittinger <cg@exept.de>
parents: 131
diff changeset
  2011
"/      ^ false
131
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  2012
"/    ].
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  2013
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  2014
    (requestor isNil or:[requestor isStream]) ifTrue:[
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2015
        aName first isUppercase ifFalse:[
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2016
            self showErrorMessage:('Error: ' , aName , ' is undefined') position:pos1.
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2017
        ].
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2018
        doCorrect := false.
86
claus
parents: 85
diff changeset
  2019
    ] ifFalse:[
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2020
        "
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2021
         ask requestor for correct/continue/abort ...
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2022
         it is supposed to raise abort or return true/false.
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2023
         True return means that correction is wanted.
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2024
        "
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2025
        msg := 'Warning: ' , aName , ' is undefined'.
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2026
        classToCompileFor notNil ifTrue:[
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2027
            "is it an instance-variable marked inaccessable ?"
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2028
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2029
            idx := (self classesInstVarNames) indexOf:(aName , '*') startingAt:1.
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2030
            idx ~~ 0 ifTrue:[
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2031
                msg := 'Warning: ' , aName , ' is a hidden instvar (not accessable from ST-code)'.
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2032
            ]
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2033
        ].
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2034
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2035
        doCorrect := self correctableError:msg position:pos1 to:pos2
86
claus
parents: 85
diff changeset
  2036
    ].
claus
parents: 85
diff changeset
  2037
claus
parents: 85
diff changeset
  2038
    doCorrect ifFalse:[
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2039
        warnedUndefVars isNil ifTrue:[
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2040
            warnedUndefVars := Set new.
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2041
        ].
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2042
        warnedUndefVars add:aName.
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  2043
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2044
86
claus
parents: 85
diff changeset
  2045
    ^ doCorrect
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2046
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2047
    "Modified: 14.10.1996 / 18:00:50 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2048
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2049
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2050
!Parser methodsFor:'parsing'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2051
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2052
array
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2053
    |arr elements elem pos1|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2054
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2055
    pos1 := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2056
    elements := OrderedCollection new:20.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2057
    [tokenType ~~ $) ] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2058
	elem := self arrayConstant.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2059
	(elem == #Error) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2060
	    (tokenType == #EOF) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2061
		self syntaxError:'unterminated array-constant; '')'' expected' 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2062
			position:pos1 to:tokenPosition
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2063
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2064
	    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2065
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2066
	elements add:elem.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2067
	self nextToken
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2068
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2069
    arr := Array withAll:elements.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2070
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2071
    (ArraysAreImmutable and:[ImmutableArray notNil]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2072
	arr changeClassTo:ImmutableArray.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2073
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2074
    ^ arr
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2075
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2076
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2077
arrayConstant
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2078
    (tokenType == #String) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2079
	^ tokenValue
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2080
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2081
    (tokenType == #Nil) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2082
	^ nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2083
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2084
    (tokenType == #Integer) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2085
	^ tokenValue
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2086
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2087
    (tokenType == #Character) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2088
	^ tokenValue
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2089
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2090
    (tokenType == #Float) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2091
	^ tokenValue
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2092
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2093
    (tokenType == #True) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2094
	^ true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2095
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2096
    (tokenType == #False) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2097
	^ false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2098
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2099
    (tokenType == #Error) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2100
	^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2101
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2102
    (tokenType == #BinaryOperator) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2103
	^ tokenName asSymbol
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2104
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2105
    (tokenType == #Keyword) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2106
	^ tokenName asSymbol
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2107
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2108
    (tokenType == #Identifier) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2109
	^ tokenName asSymbol
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2110
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2111
    (tokenType == $() ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2112
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2113
	^ self array
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2114
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2115
    (tokenType == $[) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2116
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2117
	^ self byteArray
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2118
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2119
    (tokenType == #Symbol) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2120
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2121
	self warning:'no # for symbols within array-constants'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2122
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2123
	^ tokenValue
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2124
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2125
    (tokenType == #HashLeftParen) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2126
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2127
	self warning:'no # for arrays within array-constants'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2128
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2129
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2130
	^ self array
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2131
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2132
    (tokenType == #HashLeftBrack) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2133
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2134
	self warning:'no # for arrays within array-constants'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2135
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2136
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2137
	^ self byteArray
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2138
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2139
    (tokenType == #EOF) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2140
	"just for the better error-hilight; let caller handle error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2141
	^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2142
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2143
    self syntaxError:('error in array-constant; ' 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2144
		      , tokenType printString 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2145
		      , ' unexpected').
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2146
    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2147
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2148
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2149
binaryExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2150
    "parse a binary-expression; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2151
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2152
    |receiver arg sel pos try lno note|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2153
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2154
    receiver := self unaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2155
    (receiver == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2156
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2157
    "special kludge: since Scanner cannot know if -digit is a binary
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2158
     expression or a negative constant, handle cases here"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2159
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2160
    [(tokenType == #BinaryOperator) or:[(tokenType == $|)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2161
     or:[(tokenType == #Integer) and:[tokenValue < 0]]]] whileTrue:[
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2162
        pos := tokenPosition.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2163
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2164
        lno := tokenLineNr.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2165
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2166
        "kludge here: bar and minus are not scanned as binop "
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2167
        (tokenType == $|) ifTrue:[
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2168
            sel := '|'.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2169
            self nextToken
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2170
        ] ifFalse:[
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2171
            (tokenType == #BinaryOperator) ifTrue:[
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2172
                sel := self selectorCheck:tokenName for:receiver position:tokenPosition to:(tokenPosition + tokenName size - 1).
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2173
                self nextToken
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2174
            ] ifFalse:[
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2175
                sel := '-'.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2176
                tokenValue := tokenValue negated
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2177
            ]
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2178
        ].
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2179
        arg := self unaryExpression.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2180
        (arg == #Error) ifTrue:[^ #Error].
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  2181
        try := BinaryNode receiver:receiver selector:sel arg:arg fold:foldConstants.
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2182
        (try isMemberOf:String) ifTrue:[
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2183
            self parseError:try position:pos to:tokenPosition.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2184
            errorFlag := false. "ok, user wants it - so he'll get it"
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  2185
            receiver := BinaryNode receiver:receiver selector:sel arg:arg fold:nil.
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2186
            note := receiver plausibilityCheck.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2187
            note notNil ifTrue:[
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2188
                self warning:note position:pos to:tokenPosition
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2189
            ].
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2190
        ] ifFalse:[
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2191
            receiver := try
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2192
        ].
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2193
        receiver lineNumber:lno.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2194
        parseForCode ifFalse:[self rememberSelectorUsed:sel].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2195
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2196
    ^ receiver
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2197
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  2198
    "Modified: 21.3.1996 / 16:09:04 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2199
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2200
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2201
block
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2202
    "parse a block; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2203
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2204
    |node args argNames arg pos lno|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2205
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2206
    lno := tokenLineNr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2207
    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2208
    (tokenType == $: ) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2209
	[tokenType == $:] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2210
	    pos := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2211
	    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2212
	    (tokenType == #Identifier) ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2213
		^ self identifierExpectedIn:'block-arg declaration'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2214
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2215
	    arg := Variable name:tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2216
	    args isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2217
		args := Array with:arg.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2218
		argNames := Array with:tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2219
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2220
		(argNames includes:tokenName) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2221
		    self syntaxError:'redefinition of ''' , tokenName , ''' in argument list.'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2222
			    position:tokenPosition 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2223
				   to:(tokenPosition + tokenName size - 1)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2224
		].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2225
		args := args copyWith:arg.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2226
		argNames := argNames copyWith:tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2227
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2228
	    self nextToken
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2229
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2230
	(tokenType ~~ $| ) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2231
	    "ST-80 allows [:arg ]"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2232
	    (tokenType == $] ) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2233
		node := BlockNode arguments:args home:currentBlock variables:nil.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2234
		node lineNumber:lno.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2235
		^ node
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2236
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2237
	    self syntaxError:'| expected after block-arg declaration'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2238
	    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2239
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2240
	self nextToken
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2241
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2242
    node := self blockBody:args.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2243
    (node notNil and:[node ~~ #Error]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2244
	node lineNumber:lno.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2245
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2246
    ^ node
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2247
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2248
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2249
blockBody:args
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2250
    "parse a blocks body; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2251
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2252
    |stats node var vars lno names|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2253
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2254
    lno := tokenLineNr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2255
    (tokenType == $| ) ifTrue:[
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2256
        self nextToken.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2257
        [tokenType == $|] whileFalse:[
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2258
            (tokenType == #Identifier) ifFalse:[
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2259
                ^ self identifierExpectedIn:'block-var declaration'
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2260
            ].
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2261
            var := Variable name:tokenName.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2262
            vars isNil ifTrue:[
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2263
                vars := Array with:var.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2264
                names := Array with:tokenName
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2265
            ] ifFalse:[
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2266
                (names includes:tokenName) ifTrue:[
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2267
                    self parseError:'redefinition of ''' , tokenName , ''' in local variables'
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2268
                           position:tokenPosition to:tokenPosition + tokenName size -1.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2269
                ] ifFalse:[
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2270
                    vars := vars copyWith:var.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2271
                    names := names copyWith:tokenName
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2272
                ]
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2273
            ].
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2274
            self nextToken.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2275
        ].
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2276
        self nextToken
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2277
    ].
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2278
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2279
    node := BlockNode arguments:args home:currentBlock variables:vars.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2280
    node lineNumber:lno.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2281
    currentBlock := node.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2282
    stats := self blockStatementList.
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2283
    lineNumberInfo == #full ifTrue:[
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2284
        node endLineNumber:tokenLineNr
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2285
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2286
    node statements:stats.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2287
    currentBlock := node home.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2288
    (stats == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2289
    ^ node
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2290
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  2291
    "Modified: 21.10.1996 / 14:48:56 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2292
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2293
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2294
blockExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2295
    "parse a blockExpression; return a node-tree, nil or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2296
     Not used by ST/X's parser, but added for ST-80 compatibility."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2297
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2298
    tokenType ~~ $[ ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2299
	self syntaxError:'[ expected'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2300
	^ #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2301
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2302
    ^ self block
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2303
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2304
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2305
blockStatementList
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2306
    "parse a blocks statementlist; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2307
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2308
    |thisStatement prevStatement firstStatement|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2309
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2310
    (tokenType == $] ) ifTrue:[^ nil].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2311
    thisStatement := self statement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2312
    (thisStatement == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2313
    firstStatement := thisStatement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2314
    [tokenType == $] ] whileFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2315
	(tokenType == $.) ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2316
	    ((tokenType == #EOF) or:[tokenType == $)]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2317
		self syntaxError:'missing '']'' in block'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2318
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2319
		self syntaxError:'missing ''.'' in block'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2320
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2321
	    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2322
	] ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2323
	    prevStatement := thisStatement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2324
	    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2325
	    tokenType == $] ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2326
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2327
		*** I had a warning here (since it was not defined
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2328
		*** in the blue-book; but PD-code contains a lot of
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2329
		*** code with periods at the end so that the warnings
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2330
		*** became annoying
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2331
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2332
		self warning:'period after last statement in block'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2333
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2334
		^ firstStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2335
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2336
	    thisStatement := self statement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2337
	    (thisStatement == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2338
	    prevStatement nextStatement:thisStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2339
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2340
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2341
    ^ firstStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2342
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2343
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2344
byteArray
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2345
    "started with ST-80 R4 - allow byteArray constants as #[ ... ]"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2346
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2347
    |bytes index limit newArray elem pos1 pos2|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2348
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2349
    pos1 := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2350
    bytes := ByteArray uninitializedNew:5000.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2351
    index := 0. limit := 5000.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2352
    [tokenType ~~ $] ] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2353
	pos2 := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2354
	"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2355
	 this is not good programming style, but speeds up
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2356
	 reading of huge byte arrays (i.e. stored Images ...)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2357
	"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2358
	(tokenType == #Integer) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2359
	    elem := tokenValue
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2360
	] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2361
	    elem := self arrayConstant.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2362
	    (elem == #Error) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2363
		(tokenType == #EOF) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2364
		    self syntaxError:'unterminated bytearray-constant; '']'' expected' 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2365
			    position:pos1 to:tokenPosition
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2366
		].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2367
		^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2368
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2369
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2370
	((elem isMemberOf:SmallInteger) and:[elem between:0 and:255]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2371
	    index := index + 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2372
	    bytes at:index put:elem.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2373
	    index == limit ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2374
		newArray := ByteArray uninitializedNew:(limit * 2).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2375
		newArray replaceFrom:1 to:limit with:bytes startingAt:1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2376
		limit := limit * 2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2377
		bytes := newArray
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2378
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2379
	] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2380
	    self parseError:'invalid ByteArray element' position:pos2 to:tokenPosition - 1
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2381
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2382
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2383
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2384
    newArray := ByteArray uninitializedNew:index.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2385
    newArray replaceFrom:1 to:index with:bytes startingAt:1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2386
    ^ newArray
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2387
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2388
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2389
degeneratedKeywordExpressionForSelector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2390
    "parse a keyword-expression without receiver - for the selector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2391
     only. return the selector or nil. This is not used in normal parsing,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2392
     but instead to extract the selector from a code fragment.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2393
     (for example, the system browsers implementors-function uses this)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2394
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2395
    |sel arg rec|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2396
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2397
    (tokenType == #Keyword) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2398
	sel := tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2399
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2400
	arg := self binaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2401
	(arg == #Error) ifTrue:[^ sel].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2402
	[tokenType == #Keyword] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2403
	    sel := sel , tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2404
	    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2405
	    arg := self binaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2406
	    (arg == #Error) ifTrue:[^ sel].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2407
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2408
	^ sel
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2409
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2410
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2411
    (rec := self primary) ~~ #Error ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2412
	sel := self degeneratedKeywordExpressionForSelector.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2413
	sel isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2414
	    rec isMessage ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2415
		sel := rec selector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2416
	    ] ifFalse:[        
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2417
		rec isAssignment ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2418
		    rec expression isMessage ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2419
			sel := rec expression selector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2420
		    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2421
		]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2422
	    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2423
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2424
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2425
    ^ sel
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2426
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2427
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2428
expression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2429
    "parse a cascade-expression; return a node-tree, nil or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2430
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2431
     expression ::= keywordExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2432
		    | keywordExpression cascade
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2433
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2434
     cascade ::= ';' expressionSendPart
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2435
		 | cascade ';' expressionSendPart
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2436
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2437
     expressionSendPart ::= { KEYWORD binaryExpression }
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2438
			    | BINARYOPERATOR unaryExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2439
			    | IDENTIFIER
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2440
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2441
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2442
    |receiver arg sel args pos pos2 lno|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2443
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2444
    pos := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2445
    receiver := self keywordExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2446
    (receiver == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2447
    (tokenType == $;) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2448
	[tokenType == $;] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2449
	    receiver isMessage ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2450
		self syntaxError:'left side of cascade must be a message expression'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2451
			position:pos to:tokenPosition
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2452
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2453
	    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2454
	    (tokenType == #Identifier) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2455
		sel := self selectorCheck:tokenName for:receiver position:tokenPosition to:(tokenPosition + tokenName size - 1).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2456
		receiver := CascadeNode receiver:receiver selector:sel.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2457
		receiver lineNumber:tokenLineNr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2458
		parseForCode ifFalse:[self rememberSelectorUsed:sel].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2459
		self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2460
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2461
		(tokenType == #BinaryOperator) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2462
		    sel := self selectorCheck:tokenName for:receiver position:tokenPosition to:(tokenPosition + tokenName size - 1).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2463
		    lno := tokenLineNr. 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2464
		    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2465
		    arg := self unaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2466
		    (arg == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2467
		    receiver := CascadeNode receiver:receiver selector:sel arg:arg.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2468
		    receiver lineNumber:lno.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2469
		    parseForCode ifFalse:[self rememberSelectorUsed:sel].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2470
		] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2471
		    (tokenType == #Keyword) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2472
			pos := tokenPosition. 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2473
			lno := tokenLineNr. 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2474
			sel := tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2475
			self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2476
			arg := self binaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2477
			(arg == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2478
			args := Array with:arg.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2479
			[tokenType == #Keyword] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2480
			    sel := sel , tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2481
			    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2482
			    arg := self binaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2483
			    (arg == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2484
			    args := args copyWith:arg.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2485
			    pos2 := tokenPosition
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2486
			].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2487
			sel := self selectorCheck:sel for:receiver position:pos to:pos2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2488
			receiver := CascadeNode receiver:receiver selector:sel args:args.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2489
			receiver lineNumber:lno.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2490
			parseForCode ifFalse:[self rememberSelectorUsed:sel].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2491
		    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2492
			(tokenType == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2493
			self syntaxError:('invalid cascade; ' , tokenType printString , ' unexpected')
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2494
				position:tokenPosition to:source position - 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2495
			^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2496
		    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2497
		]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2498
	    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2499
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2500
144
f28ab79db022 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 143
diff changeset
  2501
	"obscure (unspecified ?) if selector follows; Question:
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2502
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2503
	is
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2504
		'expr sel1; sel2 sel3'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2505
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2506
	to be parsed as: 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2507
		(t := expr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2508
		 t sel1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2509
		 t sel2) sel3
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2510
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2511
	 or:
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2512
		(t := expr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2513
		 t sel1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2514
		 t sel2 sel3)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2515
	"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2516
	((tokenType == #Identifier) 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2517
	 or:[(tokenType == #BinaryOperator)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2518
	     or:[tokenType == #Keyword]]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2519
	    self syntaxError:'ambigous cascade - please group using ( ...)'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2520
		    position:tokenPosition to:source position - 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2521
	    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2522
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2523
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2524
    ^ receiver
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2525
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2526
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2527
inWhichClassIsClassInstVar:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2528
    "search class-chain for the class-instance variable named aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2529
     - return the class or nil if not found"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2530
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2531
    |aClass|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2532
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2533
    aClass := classToCompileFor.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2534
    [aClass notNil] whileTrue:[
463
2ecdbf7140da oops - fixed inWhichClassIsClassInstVar; again ?
Claus Gittinger <cg@exept.de>
parents: 461
diff changeset
  2535
        (aClass class instVarNames includes:aString) ifTrue:[ ^ aClass].
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2536
        aClass := aClass superclass
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2537
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2538
    ^ nil
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  2539
463
2ecdbf7140da oops - fixed inWhichClassIsClassInstVar; again ?
Claus Gittinger <cg@exept.de>
parents: 461
diff changeset
  2540
    "Modified: 4.1.1997 / 14:42:15 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2541
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2542
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2543
inWhichClassIsClassVar:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2544
    "search class-chain for the classvariable named aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2545
     - return the class or nil if not found"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2546
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2547
    |aClass className baseClass|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2548
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2549
    aClass := classToCompileFor.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2550
    aClass isMeta ifTrue:[
463
2ecdbf7140da oops - fixed inWhichClassIsClassInstVar; again ?
Claus Gittinger <cg@exept.de>
parents: 461
diff changeset
  2551
        className := aClass name copyWithoutLast:6.
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  2552
        baseClass := Smalltalk at:(className asSymbol).
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  2553
        baseClass notNil ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  2554
            aClass := baseClass
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  2555
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2556
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2557
    ^ aClass whichClassDefinesClassVar:aString
463
2ecdbf7140da oops - fixed inWhichClassIsClassInstVar; again ?
Claus Gittinger <cg@exept.de>
parents: 461
diff changeset
  2558
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2559
"/    [aClass notNil] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2560
"/        (aClass classVarNames includes:aString) ifTrue:[ ^ aClass].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2561
"/        aClass := aClass superclass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2562
"/    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2563
"/    ^ nil
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  2564
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  2565
    "Modified: 17.6.1996 / 17:18:41 / stefan"
463
2ecdbf7140da oops - fixed inWhichClassIsClassInstVar; again ?
Claus Gittinger <cg@exept.de>
parents: 461
diff changeset
  2566
    "Modified: 4.1.1997 / 15:57:11 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2567
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2568
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2569
keywordExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2570
    "parse a keyword-expression; return a node-tree, nil or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2571
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2572
     keywordExpression ::= binaryexpression
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2573
                           | { KEYWORD-PART binaryExpression }
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2574
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2575
312
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2576
    |receiver sel arg args posR1 posR2 pos1 pos2 try lno note|
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2577
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2578
    posR1 := tokenPosition.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2579
    receiver := self binaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2580
    (receiver == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2581
    (tokenType == #Keyword) ifTrue:[
312
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2582
        pos1 := posR2 := tokenPosition.
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2583
        pos2 := tokenPosition + tokenName size - 1.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2584
        sel := tokenName.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2585
        lno := tokenLineNr.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2586
        self nextToken.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2587
        arg := self binaryExpression.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2588
        (arg == #Error) ifTrue:[^ #Error].
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2589
        args := Array with:arg.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2590
        [tokenType == #Keyword] whileTrue:[
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2591
            sel := sel , tokenName.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2592
            pos2 := tokenPosition + tokenName size - 1.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2593
            self nextToken.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2594
            arg := self binaryExpression.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2595
            (arg == #Error) ifTrue:[^ #Error].
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2596
            args := args copyWith:arg.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2597
        ].
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2598
        sel := self selectorCheck:sel for:receiver position:pos1 to:pos2.
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  2599
        try := MessageNode receiver:receiver selector:sel args:args fold:foldConstants.
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2600
        (try isMemberOf:String) ifTrue:[
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2601
            self parseError:try position:pos1 to:pos2.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2602
            errorFlag := false. "ok, user wants it - so he'll get it"
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  2603
            receiver := MessageNode receiver:receiver selector:sel args:args fold:nil.
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2604
            note := receiver plausibilityCheck.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2605
            note notNil ifTrue:[
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2606
                self warning:note position:pos1 to:pos2
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2607
            ].
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2608
        ] ifFalse:[
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2609
            receiver := try
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2610
        ].
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2611
        receiver lineNumber:lno.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2612
        parseForCode ifFalse:[self rememberSelectorUsed:sel].
312
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2613
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2614
        (sel = #and: 
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2615
        or:[sel = #or:]) ifTrue:[
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2616
            receiver arg1 isBlock ifFalse:[
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2617
                self warnCommonMistake:'(possible common mistake) missing block brackets ?'
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2618
                              position:pos2+1 to:tokenPosition-1
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2619
            ]
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2620
        ].
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2621
        (sel = #whileTrue: 
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2622
        or:[sel = #whileFalse:]) ifTrue:[
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2623
            receiver receiver isBlock ifFalse:[
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2624
                self warnCommonMistake:'(possible common mistake) missing block brackets ?'
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2625
                              position:posR1 to:posR2-1
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2626
            ]
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2627
        ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2628
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2629
    ^ receiver
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  2630
312
55593a43e07c warn about common mistakes:
Claus Gittinger <cg@exept.de>
parents: 290
diff changeset
  2631
    "Modified: 18.7.1996 / 10:33:26 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2632
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2633
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2634
parseMethod
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2635
    "parse a method.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2636
     Return the parseTree or #Error.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2637
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2638
     method ::= methodSpec methodBody
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2639
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2640
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2641
    |parseTree|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2642
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2643
"/    self nextToken.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2644
    (self parseMethodSpec == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2645
    parseTree := self parseMethodBody.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2646
    (parseTree == #Error) ifFalse:[
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2647
        self tree:parseTree
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2648
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2649
    ^ parseTree
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2650
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2651
    "Modified: 20.4.1996 / 20:09:26 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2652
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2653
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2654
parseMethodBody
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2655
    "parse a methods body (locals & statements). 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2656
     No more tokens may follow.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2657
     Return a node-tree, or #Error
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2658
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2659
     methodBody ::= '<' st80Primitive '>' #EOF
202
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2660
		    | '<' st80Primitive '>' methodBodyVarSpec statementList #EOF
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2661
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2662
    "
429
ffc4e2ab5581 cleanup
Claus Gittinger <cg@exept.de>
parents: 427
diff changeset
  2663
    |stats|
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2664
79
26f81a94a6ea *** empty log message ***
claus
parents: 78
diff changeset
  2665
    stats := self parseMethodBodyOrEmpty.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2666
    (stats == #Error) ifFalse:[
202
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2667
	(tokenType ~~ #EOF) ifTrue:[
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2668
	    "/ just for the nicer error message
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2669
	    (#(Self Nil True False Super Here) includes:tokenType) ifTrue:[
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2670
		self parseError:tokenName , ' unexpected (missing ''.'' before ' , tokenName , ' ?)' 
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2671
		       position:tokenPosition to:(tokenPosition + tokenName size - 1)
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2672
	    ] ifFalse:[
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2673
		self parseError:(tokenType printString , ' unexpected (missing ''.'' or selector before it ?)') 
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2674
		     position:tokenPosition to:source position-1.
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2675
	    ].
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2676
	    ^#Error
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2677
	]
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2678
    ].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2679
    ^ stats
165
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
  2680
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
  2681
    "Modified: 12.12.1995 / 19:40:58 / cg"
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2682
!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2683
79
26f81a94a6ea *** empty log message ***
claus
parents: 78
diff changeset
  2684
parseMethodBodyOrEmpty
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2685
    "parse a methods body (locals & statements);
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2686
     return  a node-tree, nil or #Error. 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2687
     empty (or comment only) input is accepted and returns nil.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2688
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2689
     methodBodyOrNil ::= '<' st80Primitive '>'
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2690
                         | '<' st80Primitive '>' methodBodyVarSpec statementList
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2691
                         | <empty>
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2692
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2693
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2694
    |stats|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2695
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2696
    (self parseMethodBodyVarSpec == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2697
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2698
    (tokenType ~~ #EOF) ifTrue:[
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2699
        stats := self statementList
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2700
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2701
    ^ stats
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2702
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2703
    "Modified: 27.4.1996 / 16:57:56 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2704
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2705
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2706
parseMethodBodyVarSpec
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2707
    "parse a methods local variable specification, handling
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2708
     possible primitive or resourceSpecs.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2709
     . 
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2710
     Leave spec of locals in methodLocals as a side effect.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2711
     Return #Error or nil.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2712
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2713
     methodBodyVarSpec ::= '|' { IDENTIFIER } '|'
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2714
                            | <empty>
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2715
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2716
53
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2717
    |var pos msg|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2718
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2719
    ((tokenType == #BinaryOperator) and:[tokenName = '<']) ifTrue:[
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2720
        self parsePrimitiveOrResourceSpecOrEmpty.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2721
    ].
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2722
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2723
    (tokenType == $|) ifTrue:[
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2724
        "memorize position for declaration in correction"
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2725
        localVarDefPosition := tokenPosition.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2726
        self nextToken.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2727
        pos := tokenPosition.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2728
        [tokenType == #Identifier] whileTrue:[
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2729
            var := Variable name:tokenName.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2730
            methodVars isNil ifTrue:[
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2731
                methodVars := Array with:var.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2732
                methodVarNames := Array with:tokenName
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2733
            ] ifFalse:[
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2734
                (methodVarNames includes:tokenName) ifTrue:[
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2735
                    self parseError:'redefinition of ''' , tokenName , ''' in local variables'
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2736
                           position:tokenPosition to:tokenPosition + tokenName size -1.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2737
                ] ifFalse:[
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2738
                    methodVars := methodVars copyWith:var.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2739
                    methodVarNames := methodVarNames copyWith:tokenName
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2740
                ]
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2741
            ].
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2742
            methodArgNames notNil ifTrue:[
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2743
                (methodArgNames includes:tokenName) ifTrue:[
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2744
                    self warning:'local variable ''' , tokenName , ''' hides argument.'
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2745
                        position:tokenPosition 
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2746
                              to:(tokenPosition + tokenName size - 1)
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2747
                ]
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2748
            ].
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2749
            self nextToken.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2750
            pos := tokenPosition
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2751
        ].
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2752
        (tokenType ~~ $|) ifTrue:[
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2753
            (#(True False Self Nil Super ThisContext) includes:tokenType) ifTrue:[
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2754
                msg := 'Reserved keyword in local var declaration' 
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2755
            ] ifFalse:[
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2756
                msg := 'Identifier or | expected in local var declaration' 
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2757
            ].
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2758
            self syntaxError:msg position:tokenPosition to:source position-1.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2759
            ^ #Error
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2760
        ].
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2761
        self nextToken
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2762
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2763
    ^ nil
139
65eaf1a009f5 warn if method local hides method arg
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  2764
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2765
    "Modified: 27.4.1996 / 16:58:28 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2766
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2767
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2768
parseMethodSpec
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2769
    "parse a methods selector & arg specification;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2770
     Set selector and methodArgs in the receiver as a side effect.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2771
     Return the receiver or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2772
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2773
     methodSpec ::= { KEYWORD IDENTIFIER }
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2774
                    | binaryOperator IDENTIFIER
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2775
                    | IDENTIFIER
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2776
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2777
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2778
    |var|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2779
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2780
    tokenType isNil ifTrue:[
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2781
        self nextToken.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2782
    ].
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2783
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2784
    (tokenType == #Keyword) ifTrue:[
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2785
        selector := ''.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2786
        [tokenType == #Keyword] whileTrue:[
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2787
            selector := selector , tokenName.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2788
            self nextToken.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2789
            (tokenType ~~ #Identifier) ifTrue:[^ #Error].
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2790
            var := Variable name:tokenName.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2791
            methodArgs isNil ifTrue:[
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2792
                methodArgs := Array with:var.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2793
                methodArgNames := Array with:tokenName
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2794
            ] ifFalse:[
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2795
                (methodArgNames includes:tokenName) ifTrue:[
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2796
                    self syntaxError:'redefinition of ''' , tokenName , ''' in argument list.'
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2797
                            position:tokenPosition 
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2798
                                  to:(tokenPosition + tokenName size - 1)
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2799
                ].
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2800
                methodArgs := methodArgs copyWith:var.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2801
                methodArgNames := methodArgNames copyWith:tokenName
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2802
            ].
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2803
            self nextToken
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2804
        ].
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2805
        selector := selector asSymbol.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2806
        ^ self
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2807
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2808
    (tokenType == #Identifier) ifTrue:[
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2809
        selector := tokenName asSymbol.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2810
        self nextToken.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2811
        ^ self
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2812
    ].
461
1d24cc165fac oops - did not allow | as method-selector
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
  2813
1d24cc165fac oops - did not allow | as method-selector
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
  2814
    "/ special handling for |, which is also a lexical token
1d24cc165fac oops - did not allow | as method-selector
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
  2815
    tokenType == $| ifTrue:[
1d24cc165fac oops - did not allow | as method-selector
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
  2816
        tokenType := #BinaryOperator.
1d24cc165fac oops - did not allow | as method-selector
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
  2817
        tokenName := '|'
1d24cc165fac oops - did not allow | as method-selector
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
  2818
    ].
1d24cc165fac oops - did not allow | as method-selector
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
  2819
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2820
    (tokenType == #BinaryOperator) ifTrue:[
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2821
        selector := tokenName asSymbol.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2822
        self nextToken.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2823
        (tokenType ~~ #Identifier) ifTrue:[^ #Error].
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2824
        var := Variable name:tokenName.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2825
"/      methodArgs isNil ifTrue:[
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2826
            methodArgs := Array with:var.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2827
            methodArgNames := Array with:tokenName.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2828
"/      ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2829
"/          methodArgs := methodArgs copyWith:var.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2830
"/          methodArgNames := methodArgNames copyWith:tokenName
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2831
"/      ].
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2832
        self nextToken.
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2833
        ^ self
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2834
    ].
461
1d24cc165fac oops - did not allow | as method-selector
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
  2835
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2836
    ^ #Error
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  2837
461
1d24cc165fac oops - did not allow | as method-selector
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
  2838
    "Modified: 3.1.1997 / 16:18:04 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2839
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2840
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2841
parsePrimitiveOrResourceSpecOrEmpty
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2842
    "parse a methods primitive or resource spec"
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2843
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2844
    |pos wmsg primNr|
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2845
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2846
    [(tokenType == #BinaryOperator) and:[tokenName = '<']] whileTrue:[
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2847
        "/ an ST-80 primitive or resourceSpec - parsed but ignored
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2848
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2849
        pos := tokenPosition.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2850
        self nextToken.
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2851
        primNr := self parseST80Primitive.
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2852
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2853
        (primNr == #Error) ifTrue:[^ #Error].
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2854
        wmsg := nil.
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2855
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2856
        primNr < 0 ifTrue:[
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2857
            WarnST80Directives == true ifTrue:[
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2858
                wmsg := 'ST-80 directive ignored'.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2859
            ].
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2860
        ] ifFalse:[
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2861
            primitiveNr := primNr.
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2862
            wmsg := 'ST-80 primitive may not work'
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2863
        ].
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2864
        wmsg notNil ifTrue:[self warning:wmsg position:pos]
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2865
    ].
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2866
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2867
    "Created: 27.4.1996 / 16:55:55 / cg"
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2868
    "Modified: 29.5.1996 / 17:25:52 / cg"
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2869
!
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  2870
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2871
parseST80Primitive
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2872
    "parse an ST-80 type primitive as '< primitive: nr >';
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2873
     return primitive number or #Error.
97
claus
parents: 96
diff changeset
  2874
     Also, ST-80 style resource specs are parsed; the result is
claus
parents: 96
diff changeset
  2875
     left (as side effect) in primitiveResource. 
claus
parents: 96
diff changeset
  2876
     (maybe someone else knows what to do with it ...)
claus
parents: 96
diff changeset
  2877
claus
parents: 96
diff changeset
  2878
     Well, as we now have this mechanism, I'll use it to mark methods which
claus
parents: 96
diff changeset
  2879
     do keyboard processing ... <resource: keyboard ( keys )>
claus
parents: 96
diff changeset
  2880
     For faster finding of used keyboard accelerators.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2881
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2882
     st80Primitive ::= 'primitive:' INTEGER
97
claus
parents: 96
diff changeset
  2883
     st80Primitive ::= 'resource:' SYMBOL       - ignored; leave SYMBOL in primitiveResource
claus
parents: 96
diff changeset
  2884
     st80Primitive ::= 'resource:' SYMBOL (...) - ignored; leave (SYMBOL (...)) in primitiveResource
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2885
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2886
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2887
    |primNumber keys resource resourceValue|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2888
60
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2889
    (tokenType ~~ #Keyword) ifTrue:[
221
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2890
        self parseError:'bad primitive definition (keyword expected)'.
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2891
        ^ #Error
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2892
    ].
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2893
60
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2894
    (tokenName = 'primitive:') ifTrue:[
221
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2895
        self nextToken.
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2896
        (tokenType == #Integer) ifFalse:[
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2897
            self parseError:'primitive number expected'.
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2898
            ^ #Error
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2899
        ].
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2900
        primitiveNr notNil ifTrue:[
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2901
            self parseError:'only one primitive spec allowed'.
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2902
            primNumber := -1.
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2903
        ] ifFalse:[
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2904
            primNumber := tokenValue.
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2905
        ].
221
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2906
        self nextToken.
60
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2907
    ] ifFalse:[
221
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2908
        (tokenName = 'resource:') ifTrue:[
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2909
            self nextToken.
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2910
            (tokenType ~~ #Symbol) ifTrue:[
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2911
                self parseError:'symbol expected'.
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2912
                ^ #Error
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2913
            ].
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2914
            primNumber := -1.
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2915
            resource := tokenValue.
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2916
            resourceValue := true.
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2917
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2918
            self nextToken.
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2919
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2920
            tokenType == $( ifTrue:[
221
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2921
                self nextToken.
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2922
                keys := OrderedCollection new.
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2923
                [tokenType == $) ] whileFalse:[
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2924
                    keys add:tokenValue.
221
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2925
                    self nextToken.
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2926
                ].
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2927
                resourceValue := keys.
221
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2928
                self nextToken.
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2929
            ].
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2930
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2931
            primitiveResource isNil ifTrue:[
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2932
                primitiveResource := IdentityDictionary new.
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2933
            ].
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2934
            primitiveResource at:(resource asSymbol) put:resourceValue.
221
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2935
        ] ifFalse:[
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2936
            self parseError:'unrecognized primitive'.
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2937
            ^ #Error
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2938
        ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2939
    ].
97
claus
parents: 96
diff changeset
  2940
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2941
    ((tokenType == #BinaryOperator) and:[tokenName = '>']) ifFalse:[
221
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2942
        self parseError:'bad primitive definition (> expected)'.
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2943
        ^ #Error
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2944
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2945
    self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2946
    ^ primNumber
221
35b92bf6d9ef parse style-resource directive
Claus Gittinger <cg@exept.de>
parents: 212
diff changeset
  2947
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  2948
    "Modified: 29.5.1996 / 17:24:09 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2949
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2950
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2951
primary
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2952
    "parse a primary-expression; return a node-tree, nil or #Error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2953
390
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  2954
    |val var expr pos name t cls nameSpace nameSpaceGlobal globlName lnr node
432
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  2955
     pos2 eMsg|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2956
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2957
    pos := tokenPosition.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2958
    (tokenType == #Self) ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2959
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2960
        ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2961
            self parseError:'assignment to self' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2962
            ^ #Error
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2963
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2964
        selfNode isNil ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2965
            selfNode := SelfNode value:selfValue
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2966
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2967
        ^ selfNode
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2968
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2969
    (tokenType == #Identifier) ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2970
        "
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2971
         must check for variable first, to be backward compatible
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2972
         with other smalltalks. 
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2973
        "
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2974
        tokenName = 'here' ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2975
            self variableOrError == #Error ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2976
                tokenType := #Here.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2977
                warnSTXHereExtensionUsed ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2978
                    self warning:'here-sends are a nonstandard feature of ST/X' 
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2979
                         position:pos to:pos+3.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2980
                    "
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2981
                     only warn once
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2982
                    "
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2983
                    warnSTXHereExtensionUsed := false
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2984
                ]
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2985
            ]
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2986
        ]
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2987
    ].
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2988
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2989
    (tokenType == #Identifier) ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2990
        name := tokenName.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2991
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2992
        var := self variable.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2993
        (var == #Error) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2994
            errorFlag := true
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2995
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  2996
        self nextToken.
359
5c3718455360 support for nameSpaces (space::name)
Claus Gittinger <cg@exept.de>
parents: 358
diff changeset
  2997
5c3718455360 support for nameSpaces (space::name)
Claus Gittinger <cg@exept.de>
parents: 358
diff changeset
  2998
        (tokenType == #'::') ifTrue:[
363
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  2999
            globlName := name.
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3000
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3001
            "is it in a namespace ?"
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3002
            nameSpace := self findNameSpaceWith:globlName.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3003
            nameSpace notNil ifTrue:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3004
                globlName := nameSpace name , '::' , globlName
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3005
            ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3006
363
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3007
            [tokenType == #'::'] whileTrue:[
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3008
                nameSpace := globlName.
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3009
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3010
                self nextToken.
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3011
                (tokenType == #Identifier) ifTrue:[
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3012
                    ignoreWarnings ifFalse:[
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3013
                        warnSTXNameSpaceUse ifTrue:[
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3014
                            self warning:'nameSpaces are a nonstandard feature of ST/X' 
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3015
                                 position:pos to:(source position).
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3016
                            "
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3017
                             only warn once
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3018
                            "
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3019
                            warnSTXNameSpaceUse := false
359
5c3718455360 support for nameSpaces (space::name)
Claus Gittinger <cg@exept.de>
parents: 358
diff changeset
  3020
                        ]
5c3718455360 support for nameSpaces (space::name)
Claus Gittinger <cg@exept.de>
parents: 358
diff changeset
  3021
                    ].
363
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3022
                    name := tokenName.
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3023
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3024
                    globlName := (nameSpace , '::' , name).
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3025
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3026
                    nameSpaceGlobal := Smalltalk at:nameSpace asSymbol ifAbsent:nil.
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3027
                    nameSpaceGlobal isNil ifTrue:[
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3028
                        self parseError:('unknown nameSpace: ', nameSpace) position:pos to:tokenPosition-1.
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3029
                        errorFlag := true
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3030
                    ] ifFalse:[
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3031
                        nameSpaceGlobal isNamespace ifTrue:[
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3032
                            "/ for now: only Smalltalk is allowed
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3033
                            nameSpaceGlobal ~~ Smalltalk ifTrue:[
424
9f8ffd4289a4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 423
diff changeset
  3034
"/                                self parseError:('(currently) the only valid nameSpace is `Smalltalk''') position:pos to:tokenPosition-1.
9f8ffd4289a4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 423
diff changeset
  3035
"/                                errorFlag := true
9f8ffd4289a4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 423
diff changeset
  3036
                            ] ifFalse:[
9f8ffd4289a4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 423
diff changeset
  3037
                                globlName := name
363
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3038
                            ].
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3039
                        ] ifFalse:[
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3040
                            nameSpaceGlobal isBehavior ifFalse:[
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3041
                                self parseError:('invalid nameSpace: ' , nameSpace)  position:pos to:tokenPosition-1.
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3042
                                errorFlag := true
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3043
                            ] ifTrue:[
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3044
                                (nameSpaceGlobal privateClassesAt:name asSymbol) isNil ifTrue:[
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3045
                                    self parseError:('no private class: ' , name , ' in class: ' , nameSpace)  position:pos to:tokenPosition-1.                                
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3046
                                    errorFlag := true
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3047
                                ]
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3048
                            ]
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3049
                        ].
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3050
                    ].
fb9565dd2770 parse nested nameSpace access foo::bar::baz
Claus Gittinger <cg@exept.de>
parents: 362
diff changeset
  3051
                    self nextToken.
359
5c3718455360 support for nameSpaces (space::name)
Claus Gittinger <cg@exept.de>
parents: 358
diff changeset
  3052
                ].
5c3718455360 support for nameSpaces (space::name)
Claus Gittinger <cg@exept.de>
parents: 358
diff changeset
  3053
                var := VariableNode
5c3718455360 support for nameSpaces (space::name)
Claus Gittinger <cg@exept.de>
parents: 358
diff changeset
  3054
                     type:#GlobalVariable
362
b2ff93e77a72 allow Smalltalk::name
Claus Gittinger <cg@exept.de>
parents: 361
diff changeset
  3055
                     name:globlName asSymbol.
b2ff93e77a72 allow Smalltalk::name
Claus Gittinger <cg@exept.de>
parents: 361
diff changeset
  3056
                parseForCode ifFalse:[self rememberGlobalUsed:globlName].
359
5c3718455360 support for nameSpaces (space::name)
Claus Gittinger <cg@exept.de>
parents: 358
diff changeset
  3057
            ]
5c3718455360 support for nameSpaces (space::name)
Claus Gittinger <cg@exept.de>
parents: 358
diff changeset
  3058
        ].
5c3718455360 support for nameSpaces (space::name)
Claus Gittinger <cg@exept.de>
parents: 358
diff changeset
  3059
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3060
        ((tokenType == $_) or:[tokenType == #':=']) ifFalse:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3061
            ^ var
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3062
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3063
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3064
        "/ careful: it could already be an implicit self send
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3065
        ImplicitSelfSends ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3066
            var isMessage ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3067
                self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3068
                expr := self expression.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3069
                (errorFlag or:[expr == #Error]) ifTrue:[^ #Error].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3070
                selfNode isNil ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3071
                    selfNode := SelfNode value:selfValue
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3072
                ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3073
                ^ MessageNode receiver:selfNode selector:('implicit_' , name , ':') asSymbol arg:expr.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3074
            ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3075
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3076
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3077
        (var ~~ #Error) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3078
            t := var type.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3079
            (t ~~ #MethodVar) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3080
                (t == #PrivateClass) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3081
                    self parseError:'assignment to private class' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3082
                    errorFlag := true
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3083
                ] ifFalse:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3084
                    (t == #MethodArg) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3085
                        self parseError:'assignment to method argument' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3086
                        errorFlag := true
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3087
                    ] ifFalse:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3088
                        (t == #BlockArg) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3089
                            self parseError:'assignment to block argument' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3090
                            errorFlag := true
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3091
                        ] ifFalse:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3092
                            (t == #InstanceVariable) ifTrue:[
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  3093
                                name := self classesInstVarNames at:(var index).
387
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3094
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3095
                                "/ ca once did this to `name' and wondered what happened to his class ...
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3096
                                "/ (not really a beginners bug, but may happen as a typo or missing local variable;
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3097
                                "/  and is hard to track down later)
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3098
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3099
                                warnCommonMistakes ifTrue:[
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3100
                                    classToCompileFor isMeta ifTrue:[
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3101
                                        (classToCompileFor isSubclassOf:Class) ifTrue:[
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3102
                                            (Class allInstVarNames includes:(var name)) ifTrue:[
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3103
                                                self warning:'assignment to a classInstanceVariable\(see hierarchy of `Class'')' withCRs position:pos to:tokenPosition+1.
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3104
                                            ]
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3105
                                        ]
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3106
                                    ]
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3107
                                ].
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3108
                                parseForCode ifFalse:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3109
                                    modifiedInstVars isNil ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3110
                                        modifiedInstVars := Set new
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3111
                                    ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3112
                                    modifiedInstVars add:name
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3113
                                ]
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3114
                            ] ifFalse:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3115
                                (t == #ClassVariable) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3116
                                    name := var name.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3117
                                    name := name copyFrom:((name indexOf:$:) + 1).
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3118
                                    parseForCode ifFalse:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3119
                                        modifiedClassVars isNil ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3120
                                            modifiedClassVars := Set new
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3121
                                        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3122
                                        modifiedClassVars add:name
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3123
                                    ]
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3124
                                ] ifFalse:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3125
                                    (t == #GlobalVariable) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3126
                                        (cls := Smalltalk classNamed:var name) notNil ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3127
                                            cls name = var name ifTrue:[
387
908ee278cdf5 warn if a classInstVar of the Class-hierarchy is modified.
Claus Gittinger <cg@exept.de>
parents: 385
diff changeset
  3128
                                                self warning:'assignment to global which refers to a class' position:pos to:tokenPosition.
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3129
                                            ]
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3130
                                        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3131
                                        parseForCode ifFalse:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3132
                                            modifiedGlobals isNil ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3133
                                                modifiedGlobals := Set new
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3134
                                            ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3135
                                            modifiedGlobals add:var name
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3136
                                        ]
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3137
                                    ]
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3138
                                ]
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3139
                            ]
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3140
                        ]
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3141
                    ]
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3142
                ]
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3143
            ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3144
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3145
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3146
        lnr := tokenLineNr.
390
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3147
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3148
        self nextToken.
390
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3149
        pos2 := tokenPosition.
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3150
        expr := self expression.
390
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3151
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3152
        "/ a typical beginner error:
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3153
        "/   expr ifTrue:[
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3154
        "/      var := super
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3155
        "/   ] ifFalse:[
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3156
        "/      var := something-else
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3157
        "/   ].
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3158
        "/   var messageSend
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3159
        "/
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3160
        "/   does not what a beginner might think.
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3161
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3162
        warnCommonMistakes ifTrue:[
412
b176a2cf617c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 406
diff changeset
  3163
            (expr ~~ #Error and:[expr isSuper]) ifTrue:[
390
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3164
                self warning:'followup messageSends to `' , var name , ''' will have normal send semantics\(i.e. NO super- or here-sends). Use self to avoid confusion.' withCRs position:pos to:pos2.
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3165
            ].
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3166
        ].
5ba190b979d4 warn about another beginners error
Claus Gittinger <cg@exept.de>
parents: 387
diff changeset
  3167
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3168
        (errorFlag or:[expr == #Error]) ifTrue:[^ #Error].
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3169
        node := AssignmentNode variable:var expression:expr.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3170
        (lineNumberInfo == #full) ifTrue:[node lineNr:lnr].
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3171
        ^ node
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3172
    ].
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  3173
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3174
    ((tokenType == #Integer) 
120
claus
parents: 117
diff changeset
  3175
     or:[(tokenType == #String)
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3176
     or:[(tokenType == #Character) 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3177
     or:[(tokenType == #Float)
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3178
     or:[(tokenType == #Symbol)]]]]) ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3179
        val := ConstantNode type:tokenType value:tokenValue.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3180
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3181
        ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3182
            self parseError:'assignment to a constant' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3183
            ^ #Error
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3184
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3185
        ^ val
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3186
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3187
    (tokenType == #Nil) ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3188
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3189
        ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3190
            self parseError:'assignment to nil' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3191
            ^ #Error
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3192
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3193
        ^ ConstantNode type:#Nil value:nil
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3194
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3195
    (tokenType == #True) ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3196
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3197
        ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3198
            self parseError:'assignment to true' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3199
            ^ #Error
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3200
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3201
        ^ ConstantNode type:#True value:true
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3202
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3203
    (tokenType == #False) ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3204
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3205
        ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3206
            self parseError:'assignment to false' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3207
            ^ #Error
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3208
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3209
        ^ ConstantNode type:#False value:false
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3210
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3211
    (tokenType  == #Super) ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3212
        usesSuper := true.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3213
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3214
        ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3215
            self parseError:'assignment to super' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3216
            ^ #Error
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3217
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3218
        (classToCompileFor isNil or:[classToCompileFor superclass isNil]) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3219
            self warning:'superclass is (currently ?) nil' position:pos to:(pos + 4).
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3220
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3221
        superNode isNil ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3222
            superNode := SuperNode value:selfValue inClass:classToCompileFor
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3223
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3224
        ^ superNode
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3225
    ].
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  3226
    (tokenType  == #Here) ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3227
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3228
        ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3229
            self parseError:'assignment to here' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3230
            ^ #Error
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3231
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3232
        classToCompileFor isNil ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3233
            self warning:'in which class are you ?' position:pos to:(pos + 3).
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3234
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3235
        ^ SuperNode value:selfValue inClass:classToCompileFor here:true
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  3236
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3237
    (tokenType == #ThisContext) ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3238
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3239
        ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3240
            self parseError:'assignment to thisContext' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3241
            ^ #Error
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3242
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3243
        ^ VariableNode type:#ThisContext
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3244
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3245
    (tokenType == #HashLeftParen) ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3246
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3247
        val := self array.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3248
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3249
        ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3250
            self parseError:'assignment to a constant' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3251
            ^ #Error
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3252
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3253
        ^ ConstantNode type:#Array value:val
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3254
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3255
    (tokenType == #HashLeftBrack) ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3256
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3257
        val := self byteArray.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3258
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3259
        ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3260
            self parseError:'assignment to a constant' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3261
            ^ #Error
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3262
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3263
        ^ ConstantNode type:#Array value:val
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3264
    ].
432
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  3265
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3266
    (tokenType == $() ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3267
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3268
        val := self expression.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3269
        (val == #Error) ifTrue:[^ #Error].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3270
        (tokenType ~~ $) ) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3271
            tokenType isCharacter ifTrue:[
432
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  3272
                eMsg := 'missing '')'' (i.e. ''' , tokenType asString , ''' unexpected)'.
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3273
            ] ifFalse:[
432
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  3274
                eMsg := 'missing '')'''.
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3275
            ].
432
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  3276
            self syntaxError:eMsg withCRs position:pos to:tokenPosition.
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3277
            ^ #Error
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3278
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3279
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3280
        ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3281
            self parseError:'invalid assignment' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3282
            ^ #Error
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3283
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3284
        val parenthized:true.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3285
        ^ val
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3286
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3287
    (tokenType == $[ ) ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3288
        val := self block.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3289
        self nextToken.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3290
        ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3291
            self parseError:'invalid assignment' position:pos to:tokenPosition.
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3292
            ^ #Error
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3293
        ].
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3294
        ^ val
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3295
    ].
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  3296
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3297
    (tokenType == #Error) ifTrue:[^ #Error].
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3298
    tokenType isCharacter ifTrue:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3299
        self syntaxError:('error in primary; ' 
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3300
                           , tokenType printString , 
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3301
                           ' unexpected') position:tokenPosition to:tokenPosition
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3302
    ] ifFalse:[
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3303
        (#(BinaryOperator Keyword) includes:tokenType) ifTrue:[
432
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  3304
            eMsg := ('error in primary; ' 
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  3305
                    , tokenType printString , '(' , tokenName , ') ' ,
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  3306
                    ' unexpected')
354
87afbc0db191 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 353
diff changeset
  3307
        ] ifFalse:[
432
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  3308
            eMsg := ('error in primary; ' 
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  3309
                     , tokenType printString ,
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  3310
                     ' unexpected') 
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  3311
        ].
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  3312
        self syntaxError:eMsg
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3313
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3314
    ^ #Error
120
claus
parents: 117
diff changeset
  3315
claus
parents: 117
diff changeset
  3316
    "Created: 13.9.1995 / 12:50:50 / claus"
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3317
    "Modified: 20.12.1996 / 00:03:40 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3318
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3319
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3320
statement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3321
    "parse a statement; return a node-tree or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3322
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3323
     statement ::= '^' expression
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3324
                   | PRIMITIVECODE
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3325
                   | expression
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3326
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3327
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3328
    |expr node lnr|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3329
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3330
    (tokenType == $^) ifTrue:[
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3331
        lnr := tokenLineNr.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3332
        self nextToken.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3333
        expr := self expression.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3334
        (expr == #Error) ifTrue:[^ #Error].
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3335
        node := ReturnNode expression:expr.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3336
        node home:self blockHome:currentBlock.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3337
        (lineNumberInfo == #full) ifTrue:[node lineNr:lnr].
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3338
        ^ node
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3339
    ].
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3340
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3341
    (tokenType == #Primitive) ifTrue:[
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3342
        self nextToken.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3343
        node := PrimitiveNode code:tokenValue.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3344
        node isOptional ifFalse:[
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3345
            hasNonOptionalPrimitiveCode := true
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3346
        ].
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3347
        hasPrimitiveCode := true.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3348
        ^ node
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3349
    ].
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3350
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3351
    (tokenType == #EOF) ifTrue:[
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3352
        self syntaxError:'period after last statement'.
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  3353
        ^ #Error
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3354
    ].
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3355
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3356
    expr := self expression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3357
    (expr == #Error) ifTrue:[^ #Error].
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3358
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3359
"/    classToCompileFor notNil ifTrue:[
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3360
"/        currentBlock isNil ifTrue:[
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3361
"/            expr isPrimary ifTrue:[
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3362
"/                self warning:'useless computation - missing ^ ?'
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3363
"/            ]
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3364
"/        ]
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3365
"/    ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3366
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3367
    node := StatementNode expression:expr.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3368
    (lineNumberInfo == #full) ifTrue:[node lineNr:lnr].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3369
    ^ node
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3370
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3371
    "Modified: 23.10.1996 / 15:05:37 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3372
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3373
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3374
statementList
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3375
    "parse a statementlist; return a node-tree, nil or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3376
     Statements must be separated by periods.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3377
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3378
     statementList ::= <statement>
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3379
		       | <statementList> . <statement>
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3380
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3381
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3382
    |thisStatement prevStatement firstStatement correctIt periodPos|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3383
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3384
    thisStatement := self statement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3385
    (thisStatement == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3386
    firstStatement := thisStatement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3387
    [tokenType == $.] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3388
	periodPos := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3389
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3390
	(tokenType == $]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3391
	    currentBlock isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3392
		self parseError:'block nesting error'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3393
		errorFlag := true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3394
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3395
	    *** I had a warning here (since it was not defined
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3396
	    *** in the blue-book; but PD-code contains a lot of
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3397
	    *** code with periods at the end so that the warnings
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3398
	    *** became annoying
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3399
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3400
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3401
		self warning:'period after last statement' position:periodPos
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3402
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3403
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3404
	    ^ firstStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3405
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3406
	(tokenType == #EOF) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3407
	    currentBlock notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3408
		self parseError:'block nesting error (expected '']'')'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3409
		errorFlag := true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3410
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3411
	    *** I had a warning here (since it was not defined
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3412
	    *** in the blue-book; but PD-code contains a lot of
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3413
	    *** code with periods at the end so that the warnings
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3414
	    *** became annoying
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3415
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3416
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3417
		self warning:'period after last statement' position:periodPos
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3418
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3419
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3420
	    ^ firstStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3421
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3422
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3423
	prevStatement := thisStatement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3424
	prevStatement isReturnNode ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3425
	    self warning:'statements after return' position:tokenPosition
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3426
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3427
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3428
	periodPos := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3429
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3430
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3431
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3432
	((tokenType == $]) or:[tokenType == #EOF]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3433
	    (currentBlock isNil and:[tokenType == $]]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3434
		self parseError:'block nesting error'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3435
		errorFlag := true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3436
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3437
		correctIt := self correctableError:'period after last statement in block'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3438
					  position:periodPos to:(periodPos + 1).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3439
		correctIt ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3440
		    (self correctByDeleting == #Error) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3441
			errorFlag := true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3442
		    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3443
		]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3444
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3445
	    ^ firstStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3446
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3447
	thisStatement := self statement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3448
	(thisStatement == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3449
	prevStatement nextStatement:thisStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3450
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3451
    ^ firstStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3452
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3453
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3454
unaryExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3455
    "parse a unary-expression; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3456
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3457
    |receiver sel pos pos2 try|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3458
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3459
    receiver := self primary.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3460
    (receiver == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3461
    [tokenType == #Identifier] whileTrue:[
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  3462
        pos := tokenPosition.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  3463
        pos2 := pos + tokenName size - 1.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  3464
        sel := self selectorCheck:tokenName for:receiver position:pos to:pos2.
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  3465
        try := UnaryNode receiver:receiver selector:sel fold:foldConstants.
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  3466
        (try isMemberOf:String) ifTrue:[
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  3467
            self parseError:try position:pos to:pos2.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  3468
            errorFlag := false. "ok, user wants it - so he'll get it"
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  3469
            receiver := UnaryNode receiver:receiver selector:sel fold:nil.
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  3470
        ] ifFalse:[
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  3471
            receiver := try
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  3472
        ].
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  3473
        receiver lineNumber:tokenLineNr.
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  3474
        parseForCode ifFalse:[self rememberSelectorUsed:sel].
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  3475
        self nextToken.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3476
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3477
    ^ receiver
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  3478
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  3479
    "Modified: 21.3.1996 / 16:09:11 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3480
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3481
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3482
variable
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3483
    "parse a variable; if undefined, notify error and correct if user wants to"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3484
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3485
    |v|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3486
454
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3487
    v := self variableOrError:tokenName.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3488
    (v == #Error) ifFalse:[^ v].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3489
    v := self correctVariable.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3490
    (v == #Error) ifFalse:[^ v].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3491
    parseForCode ifFalse:[
454
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3492
        self rememberGlobalUsed:tokenName
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3493
    ] ifTrue:[
454
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3494
        tokenName first isLowercase ifTrue:[
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3495
            ImplicitSelfSends ifTrue:[
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3496
                selfNode isNil ifTrue:[
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3497
                    selfNode := SelfNode value:selfValue
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3498
                ].
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3499
                ^ UnaryNode receiver:selfNode selector:('implicit_' , tokenName) asSymbol.
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3500
            ].
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3501
            ^ #Error
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3502
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3503
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3504
    ^ VariableNode type:#GlobalVariable name:tokenName asSymbol
454
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3505
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3506
    "Modified: 19.12.1996 / 22:30:01 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3507
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3508
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3509
variableOrError
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3510
    "parse a variable; return a node-tree, nil or #Error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3511
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  3512
    ^ self variableOrError:tokenName
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  3513
!
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  3514
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  3515
variableOrError:varName
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  3516
    "parse a variable; return a node-tree, nil or #Error"
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  3517
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  3518
    |var instIndex aClass searchBlock args vars
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3519
     tokenSymbol space|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3520
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3521
    "is it a block-arg or block-var ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3522
    searchBlock := currentBlock.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3523
    [searchBlock notNil] whileTrue:[
353
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3524
        vars := searchBlock variables.
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3525
        vars notNil ifTrue:[
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3526
            instIndex := vars findFirst:[:aBlockVar | aBlockVar name = varName].
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3527
            instIndex ~~ 0 ifTrue:[
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3528
                ^ VariableNode type:#BlockVariable
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3529
                               name:varName
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3530
                              token:(vars at:instIndex)
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3531
                              index:instIndex
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3532
                              block:searchBlock
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3533
            ].
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3534
        ].
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3535
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3536
        args := searchBlock arguments.
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3537
        args notNil ifTrue:[
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3538
            instIndex := args findFirst:[:aBlockArg | aBlockArg name = varName].
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3539
            instIndex ~~ 0 ifTrue:[
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3540
                ^ VariableNode type:#BlockArg
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3541
                               name:varName
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3542
                              token:(args at:instIndex)
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3543
                              index:instIndex
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3544
                              block:searchBlock
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3545
            ].
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3546
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3547
        ].
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3548
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3549
        searchBlock := searchBlock home
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3550
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3551
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3552
    "is it a method-variable ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3553
    methodVars notNil ifTrue:[
353
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3554
        instIndex := methodVarNames indexOf:varName.
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3555
        instIndex ~~ 0 ifTrue:[
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3556
            var := methodVars at:instIndex.
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3557
            var used:true.
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3558
            ^ VariableNode type:#MethodVariable
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3559
                           name:varName
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3560
                          token:var
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3561
                          index:instIndex
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3562
        ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3563
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3564
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3565
    "is it a method-argument ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3566
    methodArgs notNil ifTrue:[
353
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3567
        instIndex := methodArgNames indexOf:varName.
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3568
        instIndex ~~ 0 ifTrue:[
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3569
            ^ VariableNode type:#MethodArg
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3570
                           name:varName
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3571
                          token:(methodArgs at:instIndex)
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3572
                          index:instIndex
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3573
        ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3574
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3575
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3576
    classToCompileFor notNil ifTrue:[
353
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3577
        "is it an instance-variable ?"
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3578
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3579
        instIndex := (self classesInstVarNames) lastIndexOf:varName.
353
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3580
        instIndex ~~ 0 ifTrue:[
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3581
            parseForCode ifFalse:[self rememberInstVarUsed:varName].
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3582
            ^ VariableNode type:#InstanceVariable 
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3583
                           name:varName
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3584
                          index:instIndex
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3585
                      selfValue:selfValue
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3586
        ].
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3587
443
e7d0bad68d60 oops - previous versions allowed access to class-instance variables
Claus Gittinger <cg@exept.de>
parents: 432
diff changeset
  3588
"/      "is it a class-instance-variable ?"
e7d0bad68d60 oops - previous versions allowed access to class-instance variables
Claus Gittinger <cg@exept.de>
parents: 432
diff changeset
  3589
"/
e7d0bad68d60 oops - previous versions allowed access to class-instance variables
Claus Gittinger <cg@exept.de>
parents: 432
diff changeset
  3590
"/ it is not allowed to fetch class-instance variables
e7d0bad68d60 oops - previous versions allowed access to class-instance variables
Claus Gittinger <cg@exept.de>
parents: 432
diff changeset
  3591
"/ from instance methods ...
e7d0bad68d60 oops - previous versions allowed access to class-instance variables
Claus Gittinger <cg@exept.de>
parents: 432
diff changeset
  3592
"/
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3593
        instIndex := (self classesClassInstVarNames) lastIndexOf:varName.
353
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3594
        instIndex ~~ 0 ifTrue:[
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3595
            aClass := self inWhichClassIsClassInstVar:varName.
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3596
            aClass notNil ifTrue:[
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3597
                parseForCode ifFalse:[self rememberClassVarUsed:varName].
443
e7d0bad68d60 oops - previous versions allowed access to class-instance variables
Claus Gittinger <cg@exept.de>
parents: 432
diff changeset
  3598
self warning:'access to class-inst-var from inst method will soon be no longer supported'.
353
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3599
                ^ VariableNode type:#ClassInstanceVariable
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3600
                               name:varName
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3601
                              index:instIndex
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3602
                          selfClass:aClass
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3603
            ]
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3604
        ].
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3605
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3606
        "is it a class-variable ?"
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3607
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3608
        instIndex := (self classesClassVarNames) lastIndexOf:varName.
353
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3609
        instIndex ~~ 0 ifTrue:[
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3610
            aClass := self inWhichClassIsClassVar:varName.
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3611
            aClass notNil ifTrue:[
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3612
                parseForCode ifFalse:[self rememberClassVarUsed:varName].
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3613
                ^ VariableNode type:#ClassVariable class:aClass name:varName
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3614
            ]
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3615
        ].
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3616
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3617
        "is it a private-class ?"
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3618
361
e23d954af088 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 359
diff changeset
  3619
        aClass := classToCompileFor.
e23d954af088 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 359
diff changeset
  3620
        aClass isMeta ifTrue:[
e23d954af088 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 359
diff changeset
  3621
            aClass := aClass soleInstance.
e23d954af088 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 359
diff changeset
  3622
        ].
e23d954af088 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 359
diff changeset
  3623
        (aClass privateClassesAt:varName) notNil ifTrue:[
e23d954af088 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 359
diff changeset
  3624
            parseForCode ifFalse:[self rememberGlobalUsed:(aClass name , '::' , varName)].
e23d954af088 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 359
diff changeset
  3625
            ^ VariableNode type:#PrivateClass class:aClass name:varName
418
6a3d240e7db6 namespace support
Claus Gittinger <cg@exept.de>
parents: 412
diff changeset
  3626
        ].
6a3d240e7db6 namespace support
Claus Gittinger <cg@exept.de>
parents: 412
diff changeset
  3627
    ].
6a3d240e7db6 namespace support
Claus Gittinger <cg@exept.de>
parents: 412
diff changeset
  3628
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3629
    "is it in a namespace ?"
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3630
    space := self findNameSpaceWith:varName.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3631
    space notNil ifTrue:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3632
        parseForCode ifFalse:[self rememberGlobalUsed:(space name , '::' , varName)].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3633
        ^ VariableNode type:#PrivateClass class:space name:varName
454
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3634
    ].
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  3635
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3636
    "is it a global-variable ?"
63
c30ce56de7a8 *** empty log message ***
claus
parents: 62
diff changeset
  3637
    tokenSymbol := varName asSymbolIfInterned.
c30ce56de7a8 *** empty log message ***
claus
parents: 62
diff changeset
  3638
    tokenSymbol notNil ifTrue:[
353
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3639
        (Smalltalk includesKey:tokenSymbol) ifTrue:[
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3640
            parseForCode ifFalse:[self rememberGlobalUsed:varName].
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3641
            ^ VariableNode type:#GlobalVariable name:tokenSymbol
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3642
        ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3643
    ].
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3644
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3645
    ^ #Error
353
fe7c87a7479f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 341
diff changeset
  3646
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3647
    "Modified: 19.12.1996 / 23:53:37 / cg"
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3648
! !
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3649
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3650
!Parser methodsFor:'private'!
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3651
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3652
currentNameSpace
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3653
    |spc|
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3654
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3655
    spc := currentNamespace.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3656
    spc isNil ifTrue:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3657
        (requestor respondsTo:#currentNameSpace) ifTrue:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3658
            spc := requestor currentNameSpace
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3659
        ] ifFalse:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3660
            spc := Class nameSpaceQuerySignal raise.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3661
        ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3662
        currentNamespace := spc.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3663
    ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3664
    ^ spc
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3665
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3666
    "Created: 19.12.1996 / 23:47:58 / cg"
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3667
!
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3668
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3669
currentUsedNameSpaces
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3670
    |spaces|
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3671
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3672
    spaces := currentUsedNamespaces.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3673
    spaces isNil ifTrue:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3674
        (requestor respondsTo:#usedNameSpaces) ifTrue:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3675
            spaces := requestor usedNameSpaces
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3676
        ] ifFalse:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3677
            spaces := Class usedNameSpaceQuerySignal raise.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3678
        ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3679
        currentUsedNamespaces := spaces.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3680
    ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3681
    ^ spaces
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3682
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3683
    "Created: 19.12.1996 / 23:49:10 / cg"
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3684
!
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3685
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3686
findNameSpaceWith:aVariableName
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3687
    |currentSpace usedSpaces|
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3688
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3689
    classToCompileFor notNil ifTrue:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3690
        "is it in the classes namespace ?"
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3691
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3692
        currentSpace := classToCompileFor nameSpace.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3693
        (currentSpace notNil
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3694
        and:[currentSpace ~~ Smalltalk]) ifTrue:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3695
            (currentSpace privateClassesAt:aVariableName) notNil ifTrue:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3696
                ^ currentSpace
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3697
            ]
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3698
        ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3699
    ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3700
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3701
    "is it in the current namespace ?"
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3702
    currentSpace := self currentNameSpace.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3703
    (currentSpace notNil
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3704
    and:[currentSpace ~~ Smalltalk]) ifTrue:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3705
        (currentSpace privateClassesAt:aVariableName) notNil ifTrue:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3706
            ^ currentSpace
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3707
        ]
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3708
    ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3709
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3710
    "is it in one of the used namespaces ?"
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3711
    usedSpaces := self currentUsedNameSpaces.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3712
    usedSpaces notNil ifTrue:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3713
        usedSpaces do:[:aNameSpace |
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3714
            (aNameSpace privateClassesAt:aVariableName) notNil ifTrue:[
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3715
                ^ aNameSpace
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3716
            ]
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3717
        ]
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3718
    ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3719
    ^ nil
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3720
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3721
    "Created: 19.12.1996 / 23:51:02 / cg"
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  3722
    "Modified: 19.12.1996 / 23:52:25 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3723
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3724
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3725
!Parser methodsFor:'queries'!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3726
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3727
classesClassInstVarNames
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3728
    "caching allInstVarNames for next compilation saves time ..."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3729
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3730
    PrevClassInstVarNames isNil ifTrue:[
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3731
        PrevClassInstVarNames := classToCompileFor class allInstVarNames
98
claus
parents: 97
diff changeset
  3732
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3733
    ^ PrevClassInstVarNames
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3734
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3735
    "Created: 14.10.1996 / 18:03:35 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3736
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3737
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3738
classesClassVarNames
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3739
    "caching allClassVarNames for next compilation saves time ..."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3740
429
ffc4e2ab5581 cleanup
Claus Gittinger <cg@exept.de>
parents: 427
diff changeset
  3741
    |aClass|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3742
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3743
    PrevClassVarNames isNil ifTrue:[
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  3744
        aClass := classToCompileFor.
337
7d7d1b88da10 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 335
diff changeset
  3745
        aClass isMeta ifTrue:[
7d7d1b88da10 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 335
diff changeset
  3746
            aClass := aClass soleInstance.
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  3747
            aClass isNil ifTrue:[
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  3748
                aClass := classToCompileFor
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  3749
            ]
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  3750
        ].
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  3751
        PrevClassVarNames := aClass allClassVarNames
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3752
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3753
    ^ PrevClassVarNames
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  3754
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  3755
    "Modified: 17.6.1996 / 17:15:53 / stefan"
337
7d7d1b88da10 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 335
diff changeset
  3756
    "Modified: 21.6.1996 / 15:21:17 / cg"
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3757
    "Created: 14.10.1996 / 18:02:41 / cg"
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3758
!
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3759
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3760
classesInstVarNames
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3761
    "caching allInstVarNames for next compilation saves time ..."
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3762
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3763
    (PrevInstVarNames isNil or:[PrevClass ~~ classToCompileFor]) ifTrue:[
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3764
        PrevClass notNil ifTrue:[
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3765
            PrevClass removeDependent:Parser
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3766
        ].
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3767
        PrevClass := classToCompileFor.
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3768
        PrevInstVarNames := classToCompileFor allInstVarNames.
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3769
        PrevClassInstVarNames := nil.
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3770
        PrevClassVarNames := nil.
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3771
        PrevClass addDependent:Parser
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3772
    ].
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3773
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3774
    ^ PrevInstVarNames
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3775
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3776
    "Created: 14.10.1996 / 18:00:26 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3777
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3778
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3779
hasNonOptionalPrimitiveCode
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3780
    "return true if there was any ST/X style primitive code (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3781
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3782
    ^ hasNonOptionalPrimitiveCode
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3783
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3784
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3785
hasPrimitiveCode
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3786
    "return true if there was any ST/X style primitive code (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3787
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3788
    ^ hasPrimitiveCode
98
claus
parents: 97
diff changeset
  3789
!
claus
parents: 97
diff changeset
  3790
385
425fc425516b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 382
diff changeset
  3791
lineNumberInfo
425fc425516b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 382
diff changeset
  3792
    ^ lineNumberInfo
425fc425516b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 382
diff changeset
  3793
425fc425516b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 382
diff changeset
  3794
    "Created: 21.10.1996 / 17:06:16 / cg"
425fc425516b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 382
diff changeset
  3795
!
425fc425516b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 382
diff changeset
  3796
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3797
lineNumberInfo:how
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3798
    lineNumberInfo := how
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3799
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3800
    "Created: 23.10.1996 / 15:39:43 / cg"
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3801
!
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  3802
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3803
methodArgs
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3804
    "return an array with methodarg names (valid after parsing spec)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3805
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3806
    ^ methodArgNames
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3807
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3808
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3809
methodVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3810
    "return a collection with method variablenames (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3811
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3812
    ^ methodVarNames
23
1f7bcfff8d39 *** empty log message ***
claus
parents: 21
diff changeset
  3813
!
1f7bcfff8d39 *** empty log message ***
claus
parents: 21
diff changeset
  3814
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3815
modifiedClassVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3816
    "return a collection with classvariablenames modified by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3817
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3818
    ^ modifiedClassVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3819
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3820
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3821
modifiedGlobals
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3822
    "return a collection with globalnames modified by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3823
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3824
    ^ modifiedGlobals
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3825
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3826
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3827
modifiedInstVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3828
    "return a collection with instvariablenames modified by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3829
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3830
    ^ modifiedInstVars
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3831
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3832
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3833
numberOfMethodArgs
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3834
    "return the number of methodargs (valid after parsing spec)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3835
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3836
    ^ methodArgs size
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3837
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3838
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3839
numberOfMethodVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3840
    "return the number of method variables (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3841
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3842
    ^ methodVars size
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3843
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3844
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3845
selector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3846
    "return the selector (valid after parsing spec)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3847
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3848
    ^ selector
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3849
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3850
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3851
usedClassVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3852
    "return a collection with classvariablenames refd by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3853
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3854
    ^ usedClassVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3855
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3856
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3857
usedGlobals
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3858
    "return a collection with globalnames refd by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3859
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3860
    ^ usedGlobals
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3861
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3862
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3863
usedInstVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3864
    "return a collection with instvariablenames refd by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3865
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3866
    ^ usedInstVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3867
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3868
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3869
usedVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3870
    "return a collection with variablenames refd by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3871
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3872
    ^ usedVars
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3873
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3874
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3875
usesSuper
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3876
    "return true if the parsed method uses super (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3877
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3878
    ^ usesSuper
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3879
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3880
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3881
!Parser methodsFor:'setup'!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3882
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  3883
foldConstants:aSymbolOrNil
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  3884
    "change the constant folding level. See the classMethod for a description."
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  3885
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  3886
    foldConstants := aSymbolOrNil
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  3887
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  3888
    "Created: 21.3.1996 / 16:03:22 / cg"
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  3889
    "Modified: 21.3.1996 / 16:05:04 / cg"
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  3890
!
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  3891
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3892
initialize
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3893
    super initialize.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3894
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3895
    hasPrimitiveCode := hasNonOptionalPrimitiveCode := false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3896
    warnSTXHereExtensionUsed := WarnSTXSpecials.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3897
    usesSuper := false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3898
    parseForCode := false.
377
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
  3899
    foldConstants := FoldConstants.
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
  3900
    lineNumberInfo := LineNumberInfo.
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
  3901
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
  3902
    "Modified: 21.10.1996 / 12:34:01 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3903
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3904
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3905
parseForCode
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3906
    "turns off certain statistics (keeping referenced variables, modified vars etc.)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3907
     Use this when parsing for compilation or evaluation"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3908
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3909
    parseForCode := true
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3910
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3911
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3912
setClassToCompileFor:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3913
    "set the class to be used for parsing/evaluating"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3914
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3915
    classToCompileFor := aClass.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3916
    (classToCompileFor ~~ PrevClass) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3917
	PrevClass notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3918
	    Parser update:PrevClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3919
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3920
    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3921
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3922
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3923
setContext:aContext
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3924
    "set the context used while evaluating"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3925
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3926
    contextToEvaluateIn := aContext
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3927
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3928
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3929
setSelf:anObject
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3930
    "set the value to be used for self while evaluating"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3931
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3932
    selfValue := anObject.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3933
    classToCompileFor := anObject class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3934
    (classToCompileFor ~~ PrevClass) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3935
	PrevClass notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3936
	    Parser update:PrevClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3937
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3938
    ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3939
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3940
84
claus
parents: 83
diff changeset
  3941
!Parser methodsFor:'statistic'!
claus
parents: 83
diff changeset
  3942
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3943
rememberClassVarUsed:name 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3944
    usedClassVars isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3945
	usedClassVars := Set new
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3946
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3947
    usedClassVars add:name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3948
    self rememberVariableUsed:name
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3949
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3950
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3951
rememberGlobalUsed:name 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3952
    usedGlobals isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3953
	usedGlobals := Set new
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3954
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3955
    usedGlobals add:name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3956
    self rememberVariableUsed:name
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3957
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3958
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3959
rememberInstVarUsed:name 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3960
    usedInstVars isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3961
	usedInstVars := Set new
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3962
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3963
    usedInstVars add:name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3964
    self rememberVariableUsed:name
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3965
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3966
84
claus
parents: 83
diff changeset
  3967
rememberSelectorUsed:sel
claus
parents: 83
diff changeset
  3968
    usedMessages isNil ifTrue:[
claus
parents: 83
diff changeset
  3969
	usedMessages := IdentitySet new.
claus
parents: 83
diff changeset
  3970
    ].
claus
parents: 83
diff changeset
  3971
    usedMessages add:sel
claus
parents: 83
diff changeset
  3972
!
claus
parents: 83
diff changeset
  3973
claus
parents: 83
diff changeset
  3974
rememberVariableUsed:name 
claus
parents: 83
diff changeset
  3975
    usedVars isNil ifTrue:[
claus
parents: 83
diff changeset
  3976
	usedVars := Set new
claus
parents: 83
diff changeset
  3977
    ].
claus
parents: 83
diff changeset
  3978
    usedVars add:name
claus
parents: 83
diff changeset
  3979
! !
claus
parents: 83
diff changeset
  3980
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3981
!Parser class methodsFor:'documentation'!
148
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 145
diff changeset
  3982
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 145
diff changeset
  3983
version
481
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
  3984
    ^ '$Header: /cvs/stx/stx/libcomp/Parser.st,v 1.123 1997-01-14 15:58:44 cg Exp $'
148
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 145
diff changeset
  3985
! !
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3986
Parser initialize!