Parser.st
author Claus Gittinger <cg@exept.de>
Thu, 24 Aug 2006 22:09:48 +0200
changeset 1875 23496a9ee943
parent 1855 61936f01108e
child 1901 a539817c2dde
permissions -rw-r--r--
automatically generated by browser
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
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
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
1043
08ad8eb7532d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1042
diff changeset
    13
"{ Package: 'stx:libcomp' }"
08ad8eb7532d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1042
diff changeset
    14
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    15
Scanner subclass:#Parser
1819
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    16
	instanceVariableNames:'classToCompileFor selfValue contextToEvaluateIn selector
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    17
		methodArgs methodArgNames methodVars methodVarNames tree
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    18
		currentBlock parseForCode readInstVars readClassVars readGlobals
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    19
		usedInstVars usedClassVars usedVars modifiedInstVars
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    20
		modifiedClassVars modifiedGlobals usesSuper usedGlobals
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    21
		usedSymbols messagesSent messagesSentToSelf messagesSentToSuper
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    22
		localVarDefPosition evalExitBlock selfNode superNode nilNode
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    23
		hasPrimitiveCode hasNonOptionalPrimitiveCode primitiveNr
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    24
		primitiveResource logged warnedUndefVars warnedUnknownNamespaces
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    25
		correctedSource foldConstants lineNumberInfo currentNamespace
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    26
		currentUsedNamespaces methodNode alreadyWarnedClassInstVarRefs
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    27
		localBlockVarDefPosition endOfSelectorPosition
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    28
		beginOfBodyPosition startOfBlockPosition primitiveContextInfo
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    29
		usedLocalVars modifiedLocalVars alreadyWarnedUninitializedVars
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    30
		alreadyWarnedUnimplementedSelectors returnedValues currentPackage
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    31
		doItTemporaries inFunctionCallArgument
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    32
		didWarnAboutSTXNameSpaceUse didWarnAboutSTXHereExtensionUsed
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    33
		parenthesisLevel didWarnAboutBadSupersend'
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    34
	classVariableNames:'PrevClass PrevInstVarNames PrevClassVarNames
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    35
		PrevClassInstVarNames LazyCompilation FoldConstants
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    36
		LineNumberInfo SuppressDoItCompilation ParseErrorSignal
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    37
		RestartCompilationSignal'
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    38
	poolDictionaries:''
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    39
	category:'System-Compiler'
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    40
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    41
1423
6460943f32b7 Make ParserError proceedable
Stefan Vogel <sv@exept.de>
parents: 1421
diff changeset
    42
ProceedableError subclass:#ParseError
1819
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    43
	instanceVariableNames:'errorMessage startPosition endPosition lineNumber'
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    44
	classVariableNames:''
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    45
	poolDictionaries:''
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    46
	privateIn:Parser
971
00581dfc0b59 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 964
diff changeset
    47
!
00581dfc0b59 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 964
diff changeset
    48
1647
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
    49
Notification subclass:#ParseWarning
1819
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    50
	instanceVariableNames:'errorMessage startPosition endPosition lineNumber'
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    51
	classVariableNames:''
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    52
	poolDictionaries:''
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    53
	privateIn:Parser
1647
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
    54
!
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
    55
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
    56
Parser subclass:#PrimitiveSpecParser
1819
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    57
	instanceVariableNames:''
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    58
	classVariableNames:''
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    59
	poolDictionaries:''
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    60
	privateIn:Parser
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
    61
!
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
    62
971
00581dfc0b59 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 964
diff changeset
    63
Parser::ParseError subclass:#UndefinedSuperclassError
1819
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    64
	instanceVariableNames:''
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    65
	classVariableNames:''
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    66
	poolDictionaries:''
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    67
	privateIn:Parser
971
00581dfc0b59 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 964
diff changeset
    68
!
00581dfc0b59 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 964
diff changeset
    69
1398
eaef898b063e added undefinedVariableNotification
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
    70
Notification subclass:#UndefinedVariableNotification
1819
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    71
	instanceVariableNames:'parser'
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    72
	classVariableNames:''
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    73
	poolDictionaries:''
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
    74
	privateIn:Parser
1398
eaef898b063e added undefinedVariableNotification
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
    75
!
eaef898b063e added undefinedVariableNotification
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
    76
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
    77
!Parser class methodsFor:'documentation'!
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    78
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    79
copyright
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    80
"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    81
 COPYRIGHT (c) 1989 by Claus Gittinger
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
    82
              All Rights Reserved
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    83
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    84
 This software is furnished under a license and may be used
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    85
 only in accordance with the terms of that license and with the
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    86
 inclusion of the above copyright notice.   This software may not
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    87
 be provided or otherwise made available to, or used by, any
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    88
 other person.  No title to or ownership of the software is
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    89
 hereby transferred.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    90
"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    91
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    92
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    93
documentation
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    94
"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    95
    Parser is used for both parsing and evaluating smalltalk expressions;
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    96
    it first builds a parseTree which is then interpreted (evaluate) or
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    97
    compiled. Compilation is done in the subclass ByteCodeCompiler and/or
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    98
    the (planned) MachineCodeCompiler.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    99
173
247ae4b8af76 interest is written with one 'r' (shame on me)
Claus Gittinger <cg@exept.de>
parents: 171
diff changeset
   100
    methods of main interest are:
755
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   101
        Parser evaluateExpression:...
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   102
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   103
    and:
755
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   104
        Parser parseExpression:...
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   105
        Parser parseMethod:...
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   106
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   107
    there is protocol to parse complete methods, selector specs, body only etc.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   108
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   109
    Parser is also used to find the referenced/modified inst/classvars of
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   110
    a method - this is done by sending parseXXX message to a parser and asking
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   111
    the parser for referencedXVars or modifiedXVars (see SystemBrowser).
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   112
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   113
    You can also use parsers for all kinds of other things (ChangesBrowser for
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   114
    example analyzes the expressions in the changelist ...) by looking at the
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   115
    parsers tree. (Although this is somewhat dangerous, since it exports the
755
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   116
    compilers internals ... better style is to add specialized query methods here)
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   117
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   118
    One instance of Parser is created to parse one method or expression - i.e.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   119
    its not suggested to reuse parsers.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   120
212
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   121
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   122
  Constant folding:
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   123
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   124
    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
   125
    expressions involving integers and floats are constant folded
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   126
    (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
   127
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   128
    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
   129
    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
   130
    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
   131
    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
   132
    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
   133
    Therefore, this mode is a bit dangerous and disabled by default.
755
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   134
    The current implementation, base upon a global constant-folding setting is somewhat stupid
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   135
    and intermediate - a better solution would be to allow the optimization to be controlled
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   136
    by a method-pragma, since it may make sense to disable optimization on a method level,
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   137
    if its known that the used constant objects are subject of modifications as described above.
212
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   138
    
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   139
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   140
  Immutable arrays:
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   141
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   142
    Immutable arrays are experimental and being evaluated.
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   143
    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
   144
    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
   145
    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
   146
    return the modified array. These are hard to find bugs.
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   147
    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
   148
    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
   149
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   150
    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
   151
    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
   152
    of st/x.
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   153
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   154
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   155
260
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   156
    [Instance variables:]
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   157
755
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   158
        classToCompileFor   <Class>             the class (or nil) we are compiling for
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   159
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   160
        selfValue           <any>               value to use as self when interpreting
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   161
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   162
        contextToEvaluateIn <Context>           the context (or nil) when interpreting
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   163
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   164
        selector            <Symbol>            the selector of the parsed method
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   165
                                                (valid after parseMethodSpecification)
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   166
        methodArgs                              internal
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   167
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   168
        methodArgNames      <Collection>        the names of the arguments
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   169
                                                (valid after parseMethodSpecification)
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   170
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   171
        methodVars                              internal
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   172
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   173
        methodVarNames      <Collection>        the names of the method locals
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   174
                                                (valid after parseMethodBodyVarSpec)
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   175
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   176
        tree                <ParseTree>         the parse tree - valid after parsing
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   177
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   178
        currentBlock                            if currently parsing for a block
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   179
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   180
        usedInstVars                            set of all accessed instances variables
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   181
                                                (valid after parsing)
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   182
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   183
        usedClassVars                           same for classVars
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   184
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   185
        usedVars                                all used variables (inst, class & globals)
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   186
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   187
        modifiedInstVars                        set of all modified instance variables
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   188
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   189
        modifiedClassVars                       same for clasVars
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   190
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   191
        localVarDefPosition <Integer>           the character offset of the local variable
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   192
                                                def. (i.e. the first '|' if any)
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   193
                                                Not yet used - prepared for automatic add of
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   194
                                                undefined variables
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   195
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   196
        evalExitBlock                           internal for interpretation
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   197
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   198
        selfNode            <Node>              cached one-and-only 'self' node
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   199
        superNode           <Node>              cached one-and-only 'super' node
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   200
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   201
        hasPrimitiveCode    <Boolean>           true, if it contains ST/X style primitive code
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   202
        hasNonOptionalPrimitiveCode    
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   203
                            <Boolean>           true, if it contains ST/X style primitive code
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   204
                                                which is NOT flagged by the OPTIONAL directive.
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   205
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   206
        primitiveNr         <Integer>           the parsed ST-80 type primitive number (or nil)
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   207
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   208
        logged
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   209
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   210
        warnedUndefVars     <Set>               set of all variables which the parser has
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   211
                                                already output a warning (to avoid multiple
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   212
                                                warnings about the same variable)
260
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   213
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   214
    [Class variables:]
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   215
755
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   216
        PrevClass           <Class>             class, of which properties are
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   217
                                                cached in:
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   218
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   219
        PrevInstVarNames      <Collection>      instance variablenames of cached class
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   220
        PrevClassVarNames     <Collection>      class variablenames of cached class
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   221
        PrevClassInstVarNames <Collection>      class instance variablenames of cached class
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   222
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   223
        LazyCompilation       <Boolean>         EXPERIMENTAL: lazy compilation
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   224
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   225
        ArraysAreImmutable    <Boolean>         if true, create array literals
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   226
                                                as instances of ImmutableArray,
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   227
                                                which cannot be stored into.
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   228
                                                Default is false, for compatibility.
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   229
                                                Can be turned on while developping
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   230
                                                new code to make certain that side
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   231
                                                effects are avoided.
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   232
1615
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
   233
        StringsAreImmutable   <Boolean>         same as above for string literals
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
   234
755
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   235
        WarnST80Directives    <Boolean>         if true, give warnings about
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   236
                                                ST-80 directives (resource defs)
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   237
                                                which are ignored in st/x.
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   238
                                                defaults to false.
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   239
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   240
        FoldConstants         <Symbol>          controls how constant folding should be
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   241
                                                done.
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   242
                                                Can be one of:
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   243
                                                        nil      - no constant folding
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   244
                                                        #level1  - numeric optimizations only
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   245
                                                        #level2  - secure optimizations only
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   246
                                                        #full    - full folding
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   247
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   248
                                                level1:   arithmetic on constant numbers
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   249
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   250
                                                level2:   above PLUS array conversions with #asFloatArray,
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   251
                                                          #asDoubleArray, string concatenation
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   252
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   253
                                                full:     constant points.
260
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   254
                                                          
b881b17d0da6 commentary
Claus Gittinger <cg@exept.de>
parents: 258
diff changeset
   255
    [see also:]
755
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   256
        ByteCodeCompiler Scanner ObjectFileLoader
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   257
        Workspace
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   258
        SystemBrowser
263
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 260
diff changeset
   259
3b21d0991eff documentation
Claus Gittinger <cg@exept.de>
parents: 260
diff changeset
   260
    [author:]
755
49ae81e86b7b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 752
diff changeset
   261
        Claus Gittinger
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   262
"
1399
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   263
!
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   264
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   265
examples
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   266
"
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   267
                                                                        [exBegin]
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   268
    Parser 
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   269
        evaluate:'1+2*3' 
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   270
        in:nil 
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   271
        receiver:nil 
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   272
        notifying:nil 
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   273
        logged:false 
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   274
        ifFail:nil      
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   275
                                                                        [exEnd]
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   276
                                                                        [exBegin]
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   277
    Parser undefinedVariableNotification handle:[:ex |
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   278
        |badName|
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   279
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   280
        badName := ex variableName.
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   281
        ex proceedWith:(ConstantNode value:5).
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   282
    ] do:[
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   283
        ^ self compilerClass 
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   284
            evaluate:'foo * 3' 
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   285
            in:nil 
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   286
            receiver:nil 
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   287
            notifying:nil 
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   288
            logged:false 
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   289
            ifFail:nil 
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   290
    ]
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   291
                                                                        [exEnd]
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
   292
"
141
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
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
   295
!Parser class methodsFor:'instance creation'!
141
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
for:aStringOrStream in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   298
    "return a new parser, reading code for aClass from aStringOrStream"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   299
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   300
    |parser|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   301
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   302
    parser := self for:aStringOrStream.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   303
    parser setClassToCompileFor:aClass.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   304
    ^ parser
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   305
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   306
1419
9cd1adac1785 category
Claus Gittinger <cg@exept.de>
parents: 1418
diff changeset
   307
!Parser class methodsFor:'Compatibility-ST80'!
540
642f56fab795 ST80 compatible parse:class:
Claus Gittinger <cg@exept.de>
parents: 508
diff changeset
   308
642f56fab795 ST80 compatible parse:class:
Claus Gittinger <cg@exept.de>
parents: 508
diff changeset
   309
parse:aString class:aClass
642f56fab795 ST80 compatible parse:class:
Claus Gittinger <cg@exept.de>
parents: 508
diff changeset
   310
    "same as #parseMethod:in: for ST80 compatibility."
642f56fab795 ST80 compatible parse:class:
Claus Gittinger <cg@exept.de>
parents: 508
diff changeset
   311
642f56fab795 ST80 compatible parse:class:
Claus Gittinger <cg@exept.de>
parents: 508
diff changeset
   312
    |parser|
642f56fab795 ST80 compatible parse:class:
Claus Gittinger <cg@exept.de>
parents: 508
diff changeset
   313
642f56fab795 ST80 compatible parse:class:
Claus Gittinger <cg@exept.de>
parents: 508
diff changeset
   314
    parser := self parseMethod:aString in:aClass.
642f56fab795 ST80 compatible parse:class:
Claus Gittinger <cg@exept.de>
parents: 508
diff changeset
   315
    parser notNil ifTrue:[^ parser tree].
642f56fab795 ST80 compatible parse:class:
Claus Gittinger <cg@exept.de>
parents: 508
diff changeset
   316
    ^ nil
642f56fab795 ST80 compatible parse:class:
Claus Gittinger <cg@exept.de>
parents: 508
diff changeset
   317
642f56fab795 ST80 compatible parse:class:
Claus Gittinger <cg@exept.de>
parents: 508
diff changeset
   318
    "Modified: 19.6.1997 / 16:34:57 / cg"
642f56fab795 ST80 compatible parse:class:
Claus Gittinger <cg@exept.de>
parents: 508
diff changeset
   319
! !
642f56fab795 ST80 compatible parse:class:
Claus Gittinger <cg@exept.de>
parents: 508
diff changeset
   320
1419
9cd1adac1785 category
Claus Gittinger <cg@exept.de>
parents: 1418
diff changeset
   321
!Parser class methodsFor:'Compatibility-Squeak'!
920
23f7bb1023cb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 919
diff changeset
   322
23f7bb1023cb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 919
diff changeset
   323
evaluate:someString for:aReceiver logged:logged
23f7bb1023cb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 919
diff changeset
   324
    ^ self evaluate:someString receiver:aReceiver logged:logged
23f7bb1023cb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 919
diff changeset
   325
        
23f7bb1023cb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 919
diff changeset
   326
23f7bb1023cb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 919
diff changeset
   327
23f7bb1023cb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 919
diff changeset
   328
! !
23f7bb1023cb *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 919
diff changeset
   329
1062
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
   330
!Parser class methodsFor:'Signal constants'!
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
   331
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
   332
parseErrorSignal
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
   333
    ^ ParseErrorSignal
1398
eaef898b063e added undefinedVariableNotification
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
   334
!
eaef898b063e added undefinedVariableNotification
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
   335
1468
891259e2dbe4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1461
diff changeset
   336
restartCompilationSignal
891259e2dbe4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1461
diff changeset
   337
    ^ RestartCompilationSignal
891259e2dbe4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1461
diff changeset
   338
891259e2dbe4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1461
diff changeset
   339
    "Created: / 15.11.2001 / 22:57:05 / cg"
891259e2dbe4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1461
diff changeset
   340
!
891259e2dbe4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1461
diff changeset
   341
1398
eaef898b063e added undefinedVariableNotification
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
   342
undefinedVariableNotification
eaef898b063e added undefinedVariableNotification
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
   343
    ^ UndefinedVariableNotification
1062
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
   344
! !
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
   345
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
   346
!Parser class methodsFor:'changes'!
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   347
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   348
flushNameCache
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   349
    "unconditional flush name caches"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   350
694
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
   351
    [
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
   352
        PrevClass notNil ifTrue:[
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
   353
            PrevClass removeDependent:Parser
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
   354
        ].
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
   355
        PrevClass := nil.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
   356
        PrevInstVarNames := nil.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
   357
        PrevClassVarNames := nil.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
   358
        PrevClassInstVarNames := nil.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
   359
    ] valueUninterruptably
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   360
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   361
    "Parser flushNameCache"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   362
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   363
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   364
update:something with:someArgument from:changedObject
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   365
    "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
   366
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   367
    (changedObject == PrevClass) ifTrue:[
1090
7f49c607a315 catch change-notifications from Smalltalk (to flush PrevClass cache)
Claus Gittinger <cg@exept.de>
parents: 1089
diff changeset
   368
        something == #definition ifTrue:[
7f49c607a315 catch change-notifications from Smalltalk (to flush PrevClass cache)
Claus Gittinger <cg@exept.de>
parents: 1089
diff changeset
   369
            self flushNameCache
7f49c607a315 catch change-notifications from Smalltalk (to flush PrevClass cache)
Claus Gittinger <cg@exept.de>
parents: 1089
diff changeset
   370
        ]
7f49c607a315 catch change-notifications from Smalltalk (to flush PrevClass cache)
Claus Gittinger <cg@exept.de>
parents: 1089
diff changeset
   371
    ].
7f49c607a315 catch change-notifications from Smalltalk (to flush PrevClass cache)
Claus Gittinger <cg@exept.de>
parents: 1089
diff changeset
   372
    (changedObject == Smalltalk) ifTrue:[
7f49c607a315 catch change-notifications from Smalltalk (to flush PrevClass cache)
Claus Gittinger <cg@exept.de>
parents: 1089
diff changeset
   373
        something == #classDefinition ifTrue:[
7f49c607a315 catch change-notifications from Smalltalk (to flush PrevClass cache)
Claus Gittinger <cg@exept.de>
parents: 1089
diff changeset
   374
            self flushNameCache
7f49c607a315 catch change-notifications from Smalltalk (to flush PrevClass cache)
Claus Gittinger <cg@exept.de>
parents: 1089
diff changeset
   375
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   376
    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   377
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   378
717
627b2379d5ce moved signal to scanner
Claus Gittinger <cg@exept.de>
parents: 713
diff changeset
   379
!Parser class methodsFor:'class initialization'!
627b2379d5ce moved signal to scanner
Claus Gittinger <cg@exept.de>
parents: 713
diff changeset
   380
627b2379d5ce moved signal to scanner
Claus Gittinger <cg@exept.de>
parents: 713
diff changeset
   381
initialize
627b2379d5ce moved signal to scanner
Claus Gittinger <cg@exept.de>
parents: 713
diff changeset
   382
    LazyCompilation := false.      "/ usually set to true in your .rc file
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   383
717
627b2379d5ce moved signal to scanner
Claus Gittinger <cg@exept.de>
parents: 713
diff changeset
   384
    FoldConstants := #level1.
627b2379d5ce moved signal to scanner
Claus Gittinger <cg@exept.de>
parents: 713
diff changeset
   385
    LineNumberInfo := false.
627b2379d5ce moved signal to scanner
Claus Gittinger <cg@exept.de>
parents: 713
diff changeset
   386
1062
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
   387
    ParseErrorSignal isNil ifTrue:[
1380
7288e4623e2b parseError
Claus Gittinger <cg@exept.de>
parents: 1373
diff changeset
   388
        ParseErrorSignal := ParseError.
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
   389
        ParseErrorSignal notifierString:'Parse error:'.
1380
7288e4623e2b parseError
Claus Gittinger <cg@exept.de>
parents: 1373
diff changeset
   390
7288e4623e2b parseError
Claus Gittinger <cg@exept.de>
parents: 1373
diff changeset
   391
"/        ParseErrorSignal := Error newSignalMayProceed:true.
7288e4623e2b parseError
Claus Gittinger <cg@exept.de>
parents: 1373
diff changeset
   392
"/        ParseErrorSignal notifierString:'parse error'.
7288e4623e2b parseError
Claus Gittinger <cg@exept.de>
parents: 1373
diff changeset
   393
"/        ParseErrorSignal nameClass:self message:#parseErrorSignal.
1062
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
   394
    ].
1221
2768cbe3be2b finished remove unused vars;
Claus Gittinger <cg@exept.de>
parents: 1220
diff changeset
   395
    RestartCompilationSignal := Signal new.
2768cbe3be2b finished remove unused vars;
Claus Gittinger <cg@exept.de>
parents: 1220
diff changeset
   396
1090
7f49c607a315 catch change-notifications from Smalltalk (to flush PrevClass cache)
Claus Gittinger <cg@exept.de>
parents: 1089
diff changeset
   397
    Smalltalk addDependent:self.
1062
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
   398
717
627b2379d5ce moved signal to scanner
Claus Gittinger <cg@exept.de>
parents: 713
diff changeset
   399
    "
627b2379d5ce moved signal to scanner
Claus Gittinger <cg@exept.de>
parents: 713
diff changeset
   400
     self initialize
627b2379d5ce moved signal to scanner
Claus Gittinger <cg@exept.de>
parents: 713
diff changeset
   401
    "
627b2379d5ce moved signal to scanner
Claus Gittinger <cg@exept.de>
parents: 713
diff changeset
   402
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
   403
    "Modified: / 22-08-2006 / 13:41:51 / cg"
717
627b2379d5ce moved signal to scanner
Claus Gittinger <cg@exept.de>
parents: 713
diff changeset
   404
! !
627b2379d5ce moved signal to scanner
Claus Gittinger <cg@exept.de>
parents: 713
diff changeset
   405
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
   406
!Parser class methodsFor:'controlling compilation'!
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   407
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   408
allowArrayIndexSyntaxExtension
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   409
    "experimental"
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   410
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   411
    ^ ParserFlags allowArrayIndexSyntaxExtension
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   412
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   413
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   414
allowArrayIndexSyntaxExtension:aBoolean
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   415
    "experimental"
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   416
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   417
    ParserFlags allowArrayIndexSyntaxExtension:aBoolean.
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   418
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   419
    "
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   420
     self allowArrayIndexSyntaxExtension:true
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   421
     self allowArrayIndexSyntaxExtension:false
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   422
    "
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   423
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   424
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   425
allowFunctionCallSyntaxForBlockEvaluation
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   426
    "experimental"
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   427
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   428
    ^ ParserFlags allowFunctionCallSyntaxForBlockEvaluation
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   429
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   430
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   431
allowFunctionCallSyntaxForBlockEvaluation:aBoolean
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   432
    "experimental"
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   433
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   434
    ParserFlags allowFunctionCallSyntaxForBlockEvaluation:aBoolean.
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   435
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   436
    "
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   437
     self allowFunctionCallSyntaxForBlockEvaluation:true
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   438
     self allowFunctionCallSyntaxForBlockEvaluation:false
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   439
    "
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   440
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   441
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   442
allowReservedWordsAsSelectors
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   443
    "return true, if self, super, thisContext, nil, true and false are to be allowed
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   444
     as unary message selectors."
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   445
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   446
    ^ ParserFlags allowReservedWordsAsSelectors
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   447
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   448
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   449
allowReservedWordsAsSelectors:aBoolean
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   450
    "enable/disable, if self, super, thisContext, nil, true and false are to be allowed
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   451
     as unary message selectors."
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   452
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   453
    ParserFlags allowReservedWordsAsSelectors:aBoolean.
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   454
    self setupActions
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   455
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   456
    "
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   457
     self allowReservedWordsAsSelectors:true
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   458
     self allowReservedWordsAsSelectors:false
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   459
    "
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   460
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   461
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   462
arraysAreImmutable
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   463
    "return true if arrays are immutable literals"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   464
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   465
    ^ ParserFlags arraysAreImmutable
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   466
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   467
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   468
arraysAreImmutable:aBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   469
    "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
   470
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   471
    ParserFlags arraysAreImmutable:aBoolean.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   472
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   473
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   474
     can be added to your private.rc file:
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   475
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   476
     Compiler arraysAreImmutable:true     
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   477
     Compiler arraysAreImmutable:false      
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   478
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   479
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   480
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   481
compileLazy
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   482
    "return true if compiling lazy"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   483
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   484
    ^ LazyCompilation.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   485
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   486
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   487
compileLazy:aBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   488
    "turn on/off lazy compilation - return previous setting.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   489
     Actually this flag belongs into the ByteCodeCompiler subclass,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   490
     but it also controls the reporting of some errors here; therefore
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   491
     its located here"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   492
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   493
    |oldLazy|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   494
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   495
    oldLazy := LazyCompilation.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   496
    LazyCompilation := aBoolean.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   497
    ^ oldLazy
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   498
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   499
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   500
     Compiler compileLazy:false         
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   501
     Compiler compileLazy:true          
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   502
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   503
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   504
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   505
foldConstants
212
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   506
    "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
   507
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   508
    ^ FoldConstants
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   509
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   510
    "Created: 9.2.1996 / 17:40:13 / cg"
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   511
!
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   512
212
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   513
foldConstants:aSymbol
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   514
    "set the symbol describing how constants are to be folded.
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   515
     It can be:
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   516
        nil             - no constant folding
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   517
        #level1         - numeric constants only
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   518
        #level2         - level1 PLUS array conversions PLUS string concatenation
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   519
        #full           - level2 PLUS constant points, constant rectangles (dangerous)"
212
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   520
ff39051e219f more constant folding options
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
   521
    FoldConstants := aSymbol
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   522
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   523
    "Created: 9.2.1996 / 17:40:34 / cg"
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   524
!
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
   525
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   526
implicitSelfSends
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   527
    "return true if undefined variables with
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   528
     lowercase first character are to be turned
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   529
     into implicit self sends"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   530
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   531
    ^ ParserFlags implicitSelfSends
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   532
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   533
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   534
implicitSelfSends:aBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   535
    "turn on/off implicit self sends"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   536
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   537
    ParserFlags implicitSelfSends:aBoolean
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   538
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   539
    "
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   540
     ParserFlags implicitSelfSends:true
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   541
     ParserFlags implicitSelfSends:false 
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   542
    "
377
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   543
!
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   544
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   545
lineNumberInfo
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   546
    ^ LineNumberInfo
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   547
!
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   548
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   549
lineNumberInfo:aBoolean
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
   550
    LineNumberInfo := aBoolean
752
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   551
!
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   552
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   553
stringsAreImmutable
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   554
    "return true if strings are immutable literals"
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   555
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   556
    ^ ParserFlags stringsAreImmutable
752
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   557
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   558
    "Created: / 3.8.1998 / 14:53:25 / cg"
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   559
!
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   560
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   561
stringsAreImmutable:aBoolean
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   562
    "turn on/off immutable string literals - default is false for ST-80 compatibilty."
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   563
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   564
    ParserFlags stringsAreImmutable:aBoolean.
752
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   565
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   566
    "
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   567
     can be added to your private.rc file:
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   568
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   569
     ParserFlags stringsAreImmutable:true     
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   570
     ParserFlags stringsAreImmutable:false      
752
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   571
    "
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   572
dc6c757579b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 748
diff changeset
   573
    "Created: / 3.8.1998 / 14:53:28 / cg"
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
   574
!
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
   575
1653
db35fa50902a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1650
diff changeset
   576
warnAboutBadComments:aBoolean
db35fa50902a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1650
diff changeset
   577
    "controls generation of warning messages about empty comments"
db35fa50902a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1650
diff changeset
   578
    
db35fa50902a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1650
diff changeset
   579
    ParserFlags warnAboutBadComments:aBoolean
db35fa50902a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1650
diff changeset
   580
!
db35fa50902a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1650
diff changeset
   581
1523
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   582
warnAboutVariableNameConventions 
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   583
    "controls generation of warning messages about wrong variable names"
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   584
    
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   585
    ^ ParserFlags warnAboutVariableNameConventions
1523
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   586
!
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   587
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   588
warnAboutVariableNameConventions:aBoolean 
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   589
    "controls generation of warning messages about wrong variable names"
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   590
    
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   591
    ParserFlags warnAboutVariableNameConventions:aBoolean
1523
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   592
!
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   593
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   594
warnAboutWrongVariableNames
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   595
    "controls generation of warning messages about wrong variable names"
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   596
    
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   597
    ^ ParserFlags warnAboutWrongVariableNames
1523
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   598
!
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   599
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   600
warnAboutWrongVariableNames:aBoolean
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   601
    "controls generation of warning messages about wrong variable names"
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   602
    
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   603
    ParserFlags warnAboutWrongVariableNames:aBoolean
1523
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   604
!
7846be9771d6 checkVariable-conventions accessors
Claus Gittinger <cg@exept.de>
parents: 1522
diff changeset
   605
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
   606
warnUnusedVars
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
   607
    "controls generation of warning messages about unued method variables"
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
   608
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   609
    ^ ParserFlags warnUnusedVars
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
   610
!
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
   611
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
   612
warnUnusedVars:aBoolean
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
   613
    "controls generation of warning messages about unued method variables"
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
   614
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
   615
    ParserFlags warnUnusedVars:aBoolean
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   616
! !
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   617
481
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   618
!Parser class methodsFor:'defaults'!
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   619
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   620
maxLineNumber
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   621
    "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
   622
     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
   623
     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
   624
     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
   625
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   626
    ^ 255
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   627
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   628
    "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
   629
! !
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
   630
1187
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   631
!Parser class methodsFor:'error correction'!
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   632
1199
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   633
findBest:nMax selectorsFor:aString in:aClassOrNil
1187
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   634
    "collect known selectors with their spelling distances to aString;
1199
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   635
     return the nMax best suggestions. If the argument, aClassOrNil is not nil,
1187
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   636
     the message is assumed to be sent to instances of that class (i.e. offer
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   637
     corrections from that hierarchy only)"
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   638
1286
b21dfcad59a6 Remove unused method var
Stefan Vogel <sv@exept.de>
parents: 1285
diff changeset
   639
    |info block lcSelector|
1187
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   640
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   641
    info := SortedCollection new.
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   642
    info sortBlock:[:a :b | a value > b value].
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   643
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   644
    lcSelector := aString asLowercase.
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   645
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   646
    block := [:sym :mthd|
1215
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   647
        |dist lcSym keepThis|
1187
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   648
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   649
        lcSym := sym asLowercase.
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   650
        (info contains:[:i | i key == sym]) ifFalse:[
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   651
            dist := lcSelector spellAgainst:lcSym.
1199
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   652
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   653
            (lcSym startsWith:lcSelector) ifTrue:[
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   654
                dist := dist + (aString size * 10).
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   655
            ].
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   656
        
1215
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   657
            (dist > 20) ifTrue:[
1199
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   658
                (info contains:[:entry | entry key = sym]) ifFalse:[
1215
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   659
                    keepThis := true.
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   660
                    info size >= nMax ifTrue:[
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   661
                        "will remove last entry anyway - so check if this one will remain ..."
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   662
                        dist < info last value ifTrue:[
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   663
                            keepThis := false.
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   664
                        ]
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   665
                    ].
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   666
                    keepThis ifTrue:[
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   667
                        "expensive - therefore do this check at last"
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   668
                        mthd isObsolete ifFalse:[
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   669
                            info add:(sym -> dist).
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   670
                            info size > nMax ifTrue:[
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   671
                                info removeLast.
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   672
                            ]
f2b18b227c78 speedup findBestSelector
Claus Gittinger <cg@exept.de>
parents: 1214
diff changeset
   673
                        ]
1199
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   674
                    ]
1187
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   675
                ]
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   676
            ]
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   677
        ]
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   678
    ].
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   679
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   680
    aClassOrNil isNil ifTrue:[
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   681
        Smalltalk allClassesDo:[:cls |
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   682
            cls methodDictionary keysAndValuesDo:block.
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   683
            cls class methodDictionary keysAndValuesDo:block.
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   684
        ]
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   685
    ] ifFalse:[
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   686
        aClassOrNil withAllSuperclassesDo:[:cls |
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   687
            cls methodDictionary keysAndValuesDo:block.
1323
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
   688
            "/ cls class methodDictionary keysAndValuesDo:block.
1187
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   689
        ]
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   690
    ].
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   691
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   692
    ^ info asOrderedCollection collect:[:a | a key]
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   693
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   694
    "Modified: / 19.1.2000 / 16:43:37 / cg"
1199
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   695
!
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   696
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   697
findBestSelectorsFor:aString
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   698
    "collect known selectors with their spelling distances to aString;
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   699
     return the 10 best suggestions"
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   700
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   701
    ^ self findBestSelectorsFor:aString in:nil
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   702
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   703
    "
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   704
     Parser findBestSelectorsFor:'at'
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   705
     Parser findBestSelectorsFor:'at:pu'
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   706
    "
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   707
!
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   708
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   709
findBestSelectorsFor:aString in:aClassOrNil
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   710
    "collect known selectors with their spelling distances to aString;
1323
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
   711
     return the 15 best suggestions. If the argument, aClassOrNil is not nil,
1199
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   712
     the message is assumed to be sent to instances of that class (i.e. offer
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   713
     corrections from that hierarchy only)"
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   714
3ffc14d393a7 best selector matching improved
Claus Gittinger <cg@exept.de>
parents: 1197
diff changeset
   715
    ^ self
1323
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
   716
        findBest:15 selectorsFor:aString in:aClassOrNil
1187
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   717
! !
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
   718
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
   719
!Parser class methodsFor:'evaluating expressions'!
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   720
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   721
evaluate:aStringOrStream
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   722
    "return the result of evaluating an expression in aStringOrStream.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   723
     No doit-entry is added to the changeLog."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   724
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   725
    ^ self 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   726
        evaluate:aStringOrStream 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   727
        in:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   728
        receiver:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   729
        notifying:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   730
        logged:false
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   731
        ifFail:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   732
        compile:true
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   733
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   734
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   735
     Compiler evaluate:'1 + 2'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   736
     Compiler evaluate:'''hello world'' asSortedCollection displayString printNL'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   737
     Compiler evaluate:'''hello world'' asSortedCollection printNL'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   738
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   739
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   740
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   741
evaluate:aStringOrStream compile:compile
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   742
    "return the result of evaluating aString, 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   743
     The compile argument specifies if the string should be compiled down to 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   744
     bytecode or instead be interpreted from the parseTree.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   745
     The first should be done for doIts etc, where a readable walkback is
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   746
     required.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   747
     The latter is better done for constants, styleSheet and resource
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   748
     reading and simple sends, where the overhead of compilation is bigger
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   749
     than the interpretation overhead."
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   750
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   751
    ^ self 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   752
        evaluate:aStringOrStream
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   753
        in:nil
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   754
        receiver:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   755
        notifying:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   756
        logged:false
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   757
        ifFail:nil
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   758
        compile:compile 
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   759
!
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   760
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   761
evaluate:aStringOrStream ifFail:failBlock
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   762
    "return the result of evaluating an expression in aStringOrStream.
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   763
     In case of any syntax errors, return the value of failBlock.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   764
     No doit-entry is added to the changeLog."
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   765
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   766
    ^ self 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   767
        evaluate:aStringOrStream 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   768
        in:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   769
        receiver:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   770
        notifying:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   771
        logged:false
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   772
        ifFail:failBlock 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   773
        compile:true
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   774
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   775
     Compiler evaluate:'1 +' ifFail:['oops']   
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   776
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   777
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   778
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   779
evaluate:aStringOrStream in:aContext receiver:anObject notifying:requestor ifFail:failBlock
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   780
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   781
     Allow access to anObject as self and to its instVars (used in the inspector).
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   782
     No doIt entry is added to the change-file. 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   783
     If the failBlock argument is non-nil, it is evaluated if an error occurs."
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   784
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   785
    ^ self 
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
   786
        evaluate:aStringOrStream
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
   787
        in:aContext
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
   788
        receiver:anObject
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
   789
        notifying:requestor
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
   790
        logged:false
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
   791
        ifFail:nil
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
   792
        compile:true
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
   793
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
   794
    "Modified: / 17.1.1998 / 02:54:07 / cg"
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   795
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   796
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   797
evaluate:aStringOrStream in:aContext receiver:anObject notifying:requestor logged:logged ifFail:failBlock
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   798
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   799
     Allow access to anObject as self and to its instVars (used in the inspector).
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   800
     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
   801
     is non-nil, it is evaluated if an error occurs."
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   802
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   803
    ^ self 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   804
        evaluate:aStringOrStream
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   805
        in:aContext
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   806
        receiver:anObject
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   807
        notifying:requestor
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   808
        logged:logged 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   809
        ifFail:failBlock 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   810
        compile:true
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   811
!
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   812
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   813
evaluate:aStringOrStream in:aContext receiver:anObject notifying:requestor logged:logged ifFail:failBlock compile:compile
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   814
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   815
     Allow access to anObject as self and to its instVars (used in the inspector).
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   816
     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
   817
     is non-nil, it is evaluated if an error occurs.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   818
     Finally, compile specifies if the string should be compiled down to 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   819
     bytecode or instead be interpreted from the parseTree.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   820
     The first should be done for doIts etc, where a readable walkback is
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   821
     required.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   822
     The latter is better done for constants, styleSheet and resource
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   823
     reading and simple sends, where the overhead of compilation is bigger
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   824
     than the interpretation overhead."
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   825
1363
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
   826
    ^ self new
1548
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   827
        evaluate:aStringOrStream 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   828
        in:aContext 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   829
        receiver:anObject 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   830
        notifying:requestor 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   831
        logged:logged 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   832
        ifFail:failBlock 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   833
        compile:compile
1561
175735dcd732 do not check for endOfInput if parsing from a Stream
Claus Gittinger <cg@exept.de>
parents: 1557
diff changeset
   834
        checkForEndOfInput:(aStringOrStream isStream not)
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   835
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   836
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   837
evaluate:aStringOrStream logged:logged
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   838
    "return the result of evaluating an expression in aStringOrStream.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   839
     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
   840
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   841
    ^ self 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   842
        evaluate:aStringOrStream 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   843
        in:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   844
        receiver:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   845
        notifying:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   846
        logged:logged
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   847
        ifFail:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   848
        compile:true
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   849
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   850
     Compiler evaluate:'''some string''' logged:false   
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   851
     Compiler evaluate:'''some string''' logged:true   
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
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   854
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   855
evaluate:aStringOrStream notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   856
    "return the result of evaluating aString, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   857
     errors are reported to requestor"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   858
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   859
    ^ self 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   860
        evaluate:aStringOrStream 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   861
        in:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   862
        receiver:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   863
        notifying:requestor
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   864
        logged:false
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   865
        ifFail:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   866
        compile:true
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   867
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   868
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   869
evaluate:aStringOrStream notifying:requestor compile:compile
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   870
    "return the result of evaluating aString, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   871
     errors are reported to requestor.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   872
     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
   873
     bytecode or instead be interpreted from the parseTree.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   874
     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
   875
     required.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   876
     The latter is better done for constants, styleSheet and resource
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   877
     reading and simple sends, where the overhead of compilation is bigger
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   878
     than the interpretation overhead."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   879
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   880
    ^ self 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   881
        evaluate:aStringOrStream 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   882
        in:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   883
        receiver:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   884
        notifying:requestor
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   885
        logged:false
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   886
        ifFail:nil 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   887
        compile:compile
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   888
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   889
1025
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   890
evaluate:aStringOrStream notifying:requestor logged:logged
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   891
    "return the result of evaluating aString, 
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   892
     errors are reported to requestor"
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   893
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   894
    ^ self 
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   895
        evaluate:aStringOrStream 
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   896
        in:nil 
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   897
        receiver:nil 
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   898
        notifying:requestor
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   899
        logged:logged
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   900
        ifFail:nil 
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   901
        compile:true
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   902
!
5b3022ecb269 added #evaluate:notifying:logged: (for RB)
Claus Gittinger <cg@exept.de>
parents: 1022
diff changeset
   903
572
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   904
evaluate:aStringOrStream receiver:anObject
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   905
    "return the result of evaluating aString, 
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   906
     errors are reported to requestor. Allow access to
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   907
     anObject as self and to its instVars "
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   908
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   909
    ^ self 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   910
        evaluate:aStringOrStream
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   911
        in:nil
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   912
        receiver:anObject
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   913
        notifying:nil
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   914
        logged:false
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   915
        ifFail:nil
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   916
        compile:true
572
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   917
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   918
    "
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   919
     Compiler evaluate:'self x' receiver:(1 @ 2)
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   920
    "
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   921
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   922
    "Created: 1.7.1997 / 19:02:24 / cg"
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   923
    "Modified: 1.7.1997 / 19:02:33 / cg"
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   924
!
6608880c73bc added #evaluate:receiver:
Claus Gittinger <cg@exept.de>
parents: 569
diff changeset
   925
919
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   926
evaluate:aStringOrStream receiver:someOne logged:logged
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   927
    "return the result of evaluating an expression in aStringOrStream.
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   928
     The argument log controls if an entry is added to the changeLog."
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   929
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   930
    ^ self 
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   931
        evaluate:aStringOrStream 
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   932
        in:nil 
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   933
        receiver:someOne 
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   934
        notifying:nil 
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   935
        logged:logged
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   936
        ifFail:nil 
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   937
        compile:true
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   938
    "
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   939
     Compiler evaluate:'''some string''' logged:false   
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   940
     Compiler evaluate:'''some string''' logged:true   
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   941
     Compiler evaluate:'self class' receiver:nil logged:false
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   942
     Compiler evaluate:'self class' receiver:1 logged:false 
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   943
    "
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   944
!
212f477f8d7f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 918
diff changeset
   945
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   946
evaluate:aStringOrStream receiver:anObject notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   947
    "return the result of evaluating aString, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   948
     errors are reported to requestor. Allow access to
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   949
     anObject as self and to its instVars (used in the inspector)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   950
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   951
    ^ self 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   952
        evaluate:aStringOrStream
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   953
        in:nil
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   954
        receiver:anObject
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   955
        notifying:requestor
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   956
        logged:false
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   957
        ifFail:nil
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   958
        compile:true
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   959
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   960
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   961
     Compiler evaluate:'self x' receiver:(1 @ 2) notifying:nil 
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
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   964
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   965
evaluate:aStringOrStream receiver:anObject notifying:requestor compile:compile
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   966
    "return the result of evaluating aString, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   967
     errors are reported to requestor. Allow access to
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   968
     anObject as self and to its instVars (used in the inspector).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   969
     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
   970
     bytecode or instead be interpreted from the parseTree.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   971
     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
   972
     required.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   973
     The latter is better done for constants, styleSheet and resource
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   974
     reading and simple sends, where the overhead of compilation is bigger
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   975
     than the interpretation overhead."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   976
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   977
    ^ self 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   978
        evaluate:aStringOrStream
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   979
        in:nil
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   980
        receiver:anObject
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   981
        notifying:requestor
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   982
        logged:false
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   983
        ifFail:nil
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
   984
        compile:compile 
1548
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   985
!
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   986
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   987
evaluateFrom:aStringOrStream ifFail:failBlock
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   988
    "return the result of evaluating an expression from aStringOrStream.
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   989
     In case of any syntax errors, return the value of failBlock.
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   990
     No doit-entry is added to the changeLog."
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   991
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   992
    ^ self 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   993
        evaluateFrom:aStringOrStream 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   994
        in:nil 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   995
        receiver:nil 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   996
        notifying:nil 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   997
        logged:false
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   998
        ifFail:failBlock 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
   999
        compile:true
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1000
    "
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1001
     Compiler evaluate:'1 + 2' ifFail:['oops']   
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1002
    "
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1003
!
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1004
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1005
evaluateFrom:aStringOrStream in:aContext receiver:anObject notifying:requestor logged:logged ifFail:failBlock compile:compile
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1006
    "return the result of evaluating the next expression from aStringOrStream, errors are reported to requestor. 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1007
     Allow access to anObject as self and to its instVars (used in the inspector).
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1008
     If logged is true, an entry is added to the change-file. If the failBlock argument
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1009
     is non-nil, it is evaluated if an error occurs.
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1010
     Finally, compile specifies if the string should be compiled down to 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1011
     bytecode or instead be interpreted from the parseTree.
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1012
     The first should be done for doIts etc, where a readable walkback is
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1013
     required.
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1014
     The latter is better done for constants, styleSheet and resource
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1015
     reading and simple sends, where the overhead of compilation is bigger
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1016
     than the interpretation overhead."
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1017
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1018
    ^ self new
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1019
        evaluate:aStringOrStream 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1020
        in:aContext 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1021
        receiver:anObject 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1022
        notifying:requestor 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1023
        logged:logged 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1024
        ifFail:failBlock 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1025
        compile:compile
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  1026
        checkForEndOfInput:false
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1027
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1028
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  1029
!Parser class methodsFor:'general helpers'!
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  1030
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  1031
argAndVarNamesForContext:aContext
1546
cdf59c7f2963 MArk method as obsolete
Stefan Vogel <sv@exept.de>
parents: 1545
diff changeset
  1032
    <resource:#obsolete>
1446
ac887ee4881a ** changed access to blockContexts source, args and vars -- please watch out
penk
parents: 1445
diff changeset
  1033
    self obsoleteMethodWarning.
ac887ee4881a ** changed access to blockContexts source, args and vars -- please watch out
penk
parents: 1445
diff changeset
  1034
    ^ aContext argAndVarNames.
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  1035
! !
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  1036
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  1037
!Parser class methodsFor:'parsing'!
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1038
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1039
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
  1040
    "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
  1041
     return the containing BlockNode or nil.
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1042
     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
  1043
     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
  1044
     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
  1045
     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
  1046
     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
  1047
429
ffc4e2ab5581 cleanup
Claus Gittinger <cg@exept.de>
parents: 427
diff changeset
  1048
    |compiler tree mSource who mClass blocks 
397
118267bf78e5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 391
diff changeset
  1049
     maxSoFar innerBlock m|
118267bf78e5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 391
diff changeset
  1050
481
187a88a9695d care for maxLineNo when looking for a block-by-lineNo
Claus Gittinger <cg@exept.de>
parents: 480
diff changeset
  1051
    (line isNil or:[line == self maxLineNumber]) ifTrue:[
815
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1052
        ^ nil
457
ad25339043ef care for nil-lineNumber when looking for a block
Claus Gittinger <cg@exept.de>
parents: 455
diff changeset
  1053
    ].
ad25339043ef care for nil-lineNumber when looking for a block
Claus Gittinger <cg@exept.de>
parents: 455
diff changeset
  1054
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1055
    aMethod notNil ifTrue:[
815
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1056
        m := aMethod.
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1057
        who := m who.
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1058
        who isNil ifTrue:[
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1059
            m isWrapped ifTrue:[
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1060
                m := m wrapper.
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1061
                m notNil ifTrue:[
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1062
                    who := m who.
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1063
                ]
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1064
            ]
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1065
        ].
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1066
        who notNil ifTrue:[
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1067
            mClass := who methodClass.
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1068
            mClass isNil ifTrue:[ ^ nil].
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1069
        ].
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1070
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1071
        mSource := m source.
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1072
        mSource isNil ifTrue:[^ nil].
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1073
    ] ifFalse:[
815
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1074
        aString notNil ifTrue:[
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1075
            mSource := aString.
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1076
            mClass := UndefinedObject
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1077
        ] ifFalse:[
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1078
            ^ nil
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1079
        ]
397
118267bf78e5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 391
diff changeset
  1080
    ].
118267bf78e5 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 391
diff changeset
  1081
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1082
    "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
  1083
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1084
    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
  1085
    compiler parseForCode.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1086
    compiler notifying:nil.
1365
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  1087
    compiler ignoreWarnings:true.
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  1088
    compiler ignoreErrors:true.
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1089
    compiler lineNumberInfo:#full.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1090
1515
8ffe6db5e53f suppress notifications while searching for blockAtLine.
Claus Gittinger <cg@exept.de>
parents: 1514
diff changeset
  1091
    Notification 
8ffe6db5e53f suppress notifications while searching for blockAtLine.
Claus Gittinger <cg@exept.de>
parents: 1514
diff changeset
  1092
        handle:
8ffe6db5e53f suppress notifications while searching for blockAtLine.
Claus Gittinger <cg@exept.de>
parents: 1514
diff changeset
  1093
            [:ex |
8ffe6db5e53f suppress notifications while searching for blockAtLine.
Claus Gittinger <cg@exept.de>
parents: 1514
diff changeset
  1094
                ex proceed
8ffe6db5e53f suppress notifications while searching for blockAtLine.
Claus Gittinger <cg@exept.de>
parents: 1514
diff changeset
  1095
            ]
8ffe6db5e53f suppress notifications while searching for blockAtLine.
Claus Gittinger <cg@exept.de>
parents: 1514
diff changeset
  1096
        do:[
1514
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1097
            aMethod notNil ifTrue:[
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1098
                (compiler parseMethodSpec == #Error) ifTrue:[
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1099
                    ^ nil.
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1100
                ].
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1101
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1102
                who notNil ifTrue:[
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1103
                    compiler selector ~~ (who methodSelector) ifTrue:[
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1104
                        ^ nil
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1105
                    ]
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1106
                ].
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1107
            ] ifFalse:[
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1108
                compiler nextToken.
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1109
            ].
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1110
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  1111
            tree := compiler parseMethodBody.
1515
8ffe6db5e53f suppress notifications while searching for blockAtLine.
Claus Gittinger <cg@exept.de>
parents: 1514
diff changeset
  1112
        ].
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1113
815
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1114
    (compiler errorFlag 
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1115
    or:[tree == #Error
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1116
    or:[tree isNil]]) ifTrue:[
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1117
        ^ nil
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1118
    ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1119
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1120
    blocks := OrderedCollection new.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1121
    tree collectBlocksInto:blocks.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1122
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1123
    blocks := blocks select:[:aBlock |
815
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1124
                                line between: aBlock lineNumber and:aBlock endLineNumber
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1125
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1126
                            ].
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1127
    blocks size == 1 ifTrue:[
815
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1128
        ^ blocks at:1
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1129
    ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1130
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1131
    nA notNil ifTrue:[
815
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1132
        blocks := blocks select:[:aBlock |
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1133
                                aBlock numArgs == nA
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1134
                                ].
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1135
        blocks size == 1 ifTrue:[
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1136
            ^ blocks at:1
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1137
        ].
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1138
    ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1139
    nV notNil ifTrue:[
815
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1140
        blocks := blocks select:[:aBlock |
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1141
                                aBlock numVars == nV
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1142
                                ].
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1143
        blocks size == 1 ifTrue:[
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1144
            ^ blocks at:1
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1145
        ].
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1146
    ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1147
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1148
    "/ 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
  1149
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1150
    maxSoFar := 0.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1151
    blocks do:[:aBlock |
815
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1152
        aBlock lineNumber > maxSoFar ifTrue:[
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1153
            innerBlock := aBlock.
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1154
            maxSoFar := aBlock lineNumber
3be479989a99 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 813
diff changeset
  1155
        ]
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1156
    ].
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1157
    ^ innerBlock.
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1158
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1159
    "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
  1160
    "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
  1161
!
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  1162
1365
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  1163
checkMethod:aString in:aClass ignoreErrors:ignoreErrors ignoreWarnings:ignoreWarnings
629
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1164
    "parse a method in a given class.
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1165
     Return a parser (if ok), nil (empty) or #Error (syntax).
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1166
     The parser can be queried for selector, receiver, args, locals,
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1167
     used selectors, modified instvars, referenced classvars etc.
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1168
     The noErrors and noWarnings arguments specify if error and warning 
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1169
     messages should be sent to the Transcript or suppressed."
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1170
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1171
    |parser tree|
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1172
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1173
    aString isNil ifTrue:[^ nil].
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1174
    parser := self for:(ReadStream on:aString) in:aClass.
1365
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  1175
    parser ignoreErrors:ignoreErrors.
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  1176
    parser ignoreWarnings:ignoreWarnings.
629
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1177
    tree := parser parseMethod.
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1178
    (parser errorFlag or:[tree == #Error]) ifTrue:[^ nil].
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1179
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1180
    ReadBeforeWrittenTester searchForReadBeforeWrittenIn:tree
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1181
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1182
    "
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1183
     self
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1184
        checkMethod:'foo
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1185
                        |local1 local2 local3|
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1186
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1187
                        local1 := local2.
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1188
                        ^ local3
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1189
                    '
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1190
        in:UndefinedObject 
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1191
        ignoreErrors:true 
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1192
        ignoreWarnings:true 
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1193
    "
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1194
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1195
    "Modified: / 30.10.1997 / 16:38:31 / cg"
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1196
!
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  1197
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1198
parseExpression:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1199
    "parse aString as an expression; 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1200
     Return the parseTree (if ok), nil (for an empty string 
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1201
     or comment only) or #Error (syntactic error).
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1202
     Error and warning messages are suppressed."
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1203
548
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1204
    ^ self 
1096
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1205
        withSelf:nil 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1206
        parseExpression:aString 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1207
        onError:#Error
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1208
        notifying:nil 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1209
        ignoreErrors:true       "silence on Transcript"
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1210
        ignoreWarnings:true
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1211
        inNameSpace:nil
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1212
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1213
    "
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1214
     Parser parseExpression:'self foo'
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1215
     Parser parseExpression:'self:123'
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1216
     Parser parseExpression:'self:123' onError:nil
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1217
    "
548
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1218
!
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1219
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1220
parseExpression:aString inNameSpace:aNameSpaceOrNil
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1221
    "parse aString as an expression; 
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1222
     Return the parseTree (if ok), nil (for an empty string 
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1223
     or comment only) or #Error (syntactic error).
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1224
     Error and warning messages are suppressed."
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1225
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1226
    ^ self 
1096
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1227
        withSelf:nil 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1228
        parseExpression:aString 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1229
        onError:#Error
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1230
        notifying:nil 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1231
        ignoreErrors:true       "silence on Transcript"
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1232
        ignoreWarnings:true
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1233
        inNameSpace:aNameSpaceOrNil
548
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1234
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1235
    "Modified: 24.6.1997 / 16:44:00 / cg"
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1236
    "Created: 24.6.1997 / 16:44:26 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1237
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1238
1096
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1239
parseExpression:aString inNameSpace:aNameSpaceOrNil onError:errorValue
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1240
    "parse aString as an expression; 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1241
     Return the parseTree (if ok), nil (for an empty string 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1242
     or comment only) or errorValue (syntactic error).
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1243
     Error and warning messages are suppressed."
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1244
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1245
    ^ self 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1246
        withSelf:nil 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1247
        parseExpression:aString 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1248
        onError:errorValue
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1249
        notifying:nil 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1250
        ignoreErrors:true       "silence on Transcript"
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1251
        ignoreWarnings:true
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1252
        inNameSpace:aNameSpaceOrNil
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1253
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1254
    "Modified: 24.6.1997 / 16:44:00 / cg"
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1255
    "Created: 24.6.1997 / 16:44:26 / cg"
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1256
!
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1257
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1258
parseExpression:aString onError:errorValue
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1259
    "parse aString as an expression; 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1260
     Return the parseTree (if ok), nil (for an empty string 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1261
     or comment only) or errorValue (syntactic error).
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1262
     Error and warning messages are suppressed."
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1263
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1264
    ^ self 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1265
        withSelf:nil 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1266
        parseExpression:aString 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1267
        onError:errorValue
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1268
        notifying:nil 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1269
        ignoreErrors:true       "silence on Transcript"
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1270
        ignoreWarnings:true
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1271
        inNameSpace:nil
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1272
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1273
    "Modified: 24.6.1997 / 16:44:00 / cg"
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1274
!
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1275
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1276
parseMethod:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1277
    "parse a method.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1278
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1279
     The parser can be queried for selector, receiver, args, locals,
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1280
     used selectors etc.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1281
     Error and warning messages are sent to the Transcript."
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1282
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1283
    ^ self parseMethod:aString in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1284
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1285
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1286
     |p|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1287
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1288
     p := Parser 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1289
             parseMethod:'
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1290
                 foo:arg1 bar:arg2 baz:arg3 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1291
                     |l1 l2| 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1292
                     l1 := 0. 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1293
                     l2 := arg1. 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1294
                     ^ self'.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1295
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1296
     'nArgs:  ' print. p numberOfMethodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1297
     'args:   ' print. p methodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1298
     'sel:    ' print. p selector printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1299
     'nLocal: ' print. p numberOfMethodVars printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1300
     'locals: ' print. p methodVars printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1301
     'tree:   ' printNL. p tree printAllOn:Stdout. Stdout cr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1302
    "
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1303
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1304
    "Modified: 24.4.1996 / 13:18:02 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1305
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1306
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1307
parseMethod:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1308
    "parse a method in a given class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1309
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1310
     The parser can be queried for selector, receiver, args, locals,
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1311
     used selectors, modified instvars, referenced classvars etc.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1312
     Error and warning messages are sent to the Transcript."
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1313
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1314
    ^ self 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1315
        parseMethod:aString 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1316
        in:aClass 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1317
        ignoreErrors:false 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1318
        ignoreWarnings:false
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1319
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1320
    "Modified: 24.4.1996 / 13:18:34 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1321
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1322
1365
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  1323
parseMethod:aString in:aClass ignoreErrors:ignoreErrors ignoreWarnings:ignoreWarnings
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1324
    "parse a method in a given class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1325
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1326
     The parser can be queried for selector, receiver, args, locals,
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1327
     used selectors, modified instvars, referenced classvars etc.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1328
     The noErrors and noWarnings arguments specify if error and warning 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1329
     messages should be sent to the Transcript or suppressed."
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1330
    |parser tree|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1331
1842
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  1332
    parser := self new. 
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  1333
    tree := parser parseMethod:aString in:aClass ignoreErrors:ignoreErrors ignoreWarnings:ignoreWarnings.
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  1334
    tree isNil ifTrue:[ ^ nil ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1335
    ^ parser
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1336
1842
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  1337
    "Modified: / 21-08-2006 / 18:31:04 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1338
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1339
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1340
parseMethod:aString in:aClass warnings:warnBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1341
    "parse a method in a given class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1342
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1343
     The parser can be queried for selector, receiver, args, locals,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1344
     used selectors, modified instvars, referenced classvars etc.
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1345
     The warnBoolean arguments specifies if warning 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1346
     messages should be sent to the Transcript or suppressed.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1347
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1348
     This method is OBSOLETE, and left in for backward compatibility."
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1349
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1350
    self obsoleteMethodWarning.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1351
    ^ self
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1352
        parseMethod:aString 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1353
        in:aClass 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1354
        ignoreErrors:false 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1355
        ignoreWarnings:warnBoolean not
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1356
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1357
    "Modified: 24.4.1996 / 13:28:05 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1358
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1359
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1360
parseMethodArgAndVarSpecification:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1361
    "parse a methods selector, arg and var spec (i.e. locals);
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1362
     Return a parser (if ok), nil (empty) or #Error (syntax).
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1363
     The parser can be queried for selector, receiver etc.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1364
     Error and warning messages are sent to the Transcript.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1365
     This method is OBSOLETE."
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1366
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1367
    self obsoleteMethodWarning.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1368
    ^ self parseMethodArgAndVarSpecification:aString in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1369
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1370
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1371
     |p|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1372
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1373
     p := Parser 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1374
             parseMethodArgAndVarSpecification:'
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1375
                      foo:arg1 bar:arg2 baz:arg3 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1376
                      |l1 l2|'.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1377
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1378
     'nArgs:  ' print. p numberOfMethodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1379
     'args:   ' print. p methodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1380
     'sel:    ' print. p selector printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1381
     'nLocal: ' print. p numberOfMethodVars printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1382
     'locals: ' print. p methodVars printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1383
    "
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1384
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1385
    "Modified: 24.4.1996 / 13:29:43 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1386
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1387
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1388
parseMethodArgAndVarSpecification:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1389
    "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
  1390
     Return a parser (if ok), nil (empty) or #Error (syntax).
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1391
     The parser can be queried for selector, receiver, args and locals.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1392
     Error and warning messages are sent to the Transcript.
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1393
     This method is OBSOLETE."
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1394
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1395
    self obsoleteMethodWarning.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1396
    ^ self parseMethodArgAndVarSpecification:aString 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1397
           in:aClass 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1398
           ignoreErrors:false
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1399
           ignoreWarnings:false 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1400
           parseBody:false
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1401
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1402
    "Modified: 24.4.1996 / 13:30:03 / cg"
141
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
1365
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  1405
parseMethodArgAndVarSpecification:aString in:aClass ignoreErrors:ignoreErrors ignoreWarnings:ignoreWarnings parseBody:body
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1406
    "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
  1407
     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
  1408
     (for primitives & resourceSpecs).
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1409
     The noErrors and noWarnings arguments specify if error and warning 
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1410
     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
  1411
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1412
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1413
     The parser can be queried for selector, receiver, args and locals"
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1414
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1415
    |parser|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1416
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1417
    aString isNil ifTrue:[^ nil].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1418
    parser := self for:(ReadStream on:aString) in:aClass.
1365
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  1419
    parser ignoreErrors:ignoreErrors.
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  1420
    parser ignoreWarnings:ignoreWarnings.
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1421
"/    parser nextToken.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1422
    (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
  1423
    "/
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1424
    "/ used to be #parseMethodBodyVarSpec
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1425
    "/ - 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
  1426
    "/
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1427
    body ifTrue:[
878
f9c8d2544909 added declare-as (local, global or workspace-war)
Claus Gittinger <cg@exept.de>
parents: 877
diff changeset
  1428
        parser parseMethodBodyOrEmpty
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1429
    ] ifFalse:[
878
f9c8d2544909 added declare-as (local, global or workspace-war)
Claus Gittinger <cg@exept.de>
parents: 877
diff changeset
  1430
        parser parseMethodBodyVarSpec
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1431
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1432
    parser errorFlag ifTrue:[^ nil].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1433
    ^ parser
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1434
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1435
    "Created: 24.4.1996 / 13:13:06 / cg"
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  1436
    "Modified: 27.4.1996 / 16:58:02 / cg"
141
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
parseMethodArgAndVarSpecificationSilent:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1440
    "parse a methods selector, arg and var spec (i.e. locals);
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1441
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1442
     The parser can be queried for selector, receiver etc.
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1443
     Like #parseMethodArgAndVarSpecification:, but does NOT
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1444
     display error/warning messages on the transcript."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1445
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1446
    ^ self parseMethodArgAndVarSpecificationSilent:aString in:nil
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1447
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1448
    "Modified: 24.4.1996 / 13:30:54 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1449
!
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
parseMethodArgAndVarSpecificationSilent:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1452
    "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
  1453
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1454
     The parser can be queried for selector, receiver, args and locals.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1455
     Like #parseMethodArgAndVarSpecification:in:, but does not
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1456
     display error/warning messages on the transcript."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1457
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1458
    ^ self parseMethodArgAndVarSpecification:aString 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1459
           in:aClass 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1460
           ignoreErrors:true 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1461
           ignoreWarnings:true 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1462
           parseBody:false
257
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1463
435dcaed969f dont parse body (when interrested in args & locals only)
Claus Gittinger <cg@exept.de>
parents: 255
diff changeset
  1464
    "Modified: 24.4.1996 / 13:14:27 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1465
!
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
parseMethodSilent:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1468
    "parse a method.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1469
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1470
     The parser can be queried for selector, receiver, args, locals,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1471
     used selectors etc.
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1472
     Like #parseMethod:, but warning/error messages are suppressed."
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1473
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1474
    ^ self parseMethodSilent:aString in:nil
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1475
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1476
    "Modified: 24.4.1996 / 13:32:44 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1477
!
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
parseMethodSilent:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1480
    "parse a method in a given class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1481
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1482
     The parser can be queried for selector, receiver, args, locals,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1483
     used selectors, modified instvars, referenced classvars etc.
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1484
     Like #parseMethod:in:, but warning/error messages are suppressed."
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1485
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1486
    ^ self 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1487
        parseMethod:aString 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1488
        in:aClass 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1489
        ignoreErrors:true 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1490
        ignoreWarnings:true
258
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1491
8de94646c647 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 257
diff changeset
  1492
    "Modified: 24.4.1996 / 13:32:57 / cg"
141
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
parseMethodSpecification:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1496
    "parse a methods selector & arg specification; 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1497
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1498
     The parser can be queried for selector, receiver etc."
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
    ^ self parseMethodSpecification:aString in:nil
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
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1503
     |p|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1504
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1505
     p := Parser parseMethodSpecification:'foo:arg1 bar:arg2 baz:arg3'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1506
     'nArgs: ' print. p numberOfMethodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1507
     'args:  ' print. p methodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1508
     'sel:   ' print. p selector printNL
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1509
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1510
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1511
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1512
parseMethodSpecification:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1513
    "parse a methods selector & arg spec for a given class;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1514
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1515
     The parser can be queried for selector, receiver etc."
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
    ^ self parseMethodSpecification:aString 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1518
           in:aClass 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1519
           ignoreErrors:false
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1520
           ignoreWarnings:false 
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1521
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1522
1365
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  1523
parseMethodSpecification:aString in:aClass ignoreErrors:ignoreErrors ignoreWarnings:ignoreWarnings 
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1524
    "parse a methods selector & arg spec for a given class;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1525
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1526
     The parser can be queried for selector, receiver etc.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1527
     noErrors and noWarnings specify if error- and warningMessages are
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1528
     to be output onto the Transcript."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1529
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1530
    |parser tree|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1531
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1532
    aString isNil ifTrue:[^ nil].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1533
    parser := self for:(ReadStream on:aString) in:aClass.
1365
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  1534
    parser ignoreErrors:ignoreErrors.
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  1535
    parser ignoreWarnings:ignoreWarnings.
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1536
"/    parser nextToken.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1537
    tree := parser parseMethodSpec.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1538
    (parser errorFlag or:[tree == #Error]) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1539
    ^ parser
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1540
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  1541
    "Modified: 20.4.1996 / 20:09:48 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1542
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1543
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1544
parseMethodSpecificationSilent:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1545
    "parse a methods selector & arg specification; 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1546
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1547
     The parser can be queried for selector, receiver etc.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1548
     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
  1549
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1550
    ^ self parseMethodSpecificationSilent:aString in:nil
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
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1553
parseMethodSpecificationSilent:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1554
    "parse a methods selector & arg spec for a given class;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1555
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1556
     The parser can be queried for selector, receiver etc.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1557
     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
  1558
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1559
    ^ self parseMethodSpecification:aString 
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1560
           in:aClass 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1561
           ignoreErrors:true 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  1562
           ignoreWarnings:true
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1563
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1564
    "Created: 31.10.1995 / 14:37:49 / cg"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1565
!
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1566
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1567
selectorInExpression:aString
47
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1568
    "parse an expression - return the selector. Even malformed expressions
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1569
     (such as missing receiver or missing arg are parsed.
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1570
     Used for the SystemBrowsers implementors/senders query-box initial text.
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1571
     Returns nil if unparsable."
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1572
1297
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1573
    |tree parser sel|
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1574
813
4d3ec8ff238c (isNil or:[isEmpty ]) -> (size == 0)
Claus Gittinger <cg@exept.de>
parents: 807
diff changeset
  1575
    (aString size == 0) ifTrue:[^ nil].
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1576
1297
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1577
    Error 
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1578
        handle:[:ex | ]
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1579
        do:[
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1580
            tree := self withSelf:nil 
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1581
                         parseExpression:aString 
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1582
                         notifying:nil 
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1583
                         ignoreErrors:true 
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1584
                         ignoreWarnings:true. 
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1585
        ].
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1586
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1587
    "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1588
     special: take the expression of the right side, if its an
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1589
     assignment or return
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1590
    "
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1591
    (tree notNil and:[tree ~~ #Error]) ifTrue:[
813
4d3ec8ff238c (isNil or:[isEmpty ]) -> (size == 0)
Claus Gittinger <cg@exept.de>
parents: 807
diff changeset
  1592
        (tree isAssignment 
4d3ec8ff238c (isNil or:[isEmpty ]) -> (size == 0)
Claus Gittinger <cg@exept.de>
parents: 807
diff changeset
  1593
        or:[tree isReturnNode]) ifTrue:[
4d3ec8ff238c (isNil or:[isEmpty ]) -> (size == 0)
Claus Gittinger <cg@exept.de>
parents: 807
diff changeset
  1594
            tree expression isMessage ifTrue:[
4d3ec8ff238c (isNil or:[isEmpty ]) -> (size == 0)
Claus Gittinger <cg@exept.de>
parents: 807
diff changeset
  1595
                tree := tree expression
4d3ec8ff238c (isNil or:[isEmpty ]) -> (size == 0)
Claus Gittinger <cg@exept.de>
parents: 807
diff changeset
  1596
            ]
4d3ec8ff238c (isNil or:[isEmpty ]) -> (size == 0)
Claus Gittinger <cg@exept.de>
parents: 807
diff changeset
  1597
        ].
4d3ec8ff238c (isNil or:[isEmpty ]) -> (size == 0)
Claus Gittinger <cg@exept.de>
parents: 807
diff changeset
  1598
        tree isMessage ifTrue:[
4d3ec8ff238c (isNil or:[isEmpty ]) -> (size == 0)
Claus Gittinger <cg@exept.de>
parents: 807
diff changeset
  1599
            ^ tree selector
4d3ec8ff238c (isNil or:[isEmpty ]) -> (size == 0)
Claus Gittinger <cg@exept.de>
parents: 807
diff changeset
  1600
        ].
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1601
    ].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1602
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1603
    "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1604
     mhmh, try expression without receiver
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1605
    "
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1606
    parser := self for:(ReadStream on:aString).
1365
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  1607
    parser ignoreErrors:true.
1297
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1608
    Error 
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1609
        handle:[:ex | ]
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1610
        do:[
1482
d80c83f1167a catch twoByte string parsing in selectorInExpression
Claus Gittinger <cg@exept.de>
parents: 1471
diff changeset
  1611
            parser nextToken.
1297
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1612
            sel := parser degeneratedKeywordExpressionForSelector
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1613
        ].
67332caafef7 catch errors when extracting a message selector
Claus Gittinger <cg@exept.de>
parents: 1295
diff changeset
  1614
    ^ sel
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1615
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1616
"
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1617
    Parser selectorInExpression:'foo at:1 put:(5 * bar)'     
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1618
    Parser selectorInExpression:'(foo at:1) at:1'           
47
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1619
    Parser selectorInExpression:'a + 4'                     
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1620
    Parser selectorInExpression:'a negated'                 
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1621
    Parser selectorInExpression:'at:1 put:5'            
47
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1622
    Parser selectorInExpression:'at:1 put:'            
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1623
    Parser selectorInExpression:'a at:1 put:5'            
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  1624
    Parser selectorInExpression:'a at:1 put:'            
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1625
    Parser selectorInExpression:'a := foo at:1 put:5'    
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1626
"
451
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1627
9e116ffc172c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 450
diff changeset
  1628
    "Modified: 17.12.1996 / 12:12:47 / cg"
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1629
!
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1630
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1631
withSelf:anObject parseExpression:aString notifying:someOne 
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1632
    "parse aString as an expression with self set to anObject;
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1633
     Return the parseTree (if ok), nil (for an empty string 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1634
     or comment only ) or #Error (syntactic error).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1635
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1636
     Errors and warnings are forwarded to someOne (usually some
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1637
     codeView) which can highlight it and show a popup box."
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1638
548
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1639
    ^ self 
1096
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1640
        withSelf:anObject 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1641
        parseExpression:aString 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1642
        onError:#Error
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1643
        notifying:someOne 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1644
        ignoreErrors:false 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1645
        ignoreWarnings:false 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1646
        inNameSpace:nil
548
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1647
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1648
    "Modified: 24.6.1997 / 16:43:37 / cg"
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1649
!
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1650
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  1651
withSelf:anObject parseExpression:aString notifying:someOne ignoreErrors:ignore
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1652
    "parse aString as an expression with self set to anObject;
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1653
     Return the parseTree (if ok), nil (for an empty string 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1654
     or comment only ) or #Error (syntactic error).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1655
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1656
     Errors and warnings are forwarded to someOne (usually some
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1657
     codeView) which can highlight it and show a popup box."
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1658
548
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1659
    ^ self 
1096
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1660
        withSelf:anObject
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1661
        parseExpression:aString 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1662
        onError:#Error
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1663
        notifying:someOne 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1664
        ignoreErrors:ignore 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1665
        ignoreWarnings:ignore 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1666
        inNameSpace:nil
548
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1667
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1668
    "Modified: 24.6.1997 / 16:43:26 / cg"
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1669
!
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1670
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1671
withSelf:anObject parseExpression:aString notifying:someOne ignoreErrors:ignoreErrors ignoreWarnings:ignoreWarnings
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1672
    "parse aString as an expression with self set to anObject;
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1673
     Return the parseTree (if ok), nil (for an empty string 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1674
     or comment only ) or #Error (syntactic error).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1675
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1676
     Errors and warnings are forwarded to someOne (usually some
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1677
     codeView) which can highlight it and show a popup box,
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1678
     iff ignoreErrors/ignoreWarnings is true respectively."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1679
548
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1680
    ^ self
1096
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1681
        withSelf:anObject 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1682
        parseExpression:aString
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1683
        onError:#Error
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1684
        notifying:someOne 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1685
        ignoreErrors:ignoreErrors 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1686
        ignoreWarnings:ignoreWarnings 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1687
        inNameSpace:nil
548
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1688
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1689
    "Modified: 24.6.1997 / 16:43:12 / cg"
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1690
!
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1691
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1692
withSelf:anObject parseExpression:aString notifying:someOne ignoreErrors:ignoreErrors ignoreWarnings:ignoreWarnings inNameSpace:aNameSpaceOrNil
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1693
    "parse aString as an expression with self set to anObject;
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1694
     Return the parseTree (if ok), nil (for an empty string 
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1695
     or comment only ) or #Error (syntactic error).
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1696
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1697
     Errors and warnings are forwarded to someOne (usually some
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1698
     codeView) which can highlight it and show a popup box,
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1699
     iff ignoreErrors/ignoreWarnings is true respectively."
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1700
1096
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1701
    ^ self
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1702
        withSelf:anObject 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1703
        parseExpression:aString 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1704
        onError:#Error 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1705
        notifying:someOne 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1706
        ignoreErrors:ignoreErrors 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1707
        ignoreWarnings:ignoreWarnings 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1708
        inNameSpace:aNameSpaceOrNil
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1709
!
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1710
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1711
withSelf:anObject parseExpression:aString onError:errorValue notifying:someOne ignoreErrors:ignoreErrors ignoreWarnings:ignoreWarnings inNameSpace:aNameSpaceOrNil
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1712
    "parse aString as an expression with self set to anObject;
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1713
     Return the parseTree (if ok), nil (for an empty string 
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1714
     or comment only ) or errorValue (syntactic error).
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1715
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1716
     Errors and warnings are forwarded to someOne (usually some
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1717
     codeView) which can highlight it and show a popup box,
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1718
     iff ignoreErrors/ignoreWarnings is true respectively."
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1719
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1720
    |parser tree|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1721
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1722
    aString isNil ifTrue:[^ nil].
548
79948fed91a7 added entry to parse an expression in a specific nameSpace
Claus Gittinger <cg@exept.de>
parents: 547
diff changeset
  1723
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1724
    parser := self for:(ReadStream on:aString).
1096
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1725
    tree := parser 
1006
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  1726
        parseExpressionWithSelf:anObject 
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  1727
        notifying:someOne 
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  1728
        ignoreErrors:ignoreErrors 
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  1729
        ignoreWarnings:ignoreWarnings 
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  1730
        inNameSpace:aNameSpaceOrNil.
1096
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1731
    tree == #Error ifTrue:[
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1732
        ^ errorValue value
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1733
    ].
d1d897aba4d5 added #parseExpression:onError: protocol.
Claus Gittinger <cg@exept.de>
parents: 1091
diff changeset
  1734
    ^ tree
1006
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  1735
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  1736
    "Modified: / 14.12.1999 / 15:12:16 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1737
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1738
1621
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1739
!Parser class methodsFor:'private'!
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1740
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1741
makeImmutableArray:anArray
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1742
    |newArray|
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1743
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1744
    newArray := anArray copy.
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1745
    ImmutableArray notNil ifTrue:[
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1746
        newArray changeClassTo:ImmutableArray.
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1747
    ].
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1748
    newArray beImmutable.
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1749
    ^ newArray
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1750
!
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1751
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1752
makeImmutableString:aString
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1753
    |newString|
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1754
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1755
    newString := aString copy.
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1756
    ImmutableString notNil ifTrue:[
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1757
        newString changeClassTo:ImmutableString.
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1758
    ].
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1759
    newString beImmutable.
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1760
    ^ newString
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1761
! !
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  1762
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  1763
!Parser class methodsFor:'unparsing'!
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1764
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1765
methodSpecificationForSelector:aSelector
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1766
    "given a selector such as #foo:bar:, return a string that could
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1767
     serve as a methods specification source code.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1768
     To be used for code generators"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1769
807
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1770
    |argNames n|
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1771
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1772
    n := aSelector numArgs.
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1773
    n == 1 ifTrue:[
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1774
        argNames := #('arg')
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1775
    ] ifFalse:[
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1776
        n <= 15 ifTrue:[
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1777
            argNames := #('arg1' 'arg2' 'arg3' 'arg4' 'arg5' 'arg6'
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1778
                          'arg7' 'arg8' 'arg9' 'arg10' 'arg11' 'arg12'
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1779
                          'arg13' 'arg14' 'arg15')
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1780
        ] ifFalse:[
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1781
            argNames := (1 to:aSelector numArgs) collect:[:i | 'arg' , i printString].
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1782
        ].
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1783
    ].
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1784
    ^ self methodSpecificationForSelector:aSelector argNames:argNames
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1785
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1786
    "
807
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1787
     Parser methodSpecificationForSelector:#foo:   
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1788
     Parser methodSpecificationForSelector:#foo:bar:   
807
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1789
     Parser methodSpecificationForSelector:#foo:bar:baz:   
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  1790
     Parser methodSpecificationForSelector:#+       
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1791
     Parser methodSpecificationForSelector:#negated   
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1792
    "
807
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1793
8434698556de *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 806
diff changeset
  1794
    "Modified: / 12.2.1999 / 13:12:44 / cg"
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1795
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1796
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1797
methodSpecificationForSelector:aSelector argNames:argNames
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1798
    "given a selector such as #foo:bar:, return a string that could
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1799
     serve as a methods specification source code.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1800
     To be used for code generators"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1801
806
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1802
    |s nargs parts part|
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1803
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1804
    s := WriteStream on:String new.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1805
    nargs := aSelector numArgs.
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1806
    nargs == 0 ifTrue:[
806
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1807
        s nextPutAll:aSelector
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1808
    ] ifFalse:[
806
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1809
        parts := aSelector partsIfSelector.
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1810
        1 to:nargs do:[:i |
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1811
            part := parts at:i.
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1812
            s nextPutAll:part.
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1813
            (part endsWith:$:) ifFalse:[
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1814
                s space.
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1815
            ].
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1816
            s nextPutAll:(argNames at:i).
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1817
            i ~~ nargs ifTrue:[s space].
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1818
        ]
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1819
    ].
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1820
    ^ s contents
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1821
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1822
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1823
     Parser methodSpecificationForSelector:#foo:bar: argNames:#('one' 'two' 'three')  
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1824
     Parser methodSpecificationForSelector:#+ argNames:#('one')  
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1825
     Parser methodSpecificationForSelector:#negated   
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1826
    "
806
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1827
bbfd3018e32e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 805
diff changeset
  1828
    "Modified: / 12.2.1999 / 12:33:50 / cg"
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1829
! !
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
  1830
1417
7e97dd2df5ca method category rename
Claus Gittinger <cg@exept.de>
parents: 1413
diff changeset
  1831
!Parser methodsFor:'Compatibility-ST80'!
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1832
918
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1833
evaluate:aString in:aClassOrContext to:to notifying:aRequestor ifFail:failBlock
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1834
    |parseTree value|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1835
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1836
    aString isNil ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1837
    self initializeFor:(ReadStream on:aString).
918
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1838
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1839
    "/ stupid - there seem to be differences among the various
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1840
    "/ ST dialects ...
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1841
    aClassOrContext isBehavior ifTrue:[
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1842
        self setClassToCompileFor:aClassOrContext.
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1843
        selfValue := nil.
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1844
    ] ifFalse:[
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1845
        self setContext:aClassOrContext.
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1846
        aClassOrContext notNil ifTrue:[
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1847
            self setSelf:(aClassOrContext receiver)
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1848
        ].
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1849
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1850
    requestor := aRequestor.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1851
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1852
    self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1853
    parseTree := self parseMethodBody.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1854
    (errorFlag or:[tree == #Error]) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1855
    parseTree notNil ifTrue:[
918
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1856
        self evalExitBlock:[:value | ^ failBlock value].
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1857
        value := parseTree evaluate
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1858
    ].
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1859
    self release.
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1860
    ^ value
547
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1861
!
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1862
624
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1863
parse:methodSource in:aClass notifying:aRequestor
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1864
    "parse a methods source.
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1865
     Return the methods parseTree"
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1866
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1867
    self initializeFor:methodSource.
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1868
    classToCompileFor := aClass.
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1869
    requestor := aRequestor.
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1870
    self parseMethod.
918
e088f51a649e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 915
diff changeset
  1871
624
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1872
    ^ MethodNode new
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1873
        selector:selector
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1874
        arguments:methodArgs
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1875
        locals:methodVars
1207
8b07493663e4 *** empty log message ***
james
parents: 1206
diff changeset
  1876
        statements:tree asCollectionOfStatements
624
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1877
1214
df80d1034ebe *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1212
diff changeset
  1878
    "Created: / 17.10.1997 / 12:35:01 / cg"
df80d1034ebe *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1212
diff changeset
  1879
    "Modified: / 5.11.2001 / 16:56:43 / cg"
624
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1880
!
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1881
547
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1882
parseSelector:aStringOrStream
624
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1883
    "parse a methods source for the methods selector.
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1884
     Return the selector"
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1885
547
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1886
    self initializeFor:aStringOrStream.
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1887
    self parseMethodSpec.
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1888
    ^ selector.
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1889
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1890
    "
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1891
     Parser new
624
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1892
        parseSelector:'
547
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1893
parseSelector:aStringOrStream
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1894
    self initializeFor:aStringOrStream.
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1895
    self parseMethodSpec.
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1896
    ^ selector.
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1897
'                 
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1898
    "
5a51414daf36 added #parseSelector for ST80 compatibility
Claus Gittinger <cg@exept.de>
parents: 541
diff changeset
  1899
624
e71abe9654e6 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 619
diff changeset
  1900
    "Modified: 17.10.1997 / 12:35:46 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1901
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1902
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1903
!Parser methodsFor:'accessing'!
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1904
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1905
correctedSource
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1906
    ^ correctedSource
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1907
!
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1908
1605
9c50ef665ee9 changes to allow for kludge-environments
Claus Gittinger <cg@exept.de>
parents: 1604
diff changeset
  1909
doItTemporaries
9c50ef665ee9 changes to allow for kludge-environments
Claus Gittinger <cg@exept.de>
parents: 1604
diff changeset
  1910
    ^ doItTemporaries
9c50ef665ee9 changes to allow for kludge-environments
Claus Gittinger <cg@exept.de>
parents: 1604
diff changeset
  1911
!
9c50ef665ee9 changes to allow for kludge-environments
Claus Gittinger <cg@exept.de>
parents: 1604
diff changeset
  1912
1581
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  1913
endOfLastToken
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  1914
    ^ tokenPosition
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  1915
!
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  1916
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  1917
endOfSelectorPosition
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  1918
    "return the sourcePosition of the last character of the methods selector spec"
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  1919
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  1920
    ^ endOfSelectorPosition
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  1921
!
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  1922
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1923
errorFlag
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1924
    "return true if there where any errors (valid after parsing)"
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
    ^ errorFlag
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1927
!
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
evalExitBlock:aBlock
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1930
    "when evaluating a return expression, this block is evaluated"
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
    evalExitBlock := aBlock
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1933
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1934
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1935
getNameSpace
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1936
    "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
  1937
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1938
    ^ currentNamespace
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1939
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1940
    "Modified: 8.11.1996 / 13:45:35 / cg"
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1941
!
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1942
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  1943
implicitSelfSends
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  1944
    ^ parserFlags implicitSelfSends
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  1945
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  1946
1571
1b49d2313067 +implicitSelfSends
Claus Gittinger <cg@exept.de>
parents: 1570
diff changeset
  1947
implicitSelfSends:aBoolean
1b49d2313067 +implicitSelfSends
Claus Gittinger <cg@exept.de>
parents: 1570
diff changeset
  1948
    "turn on/off implicit self sends"
1b49d2313067 +implicitSelfSends
Claus Gittinger <cg@exept.de>
parents: 1570
diff changeset
  1949
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  1950
    parserFlags implicitSelfSends:aBoolean
1571
1b49d2313067 +implicitSelfSends
Claus Gittinger <cg@exept.de>
parents: 1570
diff changeset
  1951
!
1b49d2313067 +implicitSelfSends
Claus Gittinger <cg@exept.de>
parents: 1570
diff changeset
  1952
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1953
primitiveNumber
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1954
    "return the ST-80 style primitiveNumber or nil (valid after parsing)"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1955
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1956
    ^ primitiveNr
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  1957
!
97
claus
parents: 96
diff changeset
  1958
285
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1959
primitiveResources
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1960
    "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
  1961
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1962
    ^ primitiveResource
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1963
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1964
    "Created: 29.5.1996 / 17:28:00 / cg"
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1965
!
19e8d6d22278 allow multiple resource definitions
Claus Gittinger <cg@exept.de>
parents: 273
diff changeset
  1966
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1967
release
664
63d1460e8ee3 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 663
diff changeset
  1968
    methodArgs := methodVars := tree := selfNode := superNode := nilNode := nil.
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1969
    super release.
664
63d1460e8ee3 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 663
diff changeset
  1970
63d1460e8ee3 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 663
diff changeset
  1971
    "Modified: / 31.3.1998 / 19:45:58 / cg"
90
claus
parents: 87
diff changeset
  1972
!
claus
parents: 87
diff changeset
  1973
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1974
setNameSpace:aNameSpaceName
1041
98fa50f8353f renamed Namespace to NameSpace
Claus Gittinger <cg@exept.de>
parents: 1040
diff changeset
  1975
    currentNamespace := NameSpace fullName:aNameSpaceName
427
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1976
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1977
    "Modified: 8.11.1996 / 13:43:14 / cg"
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1978
!
3d6a4d002824 pass remembered nameSpace back from upQueries
Claus Gittinger <cg@exept.de>
parents: 424
diff changeset
  1979
1247
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  1980
setPackage:aPackageID
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  1981
    currentPackage := aPackageID
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  1982
!
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  1983
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1984
targetClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1985
    ^ classToCompileFor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1986
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1987
90
claus
parents: 87
diff changeset
  1988
targetClass:aClass
117
claus
parents: 103
diff changeset
  1989
    classToCompileFor := aClass
claus
parents: 103
diff changeset
  1990
!
claus
parents: 103
diff changeset
  1991
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1992
tree
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1993
    "return the parsetree"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1994
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1995
    ^tree
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1996
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1997
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1998
tree:aTree
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1999
    "private: set the tree - for internal use only"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2000
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2001
    tree := aTree
1363
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  2002
!
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  2003
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  2004
warnSTXHereExtensionUsed
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  2005
    ^ parserFlags warnSTXHereExtensionUsed
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  2006
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  2007
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  2008
warnSTXHereExtensionUsed:aBoolean
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  2009
    parserFlags warnSTXHereExtensionUsed:aBoolean
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2010
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2011
1418
4aae7d34124a method category rename
Claus Gittinger <cg@exept.de>
parents: 1417
diff changeset
  2012
!Parser methodsFor:'dummy-syntax detection'!
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  2013
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  2014
markArgumentIdentifierFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2015
    "intentionally left empty"
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  2016
!
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  2017
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  2018
markBadIdentifierFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2019
    "intentionally left empty"
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  2020
!
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  2021
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2022
markBooleanConstantFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2023
    "intentionally left empty"
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2024
!
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2025
673
0c66b7cb1d2f checkin from browser
ca
parents: 672
diff changeset
  2026
markBracketAt:pos
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2027
    "intentionally left empty"
673
0c66b7cb1d2f checkin from browser
ca
parents: 672
diff changeset
  2028
!
0c66b7cb1d2f checkin from browser
ca
parents: 672
diff changeset
  2029
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2030
markConstantFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2031
    "intentionally left empty"
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2032
!
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2033
822
a773bb72cbd6 added extra globalClassIdentifierColor & emphasis
Claus Gittinger <cg@exept.de>
parents: 815
diff changeset
  2034
markGlobalClassIdentifierFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2035
    "intentionally left empty"
822
a773bb72cbd6 added extra globalClassIdentifierColor & emphasis
Claus Gittinger <cg@exept.de>
parents: 815
diff changeset
  2036
!
a773bb72cbd6 added extra globalClassIdentifierColor & emphasis
Claus Gittinger <cg@exept.de>
parents: 815
diff changeset
  2037
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2038
markGlobalIdentifierFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2039
    "intentionally left empty"
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2040
!
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2041
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2042
markHereFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2043
    "intentionally left empty"
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2044
!
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2045
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2046
markIdentifierFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2047
    "intentionally left empty"
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2048
!
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2049
687
27565829b5d4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 685
diff changeset
  2050
markInstVarIdentifierFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2051
    "intentionally left empty"
687
27565829b5d4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 685
diff changeset
  2052
!
27565829b5d4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 685
diff changeset
  2053
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2054
markLocalIdentifierFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2055
    "intentionally left empty"
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2056
!
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2057
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2058
markMethodSelectorFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2059
    "intentionally left empty"
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2060
!
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2061
1640
261459ccc704 emphasize parenthesis nesting
Claus Gittinger <cg@exept.de>
parents: 1638
diff changeset
  2062
markParenthesisAt:pos
261459ccc704 emphasize parenthesis nesting
Claus Gittinger <cg@exept.de>
parents: 1638
diff changeset
  2063
    "intentionally left empty"
261459ccc704 emphasize parenthesis nesting
Claus Gittinger <cg@exept.de>
parents: 1638
diff changeset
  2064
!
261459ccc704 emphasize parenthesis nesting
Claus Gittinger <cg@exept.de>
parents: 1638
diff changeset
  2065
837
b09e08bb3d5e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 832
diff changeset
  2066
markReturnAt:pos
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2067
    "intentionally left empty"
837
b09e08bb3d5e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 832
diff changeset
  2068
!
b09e08bb3d5e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 832
diff changeset
  2069
864
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  2070
markSelector:sel from:pos1 to:pos2 receiverNode:aNode
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2071
    "intentionally left empty"
864
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  2072
!
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  2073
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2074
markSelfFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2075
    "intentionally left empty"
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2076
!
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2077
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  2078
markSuperFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2079
    "intentionally left empty"
664
63d1460e8ee3 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 663
diff changeset
  2080
!
63d1460e8ee3 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 663
diff changeset
  2081
63d1460e8ee3 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 663
diff changeset
  2082
markUnknownIdentifierFrom:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2083
    "intentionally left empty"
687
27565829b5d4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 685
diff changeset
  2084
!
27565829b5d4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 685
diff changeset
  2085
27565829b5d4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 685
diff changeset
  2086
markVariable:v
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2087
    "intentionally left empty"
687
27565829b5d4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 685
diff changeset
  2088
!
27565829b5d4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 685
diff changeset
  2089
27565829b5d4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 685
diff changeset
  2090
markVariable:v from:pos1 to:pos2
1525
fefc1f7fd071 *** empty log message ***
ca
parents: 1524
diff changeset
  2091
    "intentionally left empty"
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  2092
! !
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  2093
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2094
!Parser methodsFor:'error correction'!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2095
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2096
addDoItTemporary:varName
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2097
    |holder|
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2098
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2099
    doItTemporaries isNil ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2100
        doItTemporaries := IdentityDictionary new.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2101
    ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2102
    doItTemporaries at:varName asSymbol put:(holder := ValueHolder new).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2103
    ^ holder
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2104
!
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2105
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2106
askForCorrection:aString fromList:aList
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2107
    "launch a selection box, which allows user to enter correction.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2108
     return newString or nil (for abort)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2109
1323
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2110
    |box rslt|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2111
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2112
    "in systems without widgets ..."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2113
    ListSelectionBox isNil ifTrue:[
1285
32af9747bf9d error messages
Claus Gittinger <cg@exept.de>
parents: 1282
diff changeset
  2114
        ^ self confirm:aString
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2115
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2116
    box := ListSelectionBox title:aString.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2117
    box initialText:(aList at:1).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2118
    box list:aList.
1285
32af9747bf9d error messages
Claus Gittinger <cg@exept.de>
parents: 1282
diff changeset
  2119
    box okText:'Correct'.
1323
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2120
    box action:[:aString | rslt := aString].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2121
    box showAtPointer.
1323
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2122
    box destroy.
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2123
    ^ rslt
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2124
!
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2125
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2126
askForCorrection:aString fromList:aList for:originalSelector
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2127
    "launch a selection box, which allows user to enter correction.
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2128
     return newString or nil (for abort)"
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2129
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2130
    |box rslt|
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2131
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2132
    "in systems without widgets ..."
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2133
    ListSelectionBox isNil ifTrue:[
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2134
        ^ self confirm:aString
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2135
    ].
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2136
    box := ListSelectionBox title:aString.
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2137
    box initialText:(aList at:1).
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2138
    box list:aList.
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2139
    box okText:'Correct'.
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2140
    box action:[:aString | rslt := aString].
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2141
    box addButton:(Button label:'Keep Selector' action:[rslt := originalSelector. box hide]) after:(box okButton).
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2142
    box showAtPointer.
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2143
    box destroy.
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2144
    ^ rslt
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2145
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2146
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2147
askForVariableTypeWhenDeclaringUndefined:varName
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2148
    |l how varNameIsLowercase choice holder newClass|
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2149
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2150
    l := #().
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2151
    how := #().
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2152
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2153
    varNameIsLowercase := (varName at:1) isLowercase.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2154
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2155
    "/ BlockVar, InstVar and classInstVar not yet implemented
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2156
    varNameIsLowercase ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2157
"/            currentBlock notNil ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2158
"/                l := l , #( 'Block local' ).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2159
"/                how := how , #( BlockVariable ).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2160
"/            ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2161
        selector notNil ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2162
            l := l , #( 'Method Local Variable' ).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2163
            how := how , #( MethodVariable ).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2164
        ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2165
        (classToCompileFor notNil
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2166
        and:[classToCompileFor isMeta not
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2167
        and:[classToCompileFor isBuiltInClass not 
1440
7084ae99ced7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1439
diff changeset
  2168
        and:[(self isDoIt not)]]]) ifTrue:[
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2169
            l := l copyWith:'Instance Variable'.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2170
            how := how copyWith: #InstanceVariable.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2171
        ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2172
    ] ifFalse:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2173
        l := l , #( 'New Class' 'Global' 'NameSpace' ).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2174
        how := how , #( NewClass GlobalVariable NameSpace ).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2175
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2176
        (classToCompileFor notNil
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2177
        and:[classToCompileFor isBuiltInClass not
1440
7084ae99ced7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1439
diff changeset
  2178
        and:[self isDoIt not]]) ifTrue:[
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2179
            classToCompileFor isMeta ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2180
                l := l , #('Class Instance Variable').
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2181
                how := how , #( ClassInstanceVariable).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2182
            ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2183
            l := l , #('Class Variable' ).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2184
            how := how , #( ClassVariable).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2185
        ]
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2186
    ].
1440
7084ae99ced7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1439
diff changeset
  2187
    self isDoIt ifTrue:[
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2188
        l size > 0 ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2189
            l := l ,  #( '-' ).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2190
            how := how , #( nil ).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2191
        ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2192
        l := l , #( 'Workspace Variable' 'DoIt Temporary').
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2193
        how := how , #( WorkspaceVariable DoItTemporary ).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2194
    ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2195
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2196
    l size > 0 ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2197
        l := (Array with:('Declare ' , varName allBold , ' as:') 
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2198
                    with:'-'
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2199
             ) , l.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2200
        how := #(nil nil) , how.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2201
        choice := (PopUpMenu labels:l) startUp.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2202
        (choice notNil and:[choice > 0]) ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2203
            choice := how at:choice.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2204
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2205
            choice == #WorkspaceVariable ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2206
                holder := Workspace addWorkspaceVariable:varName.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2207
                ^ VariableNode type:#WorkspaceVariable holder:holder name:varName
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2208
            ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2209
            choice == #DoItTemporary ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2210
                holder := self addDoItTemporary:varName.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2211
                ^ VariableNode type:#DoItTemporary holder:holder name:varName
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2212
            ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2213
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2214
            choice == #GlobalVariable ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2215
                Smalltalk at:varName asSymbol put:nil.
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  2216
                ^ VariableNode globalNamed:varName
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2217
            ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2218
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2219
            choice == #NewClass ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2220
                newClass := Object subclass:varName asSymbol
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2221
                       instanceVariableNames:''
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2222
                       classVariableNames:''
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2223
                       poolDictionaries:''
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2224
                       category:'* As yet uncategorized *'.
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  2225
                ^ VariableNode globalNamed:newClass name
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2226
            ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2227
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2228
            choice == #NameSpace ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2229
                NameSpace name:varName.
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  2230
                ^ VariableNode globalNamed:varName
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2231
            ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2232
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2233
            choice == #ClassVariable ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2234
                classToCompileFor theNonMetaclass addClassVarName:varName.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2235
                ^ VariableNode type:#ClassVariable class:classToCompileFor theNonMetaclass name:varName
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2236
            ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2237
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2238
            choice == #InstanceVariable ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2239
                classToCompileFor theNonMetaclass addInstVarName:varName.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2240
                "/ ST/X special - classToCompileFor is obsoleted
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2241
                classToCompileFor := Smalltalk classNamed:(classToCompileFor name).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2242
                RestartCompilationSignal raise.    
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2243
                "/ not reached - restarted compile will not arrive here again
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2244
                self error:'restart compile failed'.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2245
            ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2246
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2247
            choice == #ClassInstanceVariable ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2248
                classToCompileFor theMetaclass addInstVarName:varName.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2249
                "/ ST/X special - classToCompileFor is obsoleted
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2250
                classToCompileFor := Smalltalk classNamed:(classToCompileFor name).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2251
                RestartCompilationSignal raise.    
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2252
                "/ not reached - restarted compile will not arrive here again
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2253
                self error:'restart compile failed'.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2254
            ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2255
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2256
            choice == #MethodVariable ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2257
                |varIndex var endLocalsPos posToInsert ins|
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2258
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2259
                localVarDefPosition size == 2 ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2260
                    endLocalsPos := posToInsert := localVarDefPosition at:2.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2261
                    ins := ' ' , varName.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2262
                ] ifFalse:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2263
                    endOfSelectorPosition notNil ifTrue:[
1581
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  2264
                         posToInsert := beginOfBodyPosition.
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2265
                         ins := '|' , varName , '|' , Character cr asString , Character cr asString.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2266
                         ins := ins , (String new:(requestor colOfCharacterPosition:posToInsert)-1).   
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2267
                    ]
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2268
                ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2269
                posToInsert notNil ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2270
                    requestor 
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2271
                        insertString:ins
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2272
                        atCharacterPosition:posToInsert.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2273
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2274
                    endLocalsPos notNil ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2275
                        localVarDefPosition at:2 put:(endLocalsPos + varName size + 1).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2276
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2277
                        methodVarNames := methodVarNames copyWith:varName.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2278
                        methodVars := methodVars copyWith:(var := Variable new name:varName).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2279
                    ] ifFalse:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2280
                        localVarDefPosition := Array with:posToInsert with:posToInsert+varName size+1.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2281
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2282
                        methodVarNames := Array with:varName.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2283
                        methodVars := Array with:(var := Variable new name:varName).
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2284
                    ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2285
                    correctedSource := requestor currentSourceCode.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2286
                    source := (ReadStream on:correctedSource)
1371
de4c37ac12fc code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 1369
diff changeset
  2287
                                  position:(source position1Based + ins size).
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2288
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2289
                    varIndex := methodVarNames size.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2290
                    var used:true.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2291
                    ^ VariableNode type:#MethodVariable
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2292
                                   name:varName
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2293
                                   token:var
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2294
                                   index:varIndex
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2295
                ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2296
            ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2297
            self warning:'Sorry - unimplemented (adding ' , choice , ')'.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2298
        ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2299
        ^ #Error
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2300
    ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2301
    ^ nil.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2302
!
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2303
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2304
checkBlockArgumentNameConventionsFor:aVariableName
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2305
    self checkLocalVariableNameConventionsFor:aVariableName.
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2306
!
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2307
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2308
checkBlockVariableNameConventionsFor:aVariableName
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2309
    self checkLocalVariableNameConventionsFor:aVariableName.
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2310
!
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2311
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2312
checkForLowercaseVariableName:aVariableName
1696
4b0db823d6a2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1692
diff changeset
  2313
    aVariableName isUppercaseFirst ifTrue:[
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2314
        self 
1675
7812281ecfbd some errors are really warnings.
Claus Gittinger <cg@exept.de>
parents: 1664
diff changeset
  2315
            warning:('variable "' , aVariableName , '" should be lowercase (by convention)')
1812
4b97e5ff40d0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1803
diff changeset
  2316
            doNotShowAgainAction:[ parserFlags warnAboutNonLowercaseLocalVariableNames:false]
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2317
            position:tokenPosition to:source position1Based - 1.
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2318
    ].
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2319
!
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2320
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2321
checkForProperUseOfArticleInVariableName:aVariableName
1632
3c30939fd03f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
  2322
    |firstCharacterAfterArticle whatShouldItBeNamed|
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2323
1521
3488542e7a83 checkVariable-conventions: can be disabled via classVar.
Claus Gittinger <cg@exept.de>
parents: 1520
diff changeset
  2324
    aVariableName size > 4 ifTrue:[ 
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2325
        (aVariableName startsWith:'an') ifTrue:[
1632
3c30939fd03f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
  2326
            firstCharacterAfterArticle := aVariableName at:3.
3c30939fd03f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
  2327
            firstCharacterAfterArticle isUppercase ifTrue:[
3c30939fd03f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
  2328
                ('AEIOX' includes:firstCharacterAfterArticle) ifFalse:[
1643
b52ed0b4a317 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1642
diff changeset
  2329
                    ((aVariableName copyFrom:3) startsWith:'Up') ifFalse:[
b52ed0b4a317 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1642
diff changeset
  2330
                        whatShouldItBeNamed := 'a' , (aVariableName copyFrom:3).
b52ed0b4a317 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1642
diff changeset
  2331
                    ]
1632
3c30939fd03f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
  2332
                ]
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2333
            ].
1643
b52ed0b4a317 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1642
diff changeset
  2334
        ] ifFalse:[
b52ed0b4a317 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1642
diff changeset
  2335
            (aVariableName startsWith:'a') ifTrue:[
b52ed0b4a317 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1642
diff changeset
  2336
                firstCharacterAfterArticle := aVariableName at:2.
b52ed0b4a317 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1642
diff changeset
  2337
                firstCharacterAfterArticle isUppercase ifTrue:[
b52ed0b4a317 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1642
diff changeset
  2338
                    ('AEIOX' includes:firstCharacterAfterArticle) ifTrue:[
1650
71fcb0a081ff *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1647
diff changeset
  2339
                        ((aVariableName copyFrom:2) asLowercase startsWith:'one') ifFalse:[
71fcb0a081ff *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1647
diff changeset
  2340
                            whatShouldItBeNamed := 'an' , (aVariableName copyFrom:2).
71fcb0a081ff *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1647
diff changeset
  2341
                        ]
1643
b52ed0b4a317 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1642
diff changeset
  2342
                    ].
1521
3488542e7a83 checkVariable-conventions: can be disabled via classVar.
Claus Gittinger <cg@exept.de>
parents: 1520
diff changeset
  2343
                ].
3488542e7a83 checkVariable-conventions: can be disabled via classVar.
Claus Gittinger <cg@exept.de>
parents: 1520
diff changeset
  2344
            ].
3488542e7a83 checkVariable-conventions: can be disabled via classVar.
Claus Gittinger <cg@exept.de>
parents: 1520
diff changeset
  2345
        ].
1632
3c30939fd03f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
  2346
        whatShouldItBeNamed notNil ifTrue:[
3c30939fd03f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
  2347
            self 
3c30939fd03f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
  2348
                warnCommonMistake:('variable "',aVariableName,'" should be named "',whatShouldItBeNamed,'" (by english language rules)')
3c30939fd03f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
  2349
                position:tokenPosition to:source position1Based - 1.
3c30939fd03f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1631
diff changeset
  2350
        ].
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2351
    ].
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2352
!
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2353
1512
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  2354
checkIfAllSubclassesOf:aClass implement:aSelector
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  2355
    (aClass subclasses 
1517
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2356
        contains:[:cls | (cls implements:aSelector) not]) ifTrue:[^ false].
1512
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  2357
    ^ true.
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  2358
!
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  2359
1522
777862196320 checkVariable-conventions: can be (are by default) disabled via classVar.
Claus Gittinger <cg@exept.de>
parents: 1521
diff changeset
  2360
checkLocalVariableNameConventionsFor:aVariableName 
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  2361
    parserFlags warnAboutVariableNameConventions == true ifTrue:[
1812
4b97e5ff40d0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1803
diff changeset
  2362
        parserFlags warnAboutNonLowercaseLocalVariableNames == true ifTrue:[
1739
64731d67f059 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1736
diff changeset
  2363
            self checkForLowercaseVariableName:aVariableName.
64731d67f059 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1736
diff changeset
  2364
        ]
1522
777862196320 checkVariable-conventions: can be (are by default) disabled via classVar.
Claus Gittinger <cg@exept.de>
parents: 1521
diff changeset
  2365
    ].
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  2366
    parserFlags warnAboutWrongVariableNames == true ifTrue:[
1521
3488542e7a83 checkVariable-conventions: can be disabled via classVar.
Claus Gittinger <cg@exept.de>
parents: 1520
diff changeset
  2367
        self checkForProperUseOfArticleInVariableName:aVariableName.
3488542e7a83 checkVariable-conventions: can be disabled via classVar.
Claus Gittinger <cg@exept.de>
parents: 1520
diff changeset
  2368
    ].
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2369
!
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2370
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2371
checkMethodArgumentNameConventionsFor:aVariableName
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2372
    self checkLocalVariableNameConventionsFor:aVariableName.
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2373
!
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2374
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2375
checkMethodVariableNameConventionsFor:aVariableName
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2376
    self checkLocalVariableNameConventionsFor:aVariableName.
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2377
!
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2378
1507
bd29313cd901 selector check w.r.t. subclassResponsibility
penk
parents: 1499
diff changeset
  2379
checkSelector:selector for:receiver inClass:cls
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2380
    "check wether a method with selector exists in class cls and
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2381
     that the method is not obsolete.
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2382
     If cls is nil, check all classes for the selector.
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2383
     Return an error string on error or nil on success"
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2384
1507
bd29313cd901 selector check w.r.t. subclassResponsibility
penk
parents: 1499
diff changeset
  2385
    |err mthd implementor implementors allowed|
1190
8600334a549e oops - avoid cought error if method is parsed in no class.
Claus Gittinger <cg@exept.de>
parents: 1189
diff changeset
  2386
8600334a549e oops - avoid cought error if method is parsed in no class.
Claus Gittinger <cg@exept.de>
parents: 1189
diff changeset
  2387
    cls isNil ifTrue:[
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2388
        SystemBrowser isNil ifTrue:[
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2389
            ^ nil
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2390
        ].
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2391
        "beware, this is sort of slow, especially for the SyntaxHighlighter"
1190
8600334a549e oops - avoid cought error if method is parsed in no class.
Claus Gittinger <cg@exept.de>
parents: 1189
diff changeset
  2392
        implementors := SystemBrowser 
8600334a549e oops - avoid cought error if method is parsed in no class.
Claus Gittinger <cg@exept.de>
parents: 1189
diff changeset
  2393
                         findImplementorsOf:selector
8600334a549e oops - avoid cought error if method is parsed in no class.
Claus Gittinger <cg@exept.de>
parents: 1189
diff changeset
  2394
                         in:(Smalltalk allClasses)
8600334a549e oops - avoid cought error if method is parsed in no class.
Claus Gittinger <cg@exept.de>
parents: 1189
diff changeset
  2395
                         ignoreCase:false.
8600334a549e oops - avoid cought error if method is parsed in no class.
Claus Gittinger <cg@exept.de>
parents: 1189
diff changeset
  2396
        implementors size == 0 ifTrue:[
8600334a549e oops - avoid cought error if method is parsed in no class.
Claus Gittinger <cg@exept.de>
parents: 1189
diff changeset
  2397
            ^ 'is nowhere implemented'
8600334a549e oops - avoid cought error if method is parsed in no class.
Claus Gittinger <cg@exept.de>
parents: 1189
diff changeset
  2398
        ].
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2399
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2400
        (implementors conform:[:eachMethod| eachMethod isObsolete]) ifTrue:[
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2401
            ^ 'each implementation of this selector in the system is deprecated'
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2402
        ].
1190
8600334a549e oops - avoid cought error if method is parsed in no class.
Claus Gittinger <cg@exept.de>
parents: 1189
diff changeset
  2403
        ^ nil
8600334a549e oops - avoid cought error if method is parsed in no class.
Claus Gittinger <cg@exept.de>
parents: 1189
diff changeset
  2404
    ].
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2405
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2406
    mthd := cls lookupMethodFor:selector.
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2407
    mthd isNil ifTrue:[
1687
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  2408
        cls isBehavior ifTrue:[
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  2409
            cls isMeta ifTrue:[
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  2410
                mthd := Metaclass lookupMethodFor:selector.
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  2411
            ].
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  2412
        ].
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  2413
    ].
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  2414
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  2415
    mthd isNil ifTrue:[
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  2416
        cls == Boolean ifTrue:[
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2417
            mthd := True compiledMethodAt:selector.
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  2418
            mthd isNil ifTrue:[
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2419
                mthd := False compiledMethodAt:selector.
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  2420
            ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  2421
        ]
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  2422
    ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  2423
    mthd isNil ifTrue:[
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2424
        "if it implements #doesNotUnderstand somewhere, assume it is ok"
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2425
        implementor := cls whichClassIncludesSelector:#doesNotUnderstand:.
1597
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  2426
"/      (implementor isNil or:[implementor == Object]) ifTrue:[
1599
2d2f92c748b8 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1597
diff changeset
  2427
            err := 'is not implemented in ' , cls name allBold
1597
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  2428
"/      ].
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2429
    ] ifFalse:[
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  2430
        (mthd sends:#shouldNotImplement) ifTrue:[
1562
d426603ccc4e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1561
diff changeset
  2431
            mthd messagesSent size == 1 ifTrue:[
d426603ccc4e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1561
diff changeset
  2432
                allowed := (cls == classToCompileFor).      "methods in abstract classes may send messages to abstract methods in the same class"
d426603ccc4e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1561
diff changeset
  2433
                allowed ifFalse:[
d426603ccc4e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1561
diff changeset
  2434
                    err := 'is not (should not be) implemented'
d426603ccc4e *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1561
diff changeset
  2435
                ]
1542
af06af21f9a9 subClassResponsibility error
penk
parents: 1539
diff changeset
  2436
            ]
1517
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2437
        ] ifFalse:[
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2438
            (mthd sends:#subclassResponsibility) ifTrue:[
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2439
                allowed := (cls == classToCompileFor).      "methods in abstract classes may send messages to abstract methods in the same class"
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2440
                allowed ifFalse:[
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2441
                    "methods in abstract classes may send messages to abstract methods in meta class"
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2442
                    (cls == classToCompileFor class) ifTrue:[
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2443
                        allowed := receiver isMessage and:[receiver selector = 'class']    
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2444
                    ].
1507
bd29313cd901 selector check w.r.t. subclassResponsibility
penk
parents: 1499
diff changeset
  2445
                ].
1517
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2446
                allowed ifTrue:[
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2447
                    "/ not from cg to stefan: thats wrong - if not implemented in all subclasses,
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2448
                    "/ its a bug of the subclass not a bug here - that message send here
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2449
                    "/ is perfectly correct. (it is very annoying for a framework developped to get
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2450
                    "/ error messages for bugs which are not his...
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2451
"/                    (self checkIfAllSubclassesOf:cls implement:selector) ifFalse:[
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2452
"/                        "if not all subclasses implement the selector - this is a possible bug"
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2453
"/                        allowed := false
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  2454
"/                    ].
1507
bd29313cd901 selector check w.r.t. subclassResponsibility
penk
parents: 1499
diff changeset
  2455
                ].
1517
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2456
                allowed ifFalse:[
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2457
                    err := 'is subclassResponsibility'
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2458
                ].
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2459
            ] ifFalse:[mthd isObsolete ifTrue:[
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2460
                err := 'is deprecated'.
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2461
            ]]
63d8bd670305 *** empty log message ***
ca
parents: 1516
diff changeset
  2462
        ].
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2463
    ].
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2464
    ^ err.
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2465
!
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2466
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2467
correctByDeleting
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2468
    "correct (by deleting token) if user wants to;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2469
     return #Error if there was no correction;
644
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2470
     nil if there was one."
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2471
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2472
    |selectionSize|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2473
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2474
    (self confirm:'confirm deleting') ifFalse:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2475
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2476
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2477
     tell requestor (i.e. CodeView) about the change
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2478
     this will update what the requestor shows.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2479
    "
644
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2480
    selectionSize := requestor selection size.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2481
    requestor deleteSelection.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2482
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2483
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2484
     get the updated source-string 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2485
     which is needed, when we eventually install the new method
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
    correctedSource := requestor currentSourceCode.
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2488
    "/ update the current source position
644
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2489
    source := (ReadStream on:correctedSource)
1371
de4c37ac12fc code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 1369
diff changeset
  2490
                  position:(source position1Based - selectionSize).
1369
2304dd8c3173 recompilation after correct-by-deleting unused local
Claus Gittinger <cg@exept.de>
parents: 1368
diff changeset
  2491
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2492
    ^ nil
644
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2493
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2494
    "Modified: / 22.1.1998 / 16:39:11 / stefan"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2495
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2496
1439
0fddfcdca37b selector check improved
Claus Gittinger <cg@exept.de>
parents: 1437
diff changeset
  2497
correctSelector:aSelectorString message:msg positions:posVector in:aClassOrNil for:receiverNode
1156
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2498
    "notify error and correct if user wants to;
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2499
     return #Error if there was no correction 
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2500
     or a ParseNode as returned by variable"
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2501
1439
0fddfcdca37b selector check improved
Claus Gittinger <cg@exept.de>
parents: 1437
diff changeset
  2502
    |correctIt suggestedNames newSelector className classToGenerateCode pos1 pos2|
0fddfcdca37b selector check improved
Claus Gittinger <cg@exept.de>
parents: 1437
diff changeset
  2503
0fddfcdca37b selector check improved
Claus Gittinger <cg@exept.de>
parents: 1437
diff changeset
  2504
    pos1 := posVector first start.
0fddfcdca37b selector check improved
Claus Gittinger <cg@exept.de>
parents: 1437
diff changeset
  2505
    pos2 := posVector last stop.
1156
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2506
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2507
    alreadyWarnedUnimplementedSelectors isNil ifTrue:[
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2508
        alreadyWarnedUnimplementedSelectors := Set new
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2509
    ].
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2510
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2511
    (alreadyWarnedUnimplementedSelectors includes:aSelectorString) ifTrue:[
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2512
        ^ aSelectorString
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2513
    ].
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2514
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2515
    "
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2516
     sorry, but I cannot handle keywords with more than one-part
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2517
     currently (too much work - maybe Ill do it later when everything else works :-)
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2518
    "
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2519
    (aSelectorString occurrencesOf:$:) > 1 ifTrue:[
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2520
        self warning:msg position:pos1 to:pos2.
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2521
        alreadyWarnedUnimplementedSelectors add:aSelectorString.
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2522
        ^ aSelectorString
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2523
    ].
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2524
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2525
    correctIt := self correctableSelectorWarning:msg position:pos1 to:pos2.
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2526
    correctIt == #generate ifTrue:[
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2527
        receiverNode isSelf ifTrue:[
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2528
            classToGenerateCode := classToCompileFor
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2529
        ] ifFalse:[
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2530
            receiverNode isVariable ifTrue:[
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2531
                receiverNode isGlobal ifTrue:[
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2532
                    classToGenerateCode := receiverNode evaluate.
1336
67ea8b161346 Generate class methods in class.
Stefan Vogel <sv@exept.de>
parents: 1335
diff changeset
  2533
                    classToGenerateCode isBehavior ifTrue:[
67ea8b161346 Generate class methods in class.
Stefan Vogel <sv@exept.de>
parents: 1335
diff changeset
  2534
                        classToGenerateCode :=  classToGenerateCode theMetaclass.
67ea8b161346 Generate class methods in class.
Stefan Vogel <sv@exept.de>
parents: 1335
diff changeset
  2535
                    ] ifFalse:[
1156
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2536
                        classToGenerateCode := nil
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2537
                    ].
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2538
                ].
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2539
            ]
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2540
        ].
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2541
        classToGenerateCode isNil ifTrue:[
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2542
            className := Dialog request:'Generate code in class:' initialAnswer:classToCompileFor name.
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2543
            className size == 0 ifTrue:[
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2544
                ^ aSelectorString
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2545
            ].
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2546
            classToGenerateCode := Smalltalk at:className asSymbol.
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2547
            classToGenerateCode isNil ifTrue:[
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2548
                self warn:'No such class.'.
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2549
                ^ aSelectorString
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2550
            ].
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2551
        ].
1252
666db3206028 #implements: -> #includesSelector:
Claus Gittinger <cg@exept.de>
parents: 1247
diff changeset
  2552
        (classToGenerateCode includesSelector:aSelectorString asSymbol) ifFalse:[
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2553
            "do not overwrite an already existant (deprecated) method"
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2554
            classToGenerateCode
1336
67ea8b161346 Generate class methods in class.
Stefan Vogel <sv@exept.de>
parents: 1335
diff changeset
  2555
                compile:((self class methodSpecificationForSelector:aSelectorString) , '\    self shouldImplement' withCRs)
1323
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2556
                classified:(Compiler defaultMethodCategory).
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  2557
        ].
1156
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2558
        correctIt := false.
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2559
    ].
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2560
    correctIt ifFalse:[
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2561
        alreadyWarnedUnimplementedSelectors add:aSelectorString.
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2562
        ^ aSelectorString
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2563
    ].
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2564
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2565
    suggestedNames := self findBestSelectorsFor:aSelectorString in:aClassOrNil.
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2566
    suggestedNames notNil ifTrue:[
1323
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2567
        newSelector := self askForCorrection:'Correct Selector to: ' fromList:suggestedNames for:aSelectorString.
34b29c93134b fixed correct for doits
Claus Gittinger <cg@exept.de>
parents: 1322
diff changeset
  2568
        newSelector isNil ifTrue:[AbortSignal raise "^ aSelectorString"].
1156
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2569
    ] ifFalse:[
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2570
        self information:'no good correction found'.
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2571
        ^ aSelectorString
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2572
    ].
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2573
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2574
    "
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2575
     tell requestor (i.e. CodeView) about the change
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2576
     this will update what the requestor shows.
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2577
    "
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2578
    requestor replaceSelectionBy:newSelector keepCursor:false.
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2579
    "
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2580
     get the updated source-string 
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2581
     which is needed, when we eventually install the new method
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2582
    "
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2583
    correctedSource := requestor currentSourceCode.
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2584
    source := (ReadStream on:correctedSource)
1371
de4c37ac12fc code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 1369
diff changeset
  2585
                  position:(source position1Based + 1 + (newSelector size - aSelectorString size)).
1361
Claus Gittinger <cg@exept.de>
parents: 1359
diff changeset
  2586
"/ Parser murks.
1156
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2587
    ^ newSelector
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2588
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2589
    "Modified: / 22.1.1998 / 16:36:04 / stefan"
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2590
    "Created: / 19.1.2000 / 16:34:01 / cg"
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2591
    "Modified: / 19.1.2000 / 16:34:55 / cg"
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2592
!
b491528ad92b fixed 'generate' option (in selector will not be understood)
Claus Gittinger <cg@exept.de>
parents: 1155
diff changeset
  2593
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2594
correctSourceByDeletingFrom:start to:stop
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2595
    "correct (by deleting token) if user wants to;
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2596
     return #Error if there was no correction;
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2597
     nil if there was one."
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2598
1445
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2599
    |deleteSize localDefsStart localDefsStop newPos|
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2600
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2601
    "
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2602
     tell requestor (i.e. CodeView) about the change
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2603
     this will update what the requestor shows.
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2604
    "
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2605
    deleteSize := stop - start + 1.
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2606
    requestor deleteFromCharacterPosition:start to:stop.
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2607
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2608
    "
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2609
     get the updated source-string 
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2610
     which is needed, when we eventually install the new method
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2611
    "
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2612
    correctedSource := requestor currentSourceCode.
1445
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2613
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2614
    "/ update the current source position
1445
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2615
    source atEnd ifTrue:[
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2616
        newPos := correctedSource size.
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2617
    ] ifFalse:[
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2618
        source position1Based >= stop ifTrue:[
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2619
            newPos := source position1Based - deleteSize
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2620
        ] ifFalse:[
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2621
            source position1Based < start ifTrue:[
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2622
                newPos := source position1Based
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2623
            ] ifFalse:[
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2624
                newPos := start
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2625
            ].
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2626
        ]
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2627
    ].
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2628
    source := (ReadStream on:correctedSource) position1Based:newPos.
1432
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2629
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2630
    localDefsStart := localVarDefPosition at:1.
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2631
    localDefsStop := localVarDefPosition at:2.
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2632
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2633
    localDefsStop <= start ifTrue:[^ self].
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2634
    localDefsStart >= stop ifTrue:[^ self].
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2635
1445
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2636
    (localDefsStart >= start and:[localDefsStop <= stop]) ifTrue:[
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2637
        localVarDefPosition := nil.
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2638
        ^ self
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2639
    ].  
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2640
1432
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2641
    "/ must update
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2642
    (start > localDefsStart and:[stop < localDefsStop]) ifTrue:[
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2643
        localVarDefPosition at:2 put:(localDefsStop - (stop-start+1)).
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2644
        ^ self.
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2645
    ].
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2646
    self halt.
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  2647
    ^ self
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2648
!
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2649
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  2650
correctVariable:varName atPosition:pos1 to:pos2
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2651
    "notify error and correct if user wants to;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2652
     return #Error if there was no correction 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2653
     or a ParseNode as returned by variable"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2654
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  2655
    |correctIt suggestedNames newName rslt
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  2656
     varNameIsLowercase undeclared boldName|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2657
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2658
    varNameIsLowercase := (varName at:1) isLowercase.
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2659
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2660
    correctIt := self undefError:varName position:pos1 to:pos2.
887
e42ea977b85d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 883
diff changeset
  2661
    (correctIt == false or:[correctIt == #continue]) ifTrue:[
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2662
        "/ no correction wanted.
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2663
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2664
        "/ lowerCase vars are added to the Undeclared dictionary,
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2665
        "/ allowing easy search for bad-spots later.
1285
32af9747bf9d error messages
Claus Gittinger <cg@exept.de>
parents: 1282
diff changeset
  2666
        boldName := varName allBold.
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2667
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2668
        varNameIsLowercase ifTrue:[
1205
1a9cbb122fba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1204
diff changeset
  2669
            undeclared := Smalltalk at:#Undeclared.
1a9cbb122fba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1204
diff changeset
  2670
            ((undeclared notNil)
1a9cbb122fba checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1204
diff changeset
  2671
            and:[(undeclared includes:varName asSymbol)]) ifFalse:[ 
1285
32af9747bf9d error messages
Claus Gittinger <cg@exept.de>
parents: 1282
diff changeset
  2672
                self warning:('Adding ''' , boldName , ''' as Undeclared.\\Remember to fix that later.') withCRs position:pos1 to:pos2.
725
326f4fe4a880 only warn once for undeclared vars.
Claus Gittinger <cg@exept.de>
parents: 718
diff changeset
  2673
            ].
644
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2674
            ^ self defineAsUndeclaredVariable:varName
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2675
        ].
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2676
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2677
        "/ upperCase vars are declared as global
1716
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  2678
        parserFlags warnings ifTrue:[
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  2679
            (warnedUndefVars isNil or:[(warnedUndefVars includes:varName) not]) ifTrue:[
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  2680
                (warnedUnknownNamespaces isNil or:[(warnedUnknownNamespaces includes:varName) not]) ifTrue:[
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  2681
                    self warning:('adding ''' , boldName , ''' as Global.') withCRs position:pos1 to:pos2.
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  2682
                ]
915
d3add8c1bb04 dont rewarn for same missing namespace
Claus Gittinger <cg@exept.de>
parents: 903
diff changeset
  2683
            ].
d3add8c1bb04 dont rewarn for same missing namespace
Claus Gittinger <cg@exept.de>
parents: 903
diff changeset
  2684
        ].
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  2685
        ^ VariableNode globalNamed:varName
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2686
    ].
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2687
1491
575056d1dccb users return value from correctableError
penk
parents: 1487
diff changeset
  2688
    correctIt == #Error ifTrue:[
575056d1dccb users return value from correctableError
penk
parents: 1487
diff changeset
  2689
        ^ #Error
575056d1dccb users return value from correctableError
penk
parents: 1487
diff changeset
  2690
    ].
575056d1dccb users return value from correctableError
penk
parents: 1487
diff changeset
  2691
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2692
    correctIt == #declare ifTrue:[
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2693
        "/ declare it
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2694
        rslt := self askForVariableTypeWhenDeclaringUndefined:varName.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2695
        rslt notNil ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2696
            ^ rslt
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  2697
        ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2698
    ].
1398
eaef898b063e added undefinedVariableNotification
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  2699
    (correctIt isKindOf:ParseNode) ifTrue:[
eaef898b063e added undefinedVariableNotification
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  2700
        ^ correctIt
eaef898b063e added undefinedVariableNotification
Claus Gittinger <cg@exept.de>
parents: 1394
diff changeset
  2701
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2702
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2703
    suggestedNames := self findBestVariablesFor:varName.
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2704
    suggestedNames isNil ifTrue:[
1285
32af9747bf9d error messages
Claus Gittinger <cg@exept.de>
parents: 1282
diff changeset
  2705
        self information:'No good correction found'.
644
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2706
        ^ #Error
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2707
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2708
1285
32af9747bf9d error messages
Claus Gittinger <cg@exept.de>
parents: 1282
diff changeset
  2709
    newName := self askForCorrection:'Correct Variable to: ' fromList:suggestedNames.
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2710
    newName isNil ifTrue:[^ #Error].
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2711
"
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2712
        newName := suggestedNames at:1.
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2713
        (self confirm:('confirm correction to: ' , newName)) ifFalse:[^ #Error].
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2714
"
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  2715
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2716
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2717
     tell requestor (i.e. CodeView) about the change
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2718
     this will update what the requestor shows.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2719
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2720
    requestor replaceSelectionBy:newName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2721
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2722
     get the updated source-string 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2723
     which is needed, when we eventually install the new method
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2724
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2725
    correctedSource := requestor currentSourceCode.
644
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2726
    source := (ReadStream on:correctedSource)
1371
de4c37ac12fc code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 1369
diff changeset
  2727
                  position:(source position1Based + newName size - tokenName size).
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2728
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2729
    "redo parse with new value"
1103
b75a71996388 ensure that token follows tomeName & tokenValue
Claus Gittinger <cg@exept.de>
parents: 1100
diff changeset
  2730
    token := tokenName := newName.
603
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2731
    rslt := self variableOrError:tokenName.
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2732
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2733
    "/ failed again ?
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2734
    rslt == #Error ifTrue:[
644
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2735
        "/ install as Undeclared:<name>, remember in #undeclared
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2736
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2737
        rslt := self defineAsUndeclaredVariable:varName
603
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2738
    ].
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2739
    ^ rslt
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2740
644
834399365be9 Highlighting of undefined variables didn't work after first correction
Stefan Vogel <sv@exept.de>
parents: 640
diff changeset
  2741
    "Modified: / 22.1.1998 / 16:34:01 / stefan"
1221
2768cbe3be2b finished remove unused vars;
Claus Gittinger <cg@exept.de>
parents: 1220
diff changeset
  2742
    "Modified: / 15.11.2001 / 22:56:38 / cg"
603
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2743
!
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2744
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2745
defineAsUndeclaredVariable:aName
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2746
    "define varName as undeclared variable
629
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  2747
     (actually, it will be installed as a funny global named 'Undeclared:::<name>').
603
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2748
     You can browse for methods with undeclareds by searching for global accesses
629
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  2749
     to 'Undeclared:::*' (or use the search-undeclared item in the launchers menu)."
603
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2750
1206
df5104d45e42 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
  2751
    |varName undeclared|
603
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2752
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2753
    varName := aName.
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2754
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2755
    "/ install as Undeclared:<name>, remember in Undeclared
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2756
1206
df5104d45e42 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
  2757
    undeclared := Smalltalk at:#Undeclared.
df5104d45e42 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
  2758
    undeclared isNil ifTrue:[
df5104d45e42 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
  2759
        Smalltalk at:#Undeclared put:(undeclared := IdentitySet new).
df5104d45e42 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
  2760
    ].
df5104d45e42 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1205
diff changeset
  2761
    undeclared add:tokenName asSymbol.
1304
ade15708e7c1 undeclared variable handling was broken (to allow reference search)
penk
parents: 1301
diff changeset
  2762
    varName := (Smalltalk undeclaredPrefix) , tokenName.
603
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2763
    varName := varName asSymbol.
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2764
    Smalltalk at:varName put:nil.
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2765
762
66cd2b4f6689 Big BUG: remember original name in usedVars - not Undeclared::xxx
tm
parents: 755
diff changeset
  2766
    parseForCode ifFalse:[self rememberGlobalUsed:aName].
603
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2767
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  2768
    ^ VariableNode globalNamed:varName
603
021722b8a427 correctly scan trailing period after a number in a block (as in x := x + 1.]
Claus Gittinger <cg@exept.de>
parents: 601
diff changeset
  2769
629
6dbcd3bb1c9d checkin from browser
Claus Gittinger <cg@exept.de>
parents: 628
diff changeset
  2770
    "Modified: / 31.10.1997 / 01:16:03 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2771
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2772
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2773
deleteDefinitionOf:varName in:defStartPos to:defEndPos
1393
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2774
    "this removes the definition of varName from the declaration part i.e.
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2775
     if the source was '... | foo bar baz |...'
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2776
     deleting the var 'bar' changes the source to '... | foo baz |...'.
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2777
     The code below tries to be somewhat smart w.r.t. spaces by
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2778
     trying to remove the whiteSpace around the removed variable also.
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2779
     However, this seems to not always work correctly"
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2780
1445
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2781
    |source startSearch pos pos2 nextChar varSlot p p2|
1172
401e669ebaf9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1171
diff changeset
  2782
401e669ebaf9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1171
diff changeset
  2783
    varSlot := methodVars detect:[:var | var name = varName].
401e669ebaf9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1171
diff changeset
  2784
    methodVars removeIdentical:varSlot.
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2785
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2786
    source := requestor currentSourceCode.
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2787
    startSearch := defStartPos+1.
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2788
1779
4cb48fc7fb17 eliminated loop-send
Claus Gittinger <cg@exept.de>
parents: 1776
diff changeset
  2789
    [true] whileTrue:[
1393
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2790
        |prevChar isFirstVar didPassEndOfLine|
1392
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2791
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2792
        "/ search this name's position in the declaration part ...
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2793
        pos := source indexOfSubCollection:varName startingAt:startSearch ifAbsent:0.
1326
Claus Gittinger <cg@exept.de>
parents: 1325
diff changeset
  2794
        (pos == 0 or:[pos >= defEndPos]) ifTrue:[
Claus Gittinger <cg@exept.de>
parents: 1325
diff changeset
  2795
            self error:'should not happen' mayProceed:true.
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2796
            ^ self.
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2797
        ].
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2798
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2799
        pos2 := pos + varName size - 1.
1392
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2800
        pos > 1 ifTrue:[
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2801
            prevChar := source at:pos-1.
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2802
        ].
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2803
        (prevChar isNil or:[prevChar isLetterOrDigit not]) ifTrue:[
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2804
            nextChar := source at:pos2+1.
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2805
            nextChar isLetterOrDigit ifFalse:[
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2806
                "/ halfway intuitive space-removal behavior;
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2807
                "/ if there was a space after/before the |-char,
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2808
                "/ leave it; otherwise remove it.
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2809
                isFirstVar := pos == (defStartPos+1).
1393
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2810
                (source at:pos-1) isSeparator ifTrue:[
1392
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2811
                    pos := pos - 1.
1393
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2812
                    [ (source at:pos-1) isSeparator] whileTrue:[
1392
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2813
                        pos := pos - 1.
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2814
                    ].
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2815
                    (source at:pos-1) == $| ifTrue:[
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2816
                        "/ there was a space before - leave it
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2817
                        pos := pos + 1.
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2818
                        isFirstVar := true.
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2819
                    ]
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2820
                ].
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2821
1393
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2822
                (source at:pos2+1) isSeparator ifTrue:[
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2823
                    didPassEndOfLine := (source at:pos2+1) == Character cr.
1392
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2824
                    pos2 := pos2 + 1.
1393
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2825
                    [ (source at:pos2+1) isSeparator] whileTrue:[
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2826
                        (source at:pos2+1) == Character cr ifTrue:[ didPassEndOfLine := true ].
1392
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2827
                        pos2 := pos2 + 1.
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2828
                    ].
1393
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2829
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2830
                    didPassEndOfLine ifFalse:[    
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2831
                        (source at:pos2+1) == $" ifTrue:[
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2832
                            "/ comment follows - assume it belongs to the removed variable
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2833
                            pos2 := pos2 + 1.
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2834
                            (source at:pos2+1) == $/ ifTrue:[
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2835
                                "/ EOL comment
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2836
                                [ (source at:pos2+1) == Character cr ] whileFalse:[
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2837
                                    pos2 := pos2 + 1.
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2838
                                ].
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2839
                                pos2 := pos2 + 1.
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2840
                            ] ifFalse:[
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2841
                                "/ regular comment
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2842
                                [ (source at:pos2+1) == $" ] whileFalse:[
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2843
                                    pos2 := pos2 + 1.
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2844
                                ].
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2845
                                pos2 := pos2 + 1.
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2846
                            ].
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2847
                            [ (source at:pos2+1) isSeparator] whileTrue:[
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2848
                                (source at:pos2+1) == Character cr ifTrue:[ didPassEndOfLine := true ].
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2849
                                pos2 := pos2 + 1.
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2850
                            ].
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2851
                        ]
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2852
                    ].
8b0207fb214d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1392
diff changeset
  2853
1392
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2854
                    (source at:pos2+1) == $| ifTrue:[
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2855
                        "/ there was a space after - leave it
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2856
                        pos2 := pos2 - 1.
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2857
                    ] ifFalse:[
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2858
                        isFirstVar ifFalse:[
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2859
                            pos2 := pos2 - 1.
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2860
                        ]
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2861
                    ].
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2862
                ].
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2863
1445
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2864
                "/ if this was the last, remove empty var-declaration completely
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2865
                ((source at:pos-1) == $|
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2866
                and:[ (source at:pos2+1) == $| ]) ifTrue:[
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2867
                    pos := pos - 1.
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2868
                    pos2 := pos2 + 1.
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2869
                    "/ see if that gives us an empty line
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2870
                    p := pos.
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2871
                    p2 := pos2.
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2872
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2873
                    [(source at:p-1) == Character space] whileTrue:[ p := p - 1 ].
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2874
                    [(source at:p2+1) == Character space] whileTrue:[ p2 := p2 + 1 ].
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2875
                    ((source at:p-1) == Character cr and:[ (source at:p2+1) == Character cr]) ifTrue:[
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2876
                        pos := p-1.
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2877
                        pos2 := p2.
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2878
                        (((source at:pos-1) == Character cr) and:[((source at:pos-2) == Character cr)]) 
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2879
                            ifTrue:[ pos := pos - 1 ]
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2880
                            ifFalse:[ 
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2881
                                (((source at:pos2+1) == Character cr) and:[((source at:pos2+2) == Character cr)]) ifTrue:[ 
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2882
                                    pos2 := pos2 + 1 ]].
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2883
                    ].
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2884
                ].
2bd299cdc753 delete unused variable-decl: when decl is empty, remove it as well
Claus Gittinger <cg@exept.de>
parents: 1442
diff changeset
  2885
1392
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2886
                self correctSourceByDeletingFrom:pos to:pos2.
2c06fa7b9bbe remove unused variable fixed
Claus Gittinger <cg@exept.de>
parents: 1391
diff changeset
  2887
                ^ self.
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2888
            ].
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2889
        ].
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2890
        startSearch := pos2 + 1.
1779
4cb48fc7fb17 eliminated loop-send
Claus Gittinger <cg@exept.de>
parents: 1776
diff changeset
  2891
    ]
4cb48fc7fb17 eliminated loop-send
Claus Gittinger <cg@exept.de>
parents: 1776
diff changeset
  2892
4cb48fc7fb17 eliminated loop-send
Claus Gittinger <cg@exept.de>
parents: 1776
diff changeset
  2893
    "Modified: / 18-07-2006 / 08:56:25 / cg"
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2894
!
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  2895
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2896
findBestSelectorsFor:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2897
    "collect known selectors with their spelling distances to aString;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2898
     return the 10 best suggestions"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2899
1187
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
  2900
    ^ self class findBestSelectorsFor:aString 
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2901
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2902
    "Time millisecondsToRun:[Parser new findBestSelectorsFor:'foo']"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2903
    "Parser new findBestSelectorsFor:'findBestSel'"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2904
    "Parser new findBestSelectorsFor:'fildBestSelectrFr'"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2905
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2906
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  2907
findBestSelectorsFor:aString in:aClassOrNil
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  2908
    "collect known selectors with their spelling distances to aString;
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  2909
     return the 10 best suggestions. If the argument, aClassOrNil is not nil,
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  2910
     the message is assumed to be sent to instances of that class (i.e. offer
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  2911
     corrections from that hierarchy only)"
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  2912
1187
902d406b9100 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1186
diff changeset
  2913
    ^ self class findBestSelectorsFor:aString in:aClassOrNil
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  2914
!
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  2915
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2916
findBestVariablesFor:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2917
    "collect known variables with their spelling distances to aString;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2918
     return the 10 best suggestions"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2919
1200
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2920
    |names dists searchBlock args vars "aClass className baseClass" 
1647
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2921
     n instVarNames classVarNames spellAgainstNodeAction spellAgainstAction|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2922
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2923
    names := OrderedCollection new.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2924
    dists := OrderedCollection new.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2925
1200
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2926
    spellAgainstAction := 
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2927
        [:givenName |
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2928
            |dist|
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2929
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2930
            names add:givenName.
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2931
            dist := aString spellAgainst:givenName.
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2932
            (aString startsWith:givenName) ifTrue:[
1647
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2933
                dist := dist + (givenName size * 10).
1200
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2934
            ].
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2935
            dists add:dist
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2936
        ].
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2937
1647
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2938
    spellAgainstNodeAction := 
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2939
            [:aVarNode |
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2940
                spellAgainstAction value:(aVarNode name).
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2941
            ].
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2942
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2943
    "block arguments"
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2944
    searchBlock := currentBlock.
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2945
    [searchBlock notNil] whileTrue:[
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2946
        args := searchBlock arguments.
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2947
        args notNil ifTrue:[
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2948
            args do:spellAgainstNodeAction
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2949
        ].
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2950
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2951
        vars := searchBlock variables.
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2952
        vars notNil ifTrue:[
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2953
            vars do:spellAgainstNodeAction
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2954
        ].
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2955
        searchBlock := searchBlock home
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2956
    ].
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2957
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2958
    "method-variables"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2959
    methodVars notNil ifTrue:[
1200
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2960
        methodVarNames do:spellAgainstAction
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2961
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2962
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2963
    "method-arguments"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2964
    methodArgs notNil ifTrue:[
1200
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2965
        methodArgNames do:spellAgainstAction
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2966
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2967
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2968
    "instance-variables"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2969
    classToCompileFor notNil ifTrue:[
1200
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2970
        self classesInstVarNames do:spellAgainstAction
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2971
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2972
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2973
    "class-variables"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2974
    classToCompileFor notNil ifTrue:[
1200
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2975
        self classesClassVarNames do:spellAgainstAction.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2976
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2977
"/        aClass := classToCompileFor.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2978
"/        aClass isMeta ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2979
"/            className := aClass name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2980
"/            className := className copyWithoutLast:5.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2981
"/            baseClass := Smalltalk at:(className asSymbol).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2982
"/            baseClass notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2983
"/                aClass := baseClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2984
"/            ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2985
"/        ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2986
"/        [aClass notNil] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2987
"/            (aClass classVarNames) do:[:classVarName |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2988
"/                names add:classVarName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2989
"/                dists add:(aString spellAgainst: "levenshteinTo:"classVarName)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2990
"/            ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2991
"/            aClass := aClass superclass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2992
"/        ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2993
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2994
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2995
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2996
    "globals"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2997
    Smalltalk keysDo:[:aKey |
1647
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  2998
        |globalVarName parts|
1200
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  2999
989
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3000
        globalVarName := aKey asString.
1200
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  3001
989
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3002
        "only compare strings where length is about right"
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3003
        ((globalVarName size - aString size) abs < 3) ifTrue:[
1200
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  3004
            spellAgainstAction value:globalVarName.
1647
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3005
        ].
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3006
        (globalVarName includes:$:) ifTrue:[
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3007
            parts := globalVarName asCollectionOfSubCollectionsSeparatedByAll:'::'.
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3008
            parts size > 1 ifTrue:[
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3009
                parts do:[:eachPart |
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3010
                    |dist|
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3011
                    ((eachPart size - aString size) abs < 3) ifTrue:[
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3012
                        names add:globalVarName.
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3013
                        dist := aString spellAgainst:eachPart.
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3014
                        (aString startsWith:eachPart) ifTrue:[
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3015
                            dist := dist + (eachPart size * 10).
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3016
                        ].
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3017
                        dists add:dist
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3018
                    ].
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3019
                ].
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3020
            ].
89f03e0bc836 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1643
diff changeset
  3021
        ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3022
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3023
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3024
    "misc"
1200
aa96cdaf2780 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1199
diff changeset
  3025
    #('self' 'super' 'nil' 'thisContext') do:spellAgainstAction.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3026
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3027
    (dists size ~~ 0) ifTrue:[
989
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3028
        dists sortWith:names.
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3029
        dists := dists reverse.             
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3030
        names := names reverse.
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3031
        n := names size min:10.
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3032
        names := names copyTo:n.
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3033
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3034
        "if it starts with a lower case character, add all local & instvar names"
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3035
        (aString at:1) isLowercase ifTrue:[
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3036
            methodVarNames size > 0 ifTrue:[
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3037
                names add:'---- method locals ----'.
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3038
                methodVarNames asSortedCollection do:[:methodVarName |
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3039
                    names add:methodVarName.
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3040
                ].
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3041
            ].
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3042
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3043
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3044
            methodArgs size > 0 ifTrue:[
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3045
                names add:'---- method arguments ----'.
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3046
                methodArgNames asSortedCollection do:[:methodArgName |
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3047
                    names add:methodArgName.
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3048
                ]
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3049
            ].
1078
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3050
            classToCompileFor notNil ifTrue:[
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3051
                instVarNames := OrderedCollection new.
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3052
                self classesInstVarNames asSortedCollection do:[:instVarName |
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3053
                    (instVarNames includes:instVarName) ifFalse:[
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3054
                        instVarNames add:instVarName.
989
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3055
                    ]
1078
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3056
                ].
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3057
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3058
                instVarNames size > 0 ifTrue:[
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3059
                    (classToCompileFor notNil and:[classToCompileFor isMeta]) ifTrue:[
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3060
                        names add:'---- class instance variables ----'.
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3061
                    ] ifFalse:[
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3062
                        names add:'---- instance variables ----'.
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3063
                    ].
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3064
                    instVarNames do:[:instVarName |
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3065
                        (names includes:instVarName) ifFalse:[
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3066
                            names add:instVarName.
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3067
                        ]
989
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3068
                    ]
1078
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3069
                ].
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3070
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3071
                classVarNames := OrderedCollection new.
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3072
                self classesClassVarNames asSortedCollection do:[:classVarName |
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3073
                    (classVarNames includes:classVarName) ifFalse:[
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3074
                        classVarNames add:classVarName.
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3075
                    ]
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3076
                ].
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3077
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3078
                classVarNames size > 0 ifTrue:[
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3079
                    names add:'---- class variables ----'.
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3080
                    classVarNames do:[:classVarName |
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3081
                        (names includes:classVarName) ifFalse:[
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3082
                            names add:classVarName.
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3083
                        ]
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3084
                    ]
bf1d18b918cc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1077
diff changeset
  3085
                ].
989
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3086
            ].
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3087
        ].
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3088
6e535d9d87d8 better undef-variable message;
Claus Gittinger <cg@exept.de>
parents: 988
diff changeset
  3089
        ^ names
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3090
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3091
    ^ nil
450
8ad79af3e91c checkin from browser
Claus Gittinger <cg@exept.de>
parents: 448
diff changeset
  3092
480
e4ac7e62ca9a better block-var name detection in debugger
Claus Gittinger <cg@exept.de>
parents: 473
diff changeset
  3093
    "Modified: 11.1.1997 / 21:28:28 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3094
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3095
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3096
selectorCheck:aSelectorString for:receiver position:pos1 to:pos2
1439
0fddfcdca37b selector check improved
Claus Gittinger <cg@exept.de>
parents: 1437
diff changeset
  3097
    ^ self selectorCheck:aSelectorString for:receiver positions:(Array with:(pos1 to:pos2)).
0fddfcdca37b selector check improved
Claus Gittinger <cg@exept.de>
parents: 1437
diff changeset
  3098
!
0fddfcdca37b selector check improved
Claus Gittinger <cg@exept.de>
parents: 1437
diff changeset
  3099
0fddfcdca37b selector check improved
Claus Gittinger <cg@exept.de>
parents: 1437
diff changeset
  3100
selectorCheck:aSelectorString for:receiver positions:posVector
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3101
    "just a quick check: if a selector is totally unknown as a symbol, 
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3102
     has the same name as a variable, cannot be understood or is obsolete.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3103
     Simple, but catches many typos"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3104
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3105
    |isSyntaxHighlighter err selectorSymbol rec names recType selClass newSelector nm nowhereImplemented 
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3106
     pos1 pos2 canDefine|
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3107
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3108
    isSyntaxHighlighter := self isSyntaxHighlighter.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3109
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3110
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3111
     if compiling lazy, or errors are to be ignored, or there
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3112
     is no requestor, do not check
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3113
    "
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3114
    isSyntaxHighlighter ifFalse:[
1545
Claus Gittinger <cg@exept.de>
parents: 1542
diff changeset
  3115
        (LazyCompilation == true) ifTrue:[^ aSelectorString].
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  3116
        (ignoreErrors or:[ignoreWarnings]) ifTrue:[^ aSelectorString].
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  3117
        (requestor isNil or:[requestor isStream]) ifTrue:[^ aSelectorString].
1714
ba7113f4bce1 honor disabled warning flags
Claus Gittinger <cg@exept.de>
parents: 1710
diff changeset
  3118
        parserFlags warnings ifFalse:[^ aSelectorString].
977
c1afbaf48a23 remember used & modified local vars;
Claus Gittinger <cg@exept.de>
parents: 971
diff changeset
  3119
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3120
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3121
    canDefine := false.
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3122
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3123
    pos1 := posVector first start.
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3124
    pos2 := posVector last stop.
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3125
1301
677ca6e364d4 + warnPossible incompatibility
Claus Gittinger <cg@exept.de>
parents: 1299
diff changeset
  3126
    aSelectorString = '#' ifTrue:[
677ca6e364d4 + warnPossible incompatibility
Claus Gittinger <cg@exept.de>
parents: 1299
diff changeset
  3127
        self warnPossibleIncompatibility:'''#'' might not be a valid selector in other smalltalk systems' position:pos1 to:pos2.
677ca6e364d4 + warnPossible incompatibility
Claus Gittinger <cg@exept.de>
parents: 1299
diff changeset
  3128
    ].
677ca6e364d4 + warnPossible incompatibility
Claus Gittinger <cg@exept.de>
parents: 1299
diff changeset
  3129
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3130
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3131
     check if the selector is known at all
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3132
     - if not, it cannot be understood
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3133
    "
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3134
    nowhereImplemented := false.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3135
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3136
    selectorSymbol := aSelectorString asSymbolIfInterned.
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3137
    selectorSymbol isNil ifTrue:[
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3138
        nowhereImplemented := true.
1518
ae1f95e5ab9f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1517
diff changeset
  3139
    ] ifFalse:[
ae1f95e5ab9f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1517
diff changeset
  3140
"/ temporarily disabled - too slow.
ae1f95e5ab9f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1517
diff changeset
  3141
"/        self isSyntaxHighlighter ifTrue:[
ae1f95e5ab9f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1517
diff changeset
  3142
"/            nowhereImplemented := (self implementedInAnyClass:selectorSymbol) not.
ae1f95e5ab9f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1517
diff changeset
  3143
"/        ]
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3144
    ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3145
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3146
    nowhereImplemented ifTrue:[
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3147
        err := ' is currently nowhere implemented'.
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3148
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3149
        "
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3150
         if the selector has the name of a variable, use another message
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3151
        "
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3152
        ((methodVarNames notNil and:[methodVarNames includes:aSelectorString])
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3153
          or:[(methodArgNames notNil and:[methodArgNames includes:aSelectorString])
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3154
          or:[classToCompileFor notNil
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3155
              and:[((names := self classesInstVarNames) notNil and:[names includes:aSelectorString])
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3156
                   or:[((names := self classesClassInstVarNames) notNil and:[names includes:aSelectorString])
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3157
                   or:[(names := self classesClassVarNames) notNil and:[names includes:aSelectorString]
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3158
        ]]]]]) ifTrue:[
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3159
            err := ' is currently nowhere implemented ..
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3160
.. but a variable with that name is defined. 
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3161
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3162
Missing ''.'' after the previous expression 
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3163
or missing keyword/receiver before that word ?'.
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3164
        ].
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3165
    ] ifFalse:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3166
        receiver notNil ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3167
            selClass := self typeOfNode:receiver.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3168
            selClass notNil ifTrue:[
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3169
                "this could be performed if selClass isNil, but it is too slow"
1507
bd29313cd901 selector check w.r.t. subclassResponsibility
penk
parents: 1499
diff changeset
  3170
                err := self checkSelector:selectorSymbol for:receiver inClass:selClass.
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3171
            ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3172
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  3173
            (receiver isConstant or:[receiver isBlock]) ifTrue:[
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3174
                err notNil ifTrue:[
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  3175
                    err := err, ' in ' , selClass name , ' or any of its superclasses'.
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3176
                ].
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3177
            ] ifFalse:[(((recType := receiver type) == #GlobalVariable)
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3178
                        or:[recType == #PrivateClass]) ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3179
                rec := receiver evaluate. 
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  3180
                "/ dont check autoloaded classes - it may work after loading
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3181
                (rec isNil 
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3182
                 or:[rec isBehavior and:[rec isLoaded not]]) ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3183
                    ^ aSelectorString
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3184
                ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3185
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3186
                err notNil ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3187
                    (rec isBehavior
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3188
                     and:[rec theNonMetaclass name = receiver name]) ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3189
                        err := err, ' in ' , rec theNonMetaclass name.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3190
                    ] ifFalse:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3191
                        err := err, ' in currently assigned value (is currently ' , rec classNameWithArticle , ')'.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3192
                    ]
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3193
                ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3194
            ] ifFalse:[receiver isSuper ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3195
                receiver isHere ifFalse:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3196
                    err notNil ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3197
                        err := err, ' in superclass chain'.
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3198
                    ].
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3199
                ] ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3200
                    err notNil ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3201
                        err := err, ' in this class or superclass chain'.
1203
2bd6633eced0 better error message for 'class foo', where foo is implemented in the instance.
Claus Gittinger <cg@exept.de>
parents: 1202
diff changeset
  3202
                    ].
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3203
                ]
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3204
            ] ifFalse:[receiver isSelf ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3205
                err notNil ifTrue:[ 
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3206
                    |subErr|
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3207
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3208
                    "/ understood by all subclasses ?
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3209
                    classToCompileFor allSubclassesDo:[:eachSubclass |
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3210
                        subErr isNil ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3211
                            selClass := eachSubclass.
1507
bd29313cd901 selector check w.r.t. subclassResponsibility
penk
parents: 1499
diff changeset
  3212
                            subErr := self checkSelector:selectorSymbol for:receiver inClass:selClass.     
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3213
                        ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3214
                    ].   
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3215
                    subErr notNil ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3216
                        err := subErr, ' in this class, superclass chain or all subclasses'
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3217
                    ] ifFalse:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3218
                        err := err, ' in this class or superclass chain'.
1440
7084ae99ced7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1439
diff changeset
  3219
                    ].
7084ae99ced7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1439
diff changeset
  3220
                    canDefine := true.
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3221
                ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3222
            ] ifFalse:[(receiver isUnaryMessage
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3223
                        and:[receiver selector == #class
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3224
                        and:[receiver receiver isSelf]]) ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3225
                "its a message to self class - can check this too ..."
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3226
                err notNil ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3227
                    classToCompileFor isMeta ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3228
                        err := err, ' for the classes class'.
1507
bd29313cd901 selector check w.r.t. subclassResponsibility
penk
parents: 1499
diff changeset
  3229
                        (self checkSelector:selectorSymbol for:receiver inClass:classToCompileFor) isNil ifTrue:[
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3230
                            err := err, '...\\...but its implemented for the class itself. You probably do not want the #class message here.'.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3231
                            err := err withCRs.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3232
                        ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3233
                    ] ifFalse:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3234
                        err := err, ' for my class'.
1507
bd29313cd901 selector check w.r.t. subclassResponsibility
penk
parents: 1499
diff changeset
  3235
                        (self checkSelector:selectorSymbol for:receiver inClass:classToCompileFor) isNil ifTrue:[
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3236
                            err := err, '...\\...but its implemented for instances. You may want to remove the #class message.'.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3237
                            err := err withCRs.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3238
                        ].
1203
2bd6633eced0 better error message for 'class foo', where foo is implemented in the instance.
Claus Gittinger <cg@exept.de>
parents: 1202
diff changeset
  3239
                    ].
2bd6633eced0 better error message for 'class foo', where foo is implemented in the instance.
Claus Gittinger <cg@exept.de>
parents: 1202
diff changeset
  3240
                ].
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3241
            ] ifFalse:[(receiver isMethodVariable and:[receiver token type isNil]) ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3242
                "if it is an uninitialized variable ..."
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3243
                ((modifiedLocalVars isNil or:[(modifiedLocalVars includes:receiver name) not])
1441
7ebe4e486524 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1440
diff changeset
  3244
                 and:[hasPrimitiveCode not
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3245
                 and:[currentBlock isNil
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3246
                 and:[alreadyWarnedUninitializedVars isNil 
1442
1986d3b0513d selectorCheck
Claus Gittinger <cg@exept.de>
parents: 1441
diff changeset
  3247
                      or:[(alreadyWarnedUninitializedVars includes:receiver name) not]]]]) 
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3248
                ifTrue:[
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3249
                    ((#(at: at:put: basicAt: basicAt:put:) includes:selectorSymbol) 
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3250
                     or:[(nil respondsTo:selectorSymbol) not])ifTrue:[
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3251
                        "/ avoid trouble in miniTalk
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3252
                        "/ during bootstrap
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3253
                        nm := receiver name.    
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3254
                        Text notNil ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3255
                            nm := nm allItalic
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3256
                        ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3257
                        err := 'sent to possibly uninitialized variable ''' , nm , ''' here (?)'.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3258
                        alreadyWarnedUninitializedVars isNil ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3259
                            alreadyWarnedUninitializedVars := Set new
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3260
                        ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3261
                        alreadyWarnedUninitializedVars add:receiver name
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3262
                    ]
705
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3263
                ]
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3264
            ] ifFalse:[
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3265
                (err notNil and:[selClass notNil]) ifTrue:[
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3266
                    err := err, ' (message to ' , selClass nameWithArticle , ')'.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3267
                ].
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  3268
            ]]]]]].
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3269
        ]
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3270
    ].
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3271
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3272
    err notNil ifTrue:[
705
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3273
        (receiver notNil
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3274
        and:[((recType := receiver type) == #GlobalVariable)
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3275
             or:[recType == #PrivateClass]]) ifTrue:[
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3276
            "/ dont check autoloaded classes 
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3277
            "/ - it may work after loading
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3278
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3279
            rec := receiver evaluate. 
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3280
            (rec notNil 
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3281
             and:[rec isBehavior
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3282
             and:[rec isLoaded not]]) ifTrue:[
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  3283
                ^ aSelectorString
705
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3284
            ].
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3285
            rec class == UndefinedVariable ifTrue:[
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3286
                "/ dont check undefined vars;
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3287
                "/ it may work after loading/defining
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  3288
                ^ aSelectorString
705
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3289
            ].
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3290
        ].
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3291
        Text notNil ifTrue:[
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3292
            err := '"' , aSelectorString allBold, '" ', err
1052
0a1e613468f5 avoid trouble if Text class is not present (in mini-image)
Claus Gittinger <cg@exept.de>
parents: 1043
diff changeset
  3293
        ] ifFalse:[
1158
f2cbdb21e0b0 Check for obsolete methods, if possible.
Stefan Vogel <sv@exept.de>
parents: 1157
diff changeset
  3294
            err := aSelectorString , ' ', err
1052
0a1e613468f5 avoid trouble if Text class is not present (in mini-image)
Claus Gittinger <cg@exept.de>
parents: 1043
diff changeset
  3295
        ].
1157
122be9201878 selectorCheck (do not complain for new selector being recursively invoked)
Claus Gittinger <cg@exept.de>
parents: 1156
diff changeset
  3296
        "/ if its a recursive invocation of just that selector, do not complain
122be9201878 selectorCheck (do not complain for new selector being recursively invoked)
Claus Gittinger <cg@exept.de>
parents: 1156
diff changeset
  3297
        (selector = aSelectorString and:[ receiver isSelf]) ifTrue:[
122be9201878 selectorCheck (do not complain for new selector being recursively invoked)
Claus Gittinger <cg@exept.de>
parents: 1156
diff changeset
  3298
            ^ aSelectorString
122be9201878 selectorCheck (do not complain for new selector being recursively invoked)
Claus Gittinger <cg@exept.de>
parents: 1156
diff changeset
  3299
        ].
1499
69439abfdb93 Warn when using subclassResponsibility or shouldNotImplememt methods
Stefan Vogel <sv@exept.de>
parents: 1495
diff changeset
  3300
        isSyntaxHighlighter ifTrue:[
1439
0fddfcdca37b selector check improved
Claus Gittinger <cg@exept.de>
parents: 1437
diff changeset
  3301
            posVector do:[:p |
0fddfcdca37b selector check improved
Claus Gittinger <cg@exept.de>
parents: 1437
diff changeset
  3302
                self markUnknownIdentifierFrom:(p start) to:(p stop).
0fddfcdca37b selector check improved
Claus Gittinger <cg@exept.de>
parents: 1437
diff changeset
  3303
            ].
0fddfcdca37b selector check improved
Claus Gittinger <cg@exept.de>
parents: 1437
diff changeset
  3304
        ].
1597
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3305
        isSyntaxHighlighter ifFalse:[
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3306
            err := err , '\\This is a warning from the compiler - the code has not yet been executed/compiled.'.
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3307
            newSelector := self correctSelector:aSelectorString 
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3308
                                message:err withCRs 
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3309
                                positions:posVector in:selClass for:receiver.
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3310
"/            self warning:('#' , aSelectorString , '\\' , err) withCRs position:pos1 to:pos2.
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3311
            ^ newSelector.
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3312
        ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3313
    ].
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  3314
    ^ aSelectorString
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3315
705
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  3316
    "Modified: / 5.9.1995 / 17:02:11 / claus"
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  3317
    "Modified: / 19.1.2000 / 16:34:03 / cg"
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3318
!
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3319
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3320
typeOfNode:aNode
1687
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  3321
    |nodeVal nodeType classHint rClass|
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3322
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3323
    aNode isConstant ifTrue:[
1687
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  3324
        "if the receiver is a constant, we know its class..."
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3325
        nodeVal := aNode evaluate.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3326
        ^ nodeVal class.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3327
    ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3328
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3329
    aNode isBlock ifTrue:[
1687
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  3330
        "/ this should help with typos, sending #ifTrue to blocks ...
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3331
        ^ Block
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3332
    ].
1687
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  3333
1597
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3334
    aNode isVariable ifTrue:[
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3335
        nodeType := aNode type.
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3336
        (nodeType == #GlobalVariable or:[nodeType == #PrivateClass]) ifTrue:[
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3337
            "if the receiver is a global, we check it too ..."
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3338
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3339
            nodeVal := aNode evaluate. 
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3340
            "/ dont check autoloaded classes 
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3341
            "/ - it may work after loading
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3342
            (nodeVal isNil 
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3343
             or:[nodeVal isBehavior and:[nodeVal isLoaded not]]) ifTrue:[
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3344
                ^ nil
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3345
            ].
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3346
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3347
            ^ nodeVal class.
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3348
        ].
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3349
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3350
        (aNode isLocal) ifTrue:[
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3351
            classHint := aNode token classHint.
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3352
            classHint notNil ifTrue:[ 
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3353
                ^ Smalltalk classNamed:classHint
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3354
            ].
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  3355
        ].
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3356
    ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3357
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3358
    aNode isSuper ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3359
        "if its a super- or here-send, we can do more checking"
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3360
        aNode isHere ifFalse:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3361
            ^ classToCompileFor superclass ? UndefinedObject.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3362
        ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3363
        ^ classToCompileFor.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3364
    ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3365
    aNode isSelf ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3366
        ^ classToCompileFor.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3367
    ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3368
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3369
    (aNode isUnaryMessage) ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3370
        (aNode selector == #class) ifTrue:[
1687
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  3371
"/            aNode receiver isSelf ifTrue:[
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  3372
"/                "its a message to self class - can check this too ..."
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  3373
"/                ^ classToCompileFor class.
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  3374
"/            ].
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  3375
            rClass := self typeOfNode:aNode receiver.
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  3376
            rClass notNil ifTrue:[
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  3377
                ^ rClass class.
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3378
            ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3379
        ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3380
        ( #(#'isNil' #'notNil') includes:aNode selector) ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3381
            ^ Boolean.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3382
        ]
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3383
    ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3384
    aNode isBinaryMessage ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3385
        ( #(#'<' #'>' #'>=' #'<=' #'=' #'==' #'~=' #'~~') includes:aNode selector) ifTrue:[
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3386
            ^ Boolean.
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3387
        ]
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3388
    ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3389
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  3390
    ^ nil
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3391
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3392
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3393
!Parser methodsFor:'error handling'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3394
1259
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3395
blockArgRedefined:tokenName from:pos1 to:pos2
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3396
    "argname reuse"
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3397
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3398
    self isSyntaxHighlighter ifTrue:[
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3399
        self markBadIdentifierFrom:pos1 to:pos2.
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3400
    ] ifFalse:[
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3401
        self 
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3402
            syntaxError:'redefinition of ''' , tokenName , ''' in argument list.'
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3403
            position:pos1 to:pos2
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3404
    ].
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3405
!
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3406
1495
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3407
errorMessageForUndefined:aName
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3408
    |idx implementors|
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3409
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3410
    classToCompileFor notNil ifTrue:[
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3411
        "/ is it an instance-variable marked inaccessable ?
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3412
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3413
        idx := (self classesInstVarNames) indexOf:(aName , '*') startingAt:1.
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3414
        idx ~~ 0 ifTrue:[
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3415
            ^ '''%1'' is a hidden instvar (not accessable from ST-code)'.
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3416
        ].
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3417
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3418
        "/ is it an instance variable, while evaluateing for the class ?
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3419
        classToCompileFor isMeta ifTrue:[
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3420
            (classToCompileFor soleInstance allInstVarNames includes:aName) ifTrue:[
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3421
                ^ 'Warning: ''%1'' is an instvar\(hint: you are evaluating/compiling in the classes context)'.
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3422
            ]
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3423
        ]
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3424
    ].
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3425
    self isDoIt ifTrue:[
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  3426
        SystemBrowser notNil ifTrue:[
1569
b20e45617214 do not depend on SystemBrowser beeing present
Claus Gittinger <cg@exept.de>
parents: 1564
diff changeset
  3427
            implementors := SystemBrowser
b20e45617214 do not depend on SystemBrowser beeing present
Claus Gittinger <cg@exept.de>
parents: 1564
diff changeset
  3428
                findImplementorsOf:aName
b20e45617214 do not depend on SystemBrowser beeing present
Claus Gittinger <cg@exept.de>
parents: 1564
diff changeset
  3429
                in:(Smalltalk allClasses)
b20e45617214 do not depend on SystemBrowser beeing present
Claus Gittinger <cg@exept.de>
parents: 1564
diff changeset
  3430
                ignoreCase:false.
b20e45617214 do not depend on SystemBrowser beeing present
Claus Gittinger <cg@exept.de>
parents: 1564
diff changeset
  3431
            implementors size > 0 ifTrue:[
b20e45617214 do not depend on SystemBrowser beeing present
Claus Gittinger <cg@exept.de>
parents: 1564
diff changeset
  3432
                ^ '''%1'' is undefined but known as a message selector.\(hint: did you forget to select the receiver ?)'.
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  3433
            ].
1495
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3434
        ].
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3435
    ].
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3436
    ^ '''%1'' is undefined'.
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3437
!
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3438
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3439
exitWith:something
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3440
    "this is the longjump out of evaluation via a return expression"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3441
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3442
    evalExitBlock value:something
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
identifierExpectedIn:what
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3446
    |msg|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3447
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3448
    (#(True False Self Nil Super ThisContext) includes:tokenType) ifTrue:[
1260
50e4668049aa identifier expected - better error message
Claus Gittinger <cg@exept.de>
parents: 1259
diff changeset
  3449
        msg := 'Reserved keyword in ' 
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3450
    ] ifFalse:[
1260
50e4668049aa identifier expected - better error message
Claus Gittinger <cg@exept.de>
parents: 1259
diff changeset
  3451
        msg := 'Identifier expected in ' 
50e4668049aa identifier expected - better error message
Claus Gittinger <cg@exept.de>
parents: 1259
diff changeset
  3452
    ].
50e4668049aa identifier expected - better error message
Claus Gittinger <cg@exept.de>
parents: 1259
diff changeset
  3453
    self syntaxError:(msg , what , ' (got ''' , tokenType printString, ''')')
1371
de4c37ac12fc code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 1369
diff changeset
  3454
         position:tokenPosition to:source position1Based - 1.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3455
    ^ #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
1259
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3458
methodArgRedefined:tokenName from:pos1 to:pos2
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3459
    "argname reuse"
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3460
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3461
    self isSyntaxHighlighter ifTrue:[
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3462
        self markBadIdentifierFrom:pos1 to:pos2.
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3463
    ] ifFalse:[
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3464
        self 
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3465
            syntaxError:'redefinition of ''' , tokenName , ''' in argument list.'
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3466
            position:pos1 to:pos2
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3467
    ].
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3468
!
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  3469
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3470
showErrorMessage:aMessage position:pos
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  3471
    "redefined since parser can give more detailed info about
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  3472
     the class & selector where the error occured."
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  3473
1534
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3474
    |msg|
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  3475
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  3476
    ignoreErrors ifFalse:[
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3477
        Smalltalk silentLoading == true ifFalse:[
1534
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3478
            msg := ''.
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3479
            pos notNil ifTrue:[
1534
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3480
                msg := msg , (pos printString).
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3481
                msg := msg , ' '.
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3482
            ].
1534
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3483
            msg := msg , aMessage.
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3484
            selector notNil ifTrue:[
1534
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3485
                msg := msg , ' in '.
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3486
                classToCompileFor notNil ifTrue:[
1534
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3487
                    msg := msg , classToCompileFor name , '>>'
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3488
                ].
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3489
                msg := msg , selector.
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3490
            ] ifFalse:[
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3491
                classToCompileFor notNil ifTrue:[
1534
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3492
                    msg := msg , ' (' , classToCompileFor name , ')'
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3493
                ]
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3494
            ].
1534
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3495
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3496
            UserInformation isHandled ifTrue:[
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3497
                UserInformation raiseErrorString:msg
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3498
            ] ifFalse:[
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3499
                Transcript showCR:msg.
2a298bacebfb *** empty log message ***
ca
parents: 1531
diff changeset
  3500
            ]
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3501
        ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3502
    ]
273
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  3503
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  3504
    "Modified: 18.5.1996 / 15:44:15 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3505
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3506
171
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  3507
showErrorMessageForClass:aClass
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  3508
"/        compiler parseError:'syntax error'.
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  3509
    Transcript show:'    '.
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  3510
    aClass notNil ifTrue:[
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  3511
        Transcript show:aClass name , '>>'
171
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  3512
    ].
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  3513
    selector notNil ifTrue:[
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  3514
        Transcript show:(selector)
171
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  3515
    ].
273
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  3516
    Transcript showCR:' -> Error'.
171
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  3517
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  3518
    "Created: 13.12.1995 / 20:24:34 / cg"
273
2758f1723f53 showCr: -> showCR:
Claus Gittinger <cg@exept.de>
parents: 265
diff changeset
  3519
    "Modified: 18.5.1996 / 15:44:17 / cg"
171
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  3520
!
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  3521
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3522
undefError:aName position:pos1 to:pos2
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  3523
    "report an undefined variable error - return true, if it should be
86
claus
parents: 85
diff changeset
  3524
     corrected. If not corrected, only one warning is made per undefined
claus
parents: 85
diff changeset
  3525
     variable."
claus
parents: 85
diff changeset
  3526
1495
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3527
    |ex doCorrect boldName|
1400
20ccdab04698 *** empty log message ***
martin
parents: 1399
diff changeset
  3528
20ccdab04698 *** empty log message ***
martin
parents: 1399
diff changeset
  3529
    ex := UndefinedVariableNotification newException.
20ccdab04698 *** empty log message ***
martin
parents: 1399
diff changeset
  3530
    ex parser:self.
20ccdab04698 *** empty log message ***
martin
parents: 1399
diff changeset
  3531
    ex parameter:aName.
20ccdab04698 *** empty log message ***
martin
parents: 1399
diff changeset
  3532
    ex suspendedContext:thisContext.
20ccdab04698 *** empty log message ***
martin
parents: 1399
diff changeset
  3533
    doCorrect := ex raiseRequest.
1399
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  3534
    doCorrect notNil ifTrue:[
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  3535
        ^ doCorrect
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  3536
    ].
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  3537
1716
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  3538
    ignoreWarnings ifTrue:[^ false].
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  3539
    parserFlags warnings ifFalse:[^ false].
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3540
    parserFlags warnUndeclared ifFalse:[^ false].
607
118452a23976 allow dollars in identifiers
Claus Gittinger <cg@exept.de>
parents: 603
diff changeset
  3541
86
claus
parents: 85
diff changeset
  3542
    "
claus
parents: 85
diff changeset
  3543
     alredy warned about this one ?
claus
parents: 85
diff changeset
  3544
    "
claus
parents: 85
diff changeset
  3545
    warnedUndefVars notNil ifTrue:[
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3546
        (warnedUndefVars includes:aName) ifTrue:[
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3547
            "already warned about this one"
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3548
            ^ false
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3549
        ].
86
claus
parents: 85
diff changeset
  3550
    ].
claus
parents: 85
diff changeset
  3551
131
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  3552
"/    (classToCompileFor notNil 
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  3553
"/    and:[classToCompileFor superclass notNil
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  3554
"/    and:[classToCompileFor superclass instanceVariableString isNil]]) ifTrue:[
132
5be56a5e90b7 added methods for silent parsing (parseMethod / parseMethodSpec)
Claus Gittinger <cg@exept.de>
parents: 131
diff changeset
  3555
"/      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
  3556
"/      ^ false
131
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  3557
"/    ].
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  3558
1285
32af9747bf9d error messages
Claus Gittinger <cg@exept.de>
parents: 1282
diff changeset
  3559
    boldName := aName allBold.
32af9747bf9d error messages
Claus Gittinger <cg@exept.de>
parents: 1282
diff changeset
  3560
131
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  3561
    (requestor isNil or:[requestor isStream]) ifTrue:[
1696
4b0db823d6a2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1692
diff changeset
  3562
        aName isUppercaseFirst ifFalse:[
1285
32af9747bf9d error messages
Claus Gittinger <cg@exept.de>
parents: 1282
diff changeset
  3563
            self showErrorMessage:('Error: ''' , boldName , ''' is undefined') position:pos1.
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3564
        ].
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3565
        doCorrect := false.
86
claus
parents: 85
diff changeset
  3566
    ] ifFalse:[
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3567
        "
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3568
         ask requestor for correct/continue/abort ...
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3569
         it is supposed to raise abort or return true/false.
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3570
         True return means that correction is wanted.
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3571
        "
1495
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3572
        doCorrect := self 
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3573
                        correctableError:((self errorMessageForUndefined:aName) bindWith:boldName) withCRs
63d2a1a94504 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1491
diff changeset
  3574
                        position:pos1 to:pos2
86
claus
parents: 85
diff changeset
  3575
    ].
claus
parents: 85
diff changeset
  3576
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3577
    doCorrect == false ifTrue:[
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3578
        warnedUndefVars isNil ifTrue:[
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3579
            warnedUndefVars := Set new.
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3580
        ].
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  3581
        warnedUndefVars add:aName.
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  3582
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3583
86
claus
parents: 85
diff changeset
  3584
    ^ doCorrect
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  3585
607
118452a23976 allow dollars in identifiers
Claus Gittinger <cg@exept.de>
parents: 603
diff changeset
  3586
    "Modified: 7.9.1997 / 02:14:36 / cg"
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3587
!
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3588
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3589
warnSTXHereExtensionUsedAt:position
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3590
    ignoreWarnings ifFalse:[
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3591
        didWarnAboutSTXHereExtensionUsed ifFalse:[
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3592
            parserFlags warnSTXHereExtensionUsed ifTrue:[
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3593
                self warning:'here-sends are a nonstandard feature of ST/X' 
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3594
                     position:position to:position+3.
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3595
                "
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3596
                 only warn once
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3597
                "
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3598
                didWarnAboutSTXHereExtensionUsed := true
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3599
            ].
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3600
        ].
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3601
    ].
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3602
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3603
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3604
warnSTXNameSpaceUseAt:position
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3605
    ignoreWarnings ifFalse:[
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3606
        didWarnAboutSTXNameSpaceUse ifFalse:[
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3607
            parserFlags warnSTXNameSpaceUse ifTrue:[
1664
c49ce86307bf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1657
diff changeset
  3608
                self warning:'NameSpaces are a nonstandard feature of ST/X' 
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3609
                     doNotShowAgainAction:[ ParserFlags warnSTXSpecials:false ]
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3610
                     position:position to:(source position1Based).
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3611
                "
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3612
                 only warn once
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3613
                "
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3614
                didWarnAboutSTXNameSpaceUse := false
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3615
            ]
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3616
        ]
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3617
    ].
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3618
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3619
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3620
warnUnused:aNameCollection
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3621
    "report an unused method variable"
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3622
1654
8e793d0b9d83 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1653
diff changeset
  3623
    |msg answer lineLength first|
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3624
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3625
    (ignoreErrors not 
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3626
    and:[ignoreWarnings not 
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  3627
    and:[parserFlags warnUnusedVars]]) ifTrue:[
1638
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  3628
        msg := 'Unused method variable(s): '.
1654
8e793d0b9d83 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1653
diff changeset
  3629
        lineLength := msg size.
8e793d0b9d83 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1653
diff changeset
  3630
        first := true.
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3631
        aNameCollection asSortedCollection do:[:name|
1654
8e793d0b9d83 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1653
diff changeset
  3632
            first ifTrue:[ first := false ] ifFalse:[msg := msg , ', '].
8e793d0b9d83 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1653
diff changeset
  3633
            msg := msg , ('"',name allBold,'"').
8e793d0b9d83 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1653
diff changeset
  3634
            lineLength := lineLength + 2 + name size + 1.
8e793d0b9d83 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1653
diff changeset
  3635
            lineLength > 60 ifTrue:[
8e793d0b9d83 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1653
diff changeset
  3636
                msg := msg , '\' withCRs.
8e793d0b9d83 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1653
diff changeset
  3637
                lineLength := 0.
8e793d0b9d83 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1653
diff changeset
  3638
            ].
1638
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  3639
        ].
1222
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  3640
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3641
        (requestor isNil or:[requestor isStream]) ifTrue:[
1222
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  3642
            self showErrorMessage:('Warning: ', msg) position:nil.
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3643
        ] ifFalse:[
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  3644
            answer := requestor 
1222
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  3645
                unusedVariableWarning:msg
1432
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  3646
                position:(localVarDefPosition first) to:(localVarDefPosition last) from:self.
1222
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  3647
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  3648
            answer == true ifTrue:[
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  3649
                "/ delete the definitions ...
1221
2768cbe3be2b finished remove unused vars;
Claus Gittinger <cg@exept.de>
parents: 1220
diff changeset
  3650
                aNameCollection do:[:eachName |
1432
a85ce0ec6ee4 deleting multiple local variables
Claus Gittinger <cg@exept.de>
parents: 1427
diff changeset
  3651
                    self deleteDefinitionOf:eachName in:(localVarDefPosition first) to:(localVarDefPosition last).
1221
2768cbe3be2b finished remove unused vars;
Claus Gittinger <cg@exept.de>
parents: 1220
diff changeset
  3652
                ].
2768cbe3be2b finished remove unused vars;
Claus Gittinger <cg@exept.de>
parents: 1220
diff changeset
  3653
                RestartCompilationSignal raise
1167
34f58eacdbda unused variables correction
Claus Gittinger <cg@exept.de>
parents: 1165
diff changeset
  3654
            ].
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3655
        ].
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  3656
    ].
1221
2768cbe3be2b finished remove unused vars;
Claus Gittinger <cg@exept.de>
parents: 1220
diff changeset
  3657
1222
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  3658
    "Modified: / 17.11.2001 / 10:30:47 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3659
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3660
1363
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3661
!Parser methodsFor:'evaluating expressions'!
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3662
1683
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3663
evaluate:aStringOrStream
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3664
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3665
     Allow access to anObject as self and to its instVars (used in the inspector).
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3666
     If logged is true, an entry is added to the change-file. If the failBlock argument
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3667
     is non-nil, it is evaluated if an error occurs.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3668
     Finally, compile specifies if the string should be compiled down to 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3669
     bytecode or instead be interpreted from the parseTree.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3670
     The first should be done for doIts etc, where a readable walkback is
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3671
     required.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3672
     The latter is better done for constants, styleSheet and resource
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3673
     reading and simple sends, where the overhead of compilation is bigger
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3674
     than the interpretation overhead."
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3675
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3676
    ^ self
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3677
        evaluate:aStringOrStream 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3678
        in:nil 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3679
        receiver:nil 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3680
        notifying:requestor 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3681
        logged:logged 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3682
        ifFail:[ self error:'error in eval' ] 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3683
        compile:false 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3684
        checkForEndOfInput:true
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3685
!
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3686
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3687
evaluate:aStringOrStream ifFail:failBlock
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3688
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3689
     Allow access to anObject as self and to its instVars (used in the inspector).
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3690
     If logged is true, an entry is added to the change-file. If the failBlock argument
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3691
     is non-nil, it is evaluated if an error occurs.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3692
     Finally, compile specifies if the string should be compiled down to 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3693
     bytecode or instead be interpreted from the parseTree.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3694
     The first should be done for doIts etc, where a readable walkback is
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3695
     required.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3696
     The latter is better done for constants, styleSheet and resource
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3697
     reading and simple sends, where the overhead of compilation is bigger
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3698
     than the interpretation overhead."
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3699
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3700
    ^ self
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3701
        evaluate:aStringOrStream 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3702
        in:nil 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3703
        receiver:nil 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3704
        notifying:requestor 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3705
        logged:logged 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3706
        ifFail:failBlock 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3707
        compile:false 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3708
        checkForEndOfInput:true
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3709
!
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3710
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3711
evaluate:aStringOrStream in:aContext receiver:anObject
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3712
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3713
     Allow access to anObject as self and to its instVars (used in the inspector).
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3714
     If logged is true, an entry is added to the change-file. If the failBlock argument
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3715
     is non-nil, it is evaluated if an error occurs.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3716
     Finally, compile specifies if the string should be compiled down to 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3717
     bytecode or instead be interpreted from the parseTree.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3718
     The first should be done for doIts etc, where a readable walkback is
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3719
     required.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3720
     The latter is better done for constants, styleSheet and resource
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3721
     reading and simple sends, where the overhead of compilation is bigger
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3722
     than the interpretation overhead."
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3723
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3724
    ^ self
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3725
        evaluate:aStringOrStream 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3726
        in:aContext 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3727
        receiver:anObject 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3728
        notifying:requestor 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3729
        logged:logged 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3730
        ifFail:[ self error:'error in eval' ] 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3731
        compile:false 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3732
        checkForEndOfInput:true
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3733
!
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3734
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3735
evaluate:aStringOrStream in:aContext receiver:anObject ifFail:failBlock
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3736
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3737
     Allow access to anObject as self and to its instVars (used in the inspector).
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3738
     If logged is true, an entry is added to the change-file. If the failBlock argument
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3739
     is non-nil, it is evaluated if an error occurs.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3740
     Finally, compile specifies if the string should be compiled down to 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3741
     bytecode or instead be interpreted from the parseTree.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3742
     The first should be done for doIts etc, where a readable walkback is
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3743
     required.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3744
     The latter is better done for constants, styleSheet and resource
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3745
     reading and simple sends, where the overhead of compilation is bigger
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3746
     than the interpretation overhead."
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3747
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3748
    ^ self
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3749
        evaluate:aStringOrStream 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3750
        in:aContext 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3751
        receiver:anObject 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3752
        notifying:requestor 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3753
        logged:logged 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3754
        ifFail:failBlock 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3755
        compile:false 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3756
        checkForEndOfInput:true
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3757
!
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3758
1363
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3759
evaluate:aStringOrStream in:aContext receiver:anObject notifying:requestor logged:logged ifFail:failBlock compile:compile
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3760
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3761
     Allow access to anObject as self and to its instVars (used in the inspector).
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3762
     If logged is true, an entry is added to the change-file. If the failBlock argument
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3763
     is non-nil, it is evaluated if an error occurs.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3764
     Finally, compile specifies if the string should be compiled down to 
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3765
     bytecode or instead be interpreted from the parseTree.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3766
     The first should be done for doIts etc, where a readable walkback is
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3767
     required.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3768
     The latter is better done for constants, styleSheet and resource
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3769
     reading and simple sends, where the overhead of compilation is bigger
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3770
     than the interpretation overhead."
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3771
1548
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3772
    ^ self
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3773
        evaluate:aStringOrStream 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3774
        in:aContext 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3775
        receiver:anObject 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3776
        notifying:requestor 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3777
        logged:logged 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3778
        ifFail:failBlock 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3779
        compile:compile 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3780
        checkForEndOfInput:true
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3781
!
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3782
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3783
evaluate:aStringOrStream in:aContext receiver:anObject notifying:requestor logged:logged ifFail:failBlock compile:compile checkForEndOfInput:checkForEndOfInput
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3784
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3785
     Allow access to anObject as self and to its instVars (used in the inspector).
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3786
     If logged is true, an entry is added to the change-file. If the failBlock argument
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3787
     is non-nil, it is evaluated if an error occurs.
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3788
     Finally, compile specifies if the string should be compiled down to 
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3789
     bytecode or instead be interpreted from the parseTree.
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3790
     The first should be done for doIts etc, where a readable walkback is
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3791
     required.
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3792
     The latter is better done for constants, styleSheet and resource
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3793
     reading and simple sends, where the overhead of compilation is bigger
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3794
     than the interpretation overhead."
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3795
1363
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3796
    |tree mustBackup loggedString chgStream value s sReal spc
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3797
     nameSpaceQuerySignal compiler|
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3798
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3799
    aStringOrStream isNil ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3800
        EmptySourceNotificationSignal raiseRequest.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3801
        ^ nil
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3802
    ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3803
    (mustBackup := aStringOrStream isStream) ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3804
        s := aStringOrStream.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3805
    ] ifFalse:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3806
        loggedString := aStringOrStream.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3807
        s := ReadStream on:aStringOrStream.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3808
    ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3809
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3810
    self source:s.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3811
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3812
    self parseForCode.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3813
    self foldConstants:nil.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3814
    self setSelf:anObject.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3815
    self setContext:aContext.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3816
    aContext notNil ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3817
        self setSelf:(aContext receiver).
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3818
"/        aContext method notNil ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3819
"/            cls := aContext method mclass
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3820
"/        ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3821
"/        self setClassToCompileFor:(cls ? aContext receiver class).
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3822
        self setClassToCompileFor:(aContext receiver class).
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3823
    ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3824
    self notifying:requestor.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3825
    self nextToken.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3826
    self evalExitBlock:[:value | self release. ^ value].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3827
    tree := self parseMethodBodyOrEmpty.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3828
1548
a8e0beb870b6 +evaluateFrom:
Claus Gittinger <cg@exept.de>
parents: 1547
diff changeset
  3829
    checkForEndOfInput ifTrue:[self checkForEndOfInput].
1363
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3830
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3831
    "if reading from a stream, backup for next expression"
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3832
    mustBackup ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3833
        self backupPosition
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3834
    ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3835
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3836
    (self errorFlag or:[tree == #Error]) ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3837
        failBlock notNil ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3838
            ^ failBlock value
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3839
        ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3840
        ^ #Error
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3841
    ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3842
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3843
    tree isNil ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3844
        EmptySourceNotificationSignal raiseRequest.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3845
        ^ nil
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3846
    ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3847
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3848
    (logged
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3849
    and:[loggedString notNil
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3850
    and:[Smalltalk logDoits]]) ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3851
        Class updateChangeFileQuerySignal query ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3852
            chgStream := Class changesStream.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3853
            chgStream notNil ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3854
                chgStream nextChunkPut:loggedString.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3855
                chgStream cr.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3856
                chgStream close
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3857
            ]
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3858
        ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3859
        Project notNil ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3860
            Class updateChangeListQuerySignal query ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3861
                Project addDoIt:loggedString
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3862
            ]
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3863
        ]
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3864
    ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3865
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3866
    "
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3867
     during the evaluation, handle nameSpace queries
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3868
     from the value as defined by any namespace directive.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3869
     This, if its a class definition expression, the class will
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3870
     be installed there.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3871
    "
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3872
    nameSpaceQuerySignal := Class nameSpaceQuerySignal.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3873
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3874
    spc := self getNameSpace.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3875
    spc isNil ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3876
        (requestor respondsTo:#currentNameSpace) ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3877
            spc := requestor currentNameSpace
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3878
        ] ifFalse:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3879
            spc := nameSpaceQuerySignal query.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3880
        ]
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3881
    ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3882
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3883
    nameSpaceQuerySignal answer:spc
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3884
    do:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3885
        |method|
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3886
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3887
        "
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3888
         if compile is false, or the parse tree is that of a constant, 
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3889
         or a variable, quickly return its value.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3890
         This is used for example, when reading simple objects
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3891
         via #readFrom:. 
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3892
         The overhead of compiling a method is avoided in this case.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3893
        "
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3894
        ((SuppressDoItCompilation == true)
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3895
         or:[compile not 
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3896
         or:[tree isConstant
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3897
         or:[tree isVariable
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3898
         or:[aStringOrStream isStream
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3899
         or:[aContext notNil]]]]]) ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3900
            ^ tree evaluate
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3901
        ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3902
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3903
        "
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3904
         if I am the ByteCodeCompiler,
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3905
         generate a dummy method, execute it and return the value.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3906
         otherwise, just evaluate the tree; slower, but not too bad ...
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3907
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3908
         This allows systems to be delivered without the ByteCodeCompiler,
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3909
         and still evaluate expressions 
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3910
         (needed to read resource files or to process .rc files).
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3911
        "
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3912
        self == Parser ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3913
            self evalExitBlock:[:value | self release. ^ value].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3914
            value := tree evaluate.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3915
            self evalExitBlock:nil.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3916
        ] ifFalse:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3917
            s := self correctedSource.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3918
            s isNil ifTrue:[    
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3919
                aStringOrStream isStream ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3920
                    s := self collectedSource.  "/ does not work yet ...
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3921
                ] ifFalse:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3922
                    s := aStringOrStream
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3923
                ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3924
            ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3925
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3926
            "/ actually, its a block, to allow
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3927
            "/ easy return ...
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3928
1421
dcdc178254f0 preserve lineNumbers in compiled code (evaluate)
Claus Gittinger <cg@exept.de>
parents: 1420
diff changeset
  3929
            sReal := 'doIt ^[ ' , s , '\] value' withCRs.
1363
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3930
1366
f91f6a0a56d5 when required to compile, use Compiler instead of self class.
Claus Gittinger <cg@exept.de>
parents: 1365
diff changeset
  3931
            compiler := ByteCodeCompiler new.
1363
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3932
            compiler initializeFlagsFrom:self.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3933
            method := compiler
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3934
                    compile:sReal 
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3935
                    forClass:anObject class
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3936
                    inCategory:'_temporary_' 
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3937
                    notifying:requestor 
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3938
                    install:false 
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3939
                    skipIfSame:false 
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3940
                    silent:true
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3941
                    foldConstants:false.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3942
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3943
            method notNil ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3944
                method ~~ #Error ifTrue:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3945
                    "
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3946
                     fake: patch the source string, to what the user expects
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3947
                     in the browser
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3948
                    "
1421
dcdc178254f0 preserve lineNumbers in compiled code (evaluate)
Claus Gittinger <cg@exept.de>
parents: 1420
diff changeset
  3949
                    method source:"'        ' , "s string.
1363
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3950
                    "
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3951
                     dont do any just-in-time compilation on it.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3952
                    "
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3953
                    method checked:true.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3954
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3955
                    value := method 
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3956
                                valueWithReceiver:anObject 
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3957
                                arguments:nil  "/ (Array with:m) 
1440
7084ae99ced7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1439
diff changeset
  3958
                                selector:(requestor isNil ifTrue:#'doItX' ifFalse:#'doIt') "/ #doIt: 
1363
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3959
                                search:nil
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3960
                                sender:nil.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3961
                ] ifFalse:[
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3962
                    self evalExitBlock:[:value | self release. ^ value].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3963
                    value := tree evaluate.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3964
                    self evalExitBlock:nil.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3965
                ]
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3966
            ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3967
        ]
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3968
    ].
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3969
    self release.
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3970
    ^ value
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3971
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3972
    "Created: / 8.2.1997 / 19:34:44 / cg"
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3973
    "Modified: / 18.3.1999 / 18:25:40 / stefan"
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  3974
    "Modified: / 6.2.2000 / 15:01:57 / cg"
1683
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3975
!
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3976
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3977
evaluate:aStringOrStream receiver:anObject
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3978
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3979
     Allow access to anObject as self and to its instVars (used in the inspector).
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3980
     If logged is true, an entry is added to the change-file. If the failBlock argument
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3981
     is non-nil, it is evaluated if an error occurs.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3982
     Finally, compile specifies if the string should be compiled down to 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3983
     bytecode or instead be interpreted from the parseTree.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3984
     The first should be done for doIts etc, where a readable walkback is
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3985
     required.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3986
     The latter is better done for constants, styleSheet and resource
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3987
     reading and simple sends, where the overhead of compilation is bigger
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3988
     than the interpretation overhead."
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3989
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3990
    ^ self
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3991
        evaluate:aStringOrStream 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3992
        in:nil 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3993
        receiver:anObject 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3994
        notifying:requestor 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3995
        logged:logged 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3996
        ifFail:[ self error:'error in eval' ] 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3997
        compile:false 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3998
        checkForEndOfInput:true
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  3999
!
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4000
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4001
evaluate:aStringOrStream receiver:anObject ifFail:failBlock
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4002
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4003
     Allow access to anObject as self and to its instVars (used in the inspector).
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4004
     If logged is true, an entry is added to the change-file. If the failBlock argument
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4005
     is non-nil, it is evaluated if an error occurs.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4006
     Finally, compile specifies if the string should be compiled down to 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4007
     bytecode or instead be interpreted from the parseTree.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4008
     The first should be done for doIts etc, where a readable walkback is
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4009
     required.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4010
     The latter is better done for constants, styleSheet and resource
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4011
     reading and simple sends, where the overhead of compilation is bigger
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4012
     than the interpretation overhead."
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4013
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4014
    ^ self
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4015
        evaluate:aStringOrStream 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4016
        in:nil 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4017
        receiver:anObject 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4018
        notifying:requestor 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4019
        logged:logged 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4020
        ifFail:failBlock 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4021
        compile:false 
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4022
        checkForEndOfInput:true
1363
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  4023
! !
2ce77081f79a separated instance creation from parsing
penk
parents: 1361
diff changeset
  4024
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4025
!Parser methodsFor:'parsing'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4026
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4027
block
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4028
    "parse a block; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4029
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4030
    |node args argNames arg pos pos2 lno|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4031
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4032
    lno := tokenLineNr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4033
    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4034
    (tokenType == $: ) ifTrue:[
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4035
        [tokenType == $:] whileTrue:[
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4036
            pos := tokenPosition.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4037
            self nextToken.
1394
93e75cb62f4f incompatibility warning with space between colon and id in blockArgs.
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
  4038
93e75cb62f4f incompatibility warning with space between colon and id in blockArgs.
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
  4039
            (pos == (tokenPosition - 1)) ifFalse:[
93e75cb62f4f incompatibility warning with space between colon and id in blockArgs.
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
  4040
                self warnPossibleIncompatibility:'space(s) between colon and identifier may be non-portable' position:pos to:tokenPosition.
93e75cb62f4f incompatibility warning with space between colon and id in blockArgs.
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
  4041
            ].
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4042
            (tokenType ~~ #Identifier) ifTrue:[
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4043
                ^ self identifierExpectedIn:'block-arg declaration'
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4044
            ].
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4045
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4046
            pos2 := tokenPosition + tokenName size - 1.
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4047
            self markArgumentIdentifierFrom:tokenPosition to:pos2.
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  4048
            self checkBlockArgumentNameConventionsFor:tokenName.
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4049
            arg := Variable name:tokenName.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4050
            args isNil ifTrue:[
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4051
                args := Array with:arg.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4052
                argNames := Array with:tokenName.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4053
            ] ifFalse:[
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4054
                (argNames includes:tokenName) ifTrue:[
1259
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4055
                    self blockArgRedefined:tokenName from:tokenPosition to:pos2
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4056
                ].
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4057
                args := args copyWith:arg.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4058
                argNames := argNames copyWith:tokenName.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4059
            ].
1394
93e75cb62f4f incompatibility warning with space between colon and id in blockArgs.
Claus Gittinger <cg@exept.de>
parents: 1393
diff changeset
  4060
            self nextToken.
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4061
        ].
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4062
        (tokenType ~~ $| ) ifTrue:[
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4063
            "ST-80 allows [:arg ]"
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4064
            (tokenType == $] ) ifTrue:[
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4065
                node := BlockNode arguments:args home:currentBlock variables:nil.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4066
                node lineNumber:lno.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4067
                ^ node
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4068
            ].
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4069
            self syntaxError:'| expected after block-arg declaration'.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4070
            ^ #Error
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4071
        ].
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4072
        self nextToken
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4073
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4074
    node := self blockBody:args.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4075
    (node notNil and:[node ~~ #Error]) ifTrue:[
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4076
        node lineNumber:lno.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4077
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4078
    ^ node
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4079
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4080
    "Modified: / 31.3.1998 / 17:31:34 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4081
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4082
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4083
blockBody:args
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4084
    "parse a blocks body; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4085
1342
65f8f4d0ce09 only autoDefine workspace vars on the top level (i.e. not within blocks)
Claus Gittinger <cg@exept.de>
parents: 1341
diff changeset
  4086
    |stats node var vars lno pos2|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4087
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4088
    lno := tokenLineNr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4089
    (tokenType == $| ) ifTrue:[
668
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4090
        self nextToken.
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4091
        [tokenType == $|] whileFalse:[
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4092
            (tokenType == #Identifier) ifFalse:[
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4093
                ^ self identifierExpectedIn:'block-var declaration'
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4094
            ].
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4095
            pos2 := tokenPosition + tokenName size - 1.
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4096
            self markLocalIdentifierFrom:tokenPosition to:pos2.
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  4097
            self checkBlockVariableNameConventionsFor:tokenName.
668
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4098
            var := Variable name:tokenName.
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4099
            vars isNil ifTrue:[
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4100
                vars := Array with:var.
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4101
            ] ifFalse:[
1342
65f8f4d0ce09 only autoDefine workspace vars on the top level (i.e. not within blocks)
Claus Gittinger <cg@exept.de>
parents: 1341
diff changeset
  4102
                (vars contains:[:var | var name = tokenName]) ifTrue:[
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4103
                    "/ varname reuse
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4104
                    self isSyntaxHighlighter ifTrue:[
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4105
                        self markBadIdentifierFrom:tokenPosition to:pos2.
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4106
                    ] ifFalse:[
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4107
                        self 
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4108
                            parseError:'redefinition of ''' , tokenName , ''' in local variables'
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4109
                            position:tokenPosition to:pos2.
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4110
                    ]
668
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4111
                ] ifFalse:[
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4112
                    vars := vars copyWith:var.
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4113
                ]
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4114
            ].
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4115
            self nextToken.
1471
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4116
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  4117
            parserFlags allowLocalVariableDeclarationWithInitializerExpression == true ifTrue:[
1471
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4118
                ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4119
                    self nextToken.
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4120
                    "/ Q: should we allow literals only, or arbitrary expressions ?
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4121
                    self halt:'unimplemented feature'.
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4122
                ]
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4123
            ].
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  4124
            parserFlags allowDomainVariables == true ifTrue:[
1471
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4125
                (tokenType == $() ifTrue:[
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4126
                    self variableTypeDeclarationFor:var.
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4127
                ].
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4128
            ].
668
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4129
        ].
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4130
        self nextToken
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4131
    ].
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  4132
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4133
    node := BlockNode arguments:args home:currentBlock variables:vars.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4134
    node lineNumber:lno.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4135
    currentBlock := node.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4136
    stats := self blockStatementList.
1169
7204e72c7c3c better error message with bad parentNesting in a block.
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  4137
    (stats == #Error) ifTrue:[^ #Error].
7204e72c7c3c better error message with bad parentNesting in a block.
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  4138
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  4139
    lineNumberInfo == #full ifTrue:[
668
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4140
        node endLineNumber:tokenLineNr
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  4141
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4142
    node statements:stats.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4143
    currentBlock := node home.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4144
    ^ node
382
49aeeb0746ba more lineNumber info
Claus Gittinger <cg@exept.de>
parents: 377
diff changeset
  4145
668
8cc13d42d244 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 664
diff changeset
  4146
    "Modified: / 31.3.1998 / 22:46:09 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4147
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4148
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4149
blockExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4150
    "parse a blockExpression; return a node-tree, nil or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4151
     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
  4152
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4153
    tokenType ~~ $[ ifTrue:[
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  4154
        self syntaxError:'[ expected'.
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  4155
        ^ #Error.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4156
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4157
    ^ self block
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4158
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4159
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4160
blockStatementList
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4161
    "parse a blocks statementlist; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4162
743
3ced4791090c changes for cascades to super/here semantics.
Claus Gittinger <cg@exept.de>
parents: 739
diff changeset
  4163
    |thisStatement prevStatement firstStatement eMsg|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4164
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4165
    (tokenType == $] ) ifTrue:[^ nil].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4166
    thisStatement := self statement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4167
    (thisStatement == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4168
    firstStatement := thisStatement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4169
    [tokenType == $] ] whileFalse:[
673
0c66b7cb1d2f checkin from browser
ca
parents: 672
diff changeset
  4170
        (tokenType == $.) ifFalse:[
1169
7204e72c7c3c better error message with bad parentNesting in a block.
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  4171
            (tokenType == #EOF) ifTrue:[
1371
de4c37ac12fc code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 1369
diff changeset
  4172
                self syntaxError:'missing '']'' in block' position:(source position1Based) to:(source position1Based).
1169
7204e72c7c3c better error message with bad parentNesting in a block.
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  4173
                ^ #Error.
7204e72c7c3c better error message with bad parentNesting in a block.
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  4174
            ].
7204e72c7c3c better error message with bad parentNesting in a block.
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  4175
7204e72c7c3c better error message with bad parentNesting in a block.
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  4176
            (tokenType == $) ) ifTrue:[
7204e72c7c3c better error message with bad parentNesting in a block.
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  4177
                eMsg := 'missing '']'' or bad '')'' in block'
673
0c66b7cb1d2f checkin from browser
ca
parents: 672
diff changeset
  4178
            ] ifFalse:[
1182
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4179
                eMsg := 'missing ''.'' between statements (i.e. ''' , tokenType printString , '''-token unexpected)'
673
0c66b7cb1d2f checkin from browser
ca
parents: 672
diff changeset
  4180
            ].
1169
7204e72c7c3c better error message with bad parentNesting in a block.
Claus Gittinger <cg@exept.de>
parents: 1168
diff changeset
  4181
            self syntaxError:eMsg position:tokenPosition to:tokenPosition.
673
0c66b7cb1d2f checkin from browser
ca
parents: 672
diff changeset
  4182
            ^ #Error
1182
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4183
        ].
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4184
        prevStatement := thisStatement.
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4185
        self nextToken.
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4186
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4187
        tokenType == $] ifTrue:[
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4188
            "
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4189
            *** I had a warning here (since it was not defined
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4190
            *** in the blue-book; but PD-code contains a lot of
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4191
            *** code with periods at the end so that the warnings
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4192
            *** became annoying
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4193
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4194
            self warning:'period after last statement in block'.
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4195
            "
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4196
            self markBracketAt:tokenPosition.
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4197
            ^ firstStatement
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4198
        ].
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4199
        thisStatement := self statement.
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4200
        (thisStatement == #Error) ifTrue:[^ #Error].
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4201
        prevStatement nextStatement:thisStatement
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4202
    ].
673
0c66b7cb1d2f checkin from browser
ca
parents: 672
diff changeset
  4203
    self markBracketAt:tokenPosition.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4204
    ^ firstStatement
743
3ced4791090c changes for cascades to super/here semantics.
Claus Gittinger <cg@exept.de>
parents: 739
diff changeset
  4205
3ced4791090c changes for cascades to super/here semantics.
Claus Gittinger <cg@exept.de>
parents: 739
diff changeset
  4206
    "Modified: / 16.7.1998 / 20:38:25 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4207
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4208
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4209
checkForEndOfInput
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  4210
    |what msg endPos|
1412
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  4211
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4212
    (tokenType ~~ #EOF) ifTrue:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4213
        "/ just for the nicer error message
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4214
        (#(Self Nil True False Super Here) includes:tokenType) ifTrue:[
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  4215
            msg := '"',tokenName allBold,'" unexpected (missing "." or ":" before ' , tokenName , ' ?)'. 
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  4216
            endPos := tokenPosition + tokenName size - 1.
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4217
        ] ifFalse:[
1412
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  4218
            tokenType isCharacter ifTrue:[
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  4219
                what := '"' , tokenType asString allBold, '"'.
1412
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  4220
            ] ifFalse:[
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  4221
                what := tokenType printString allBold.
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  4222
            ].
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  4223
            msg := what , ' unexpected. (missing ".", ":" or selector before it ?)'. 
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  4224
            endPos := source position1Based-1.
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  4225
        ].
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  4226
        self parseError:msg position:tokenPosition to:endPos.
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4227
        ^#Error
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4228
    ]
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  4229
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  4230
    "Modified: / 22-08-2006 / 14:22:45 / cg"
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4231
!
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4232
1222
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4233
checkReturnedValues
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4234
    | returnsSelf returnsBoolean returnsNonBooleanLiteral|
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4235
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4236
    ignoreWarnings ifTrue:[^ self].
1683
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4237
    parserFlags warnInconsistentReturnValues ifFalse:[^ self].
1222
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4238
    returnedValues isNil ifTrue:[^ self].
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4239
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4240
    returnsBoolean := returnedValues contains:[:node | node isConstant and:[node value isBoolean]].
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4241
    returnsNonBooleanLiteral := returnedValues contains:[:node | node isConstant and:[node value isBoolean not]].
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4242
    returnsSelf := returnedValues contains:[:node | node isSelf].
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4243
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4244
    returnsBoolean ifTrue:[
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4245
        (returnsNonBooleanLiteral or:[returnsSelf]) ifTrue:[
1455
25e4af227208 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1453
diff changeset
  4246
            self 
25e4af227208 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1453
diff changeset
  4247
                warning:'Possible Error Warning:\\Method returns both boolean and non-boolean values.' withCRs
1683
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4248
                doNotShowAgainAction:[ ParserFlags warnInconsistentReturnValues:false ]
1455
25e4af227208 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1453
diff changeset
  4249
                position:1 to:tokenPosition
1222
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4250
        ]
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4251
    ].
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4252
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4253
    "Created: / 17.11.2001 / 10:31:03 / cg"
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4254
    "Modified: / 17.11.2001 / 10:34:16 / cg"
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4255
!
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4256
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4257
checkUnusedMethodVars
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4258
    | unused|
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4259
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4260
    ignoreWarnings ifFalse:[
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4261
        methodVars notNil ifTrue:[
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4262
            unused := methodVars select:[:var| var used ~~ true] thenCollect:[:var| var name].
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4263
        ].
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4264
        unused size > 0 ifTrue:[
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4265
            self warnUnused:unused.
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4266
        ].
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4267
    ].
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4268
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4269
    "Created: / 17.11.2001 / 10:23:47 / cg"
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4270
!
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4271
1224
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4272
parseExceptionOrContextPragma
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4273
    |pragmaType|
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4274
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4275
    "/ < resource: has already been parsed.
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4276
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4277
    pragmaType := tokenName.
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4278
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4279
    self nextToken.
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4280
    (tokenType ~~ #Symbol) ifTrue:[
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4281
        self parseError:'symbol expected'.
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4282
        ^ #Error
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4283
    ].
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4284
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4285
    ((pragmaType = 'exception:'
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4286
        and:[tokenValue == #'handle'
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4287
             or:[tokenValue == #'raise'
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4288
             or:[tokenValue == #'unwind']]])
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4289
    or:[
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4290
        pragmaType = 'context:'
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4291
        and:[(tokenValue == #'return')]])
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4292
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4293
    ifTrue:[
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4294
        primitiveContextInfo isNil ifTrue:[
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4295
            primitiveContextInfo := Set new.
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4296
        ].
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4297
        primitiveContextInfo add:(pragmaType->tokenValue).
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4298
    ] ifFalse:[
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4299
        self parseError:'unrecognized exception pragma: ' , tokenValue.
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4300
    ].
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4301
    self nextToken.
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4302
!
b4d80bd993f9 parse ST/C api pragma (as dummy)
Claus Gittinger <cg@exept.de>
parents: 1222
diff changeset
  4303
1006
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4304
parseExpressionWithSelf:anObject notifying:someOne ignoreErrors:ignoreErrors ignoreWarnings:ignoreWarnings inNameSpace:aNameSpaceOrNil
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4305
    "parse aString as an expression with self set to anObject;
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4306
     Return the parseTree (if ok), nil (for an empty string 
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4307
     or comment only ) or #Error (syntactic error).
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4308
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4309
     Errors and warnings are forwarded to someOne (usually some
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4310
     codeView) which can highlight it and show a popup box,
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4311
     iff ignoreErrors/ignoreWarnings is true respectively."
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4312
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4313
    |tree token|
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4314
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4315
    aNameSpaceOrNil notNil ifTrue:[
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4316
        self currentNameSpace:aNameSpaceOrNil
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4317
    ].
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4318
    self setSelf:anObject.
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4319
    self notifying:someOne.
1365
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  4320
    self ignoreErrors:ignoreErrors.
19b74038d133 ignoreErrors / ignoreWarnings are not getters.
penk
parents: 1364
diff changeset
  4321
    self ignoreWarnings:ignoreWarnings.
1006
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4322
    token := self nextToken.
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4323
    (token == $^) ifTrue:[
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4324
        self nextToken.
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4325
    ].
1564
fa3538426964 empty expression -> nil handling
Claus Gittinger <cg@exept.de>
parents: 1562
diff changeset
  4326
    (token == #EOF) ifTrue:[
fa3538426964 empty expression -> nil handling
Claus Gittinger <cg@exept.de>
parents: 1562
diff changeset
  4327
        ^ nil
fa3538426964 empty expression -> nil handling
Claus Gittinger <cg@exept.de>
parents: 1562
diff changeset
  4328
    ].
1006
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4329
    tree := self expression.
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4330
    (self errorFlag or:[tree == #Error]) ifTrue:[^ #Error].
1182
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4331
"/    tokenType ~~ #EOF ifTrue:[
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4332
"/        self parseError:'nothing more expected' position:tokenPosition
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4333
"/    ].
1006
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4334
    ^ tree
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4335
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4336
    "Created: / 14.12.1999 / 15:11:37 / cg"
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4337
!
ffce16b01b0a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1003
diff changeset
  4338
1259
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4339
parseExtendedMethodSpec
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4340
    |pos1 pos2 var|
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4341
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4342
    "/ EXPERIMENTAL
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4343
false ifTrue:[
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4344
    (tokenType == #Symbol) ifTrue:[
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4345
        pos1 := tokenPosition.
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4346
        selector := token asSymbol.
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4347
        self nextToken.
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4348
        self markMethodSelectorFrom:pos1 to:(tokenPosition-1).
1581
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  4349
        beginOfBodyPosition := tokenPosition.
1259
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4350
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4351
        tokenType == $( ifTrue:[
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4352
            self nextToken.
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4353
            [ tokenType ~~ $) ] whileTrue:[
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4354
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4355
                (tokenType ~~ #Identifier) ifTrue:[^ #Error].
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4356
                pos2 := tokenPosition+tokenName size-1.
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4357
                self markArgumentIdentifierFrom:tokenPosition to:pos2.
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4358
                var := Variable name:tokenName.
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4359
                methodArgs isNil ifTrue:[
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4360
                    methodArgs := Array with:var.
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4361
                    methodArgNames := Array with:tokenName
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4362
                ] ifFalse:[
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4363
                    (methodArgNames includes:tokenName) ifTrue:[
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4364
                        self methodArgRedefined:tokenName from:tokenPosition to:pos2
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4365
                    ].
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4366
                    methodArgs := methodArgs copyWith:var.
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4367
                    methodArgNames := methodArgNames copyWith:tokenName
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4368
                ].
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4369
                self nextToken.
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4370
            ].
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4371
            self nextToken.
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4372
        ].
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4373
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4374
        ^ self
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4375
    ].
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4376
].
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4377
    ^ #Error
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4378
!
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4379
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4380
parseMethod
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4381
    "parse a method.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4382
     Return the parseTree or #Error.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4383
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4384
     method ::= methodSpec methodBody
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4385
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4386
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4387
    |parseTree|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4388
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  4389
"/    self nextToken.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4390
    (self parseMethodSpec == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4391
    parseTree := self parseMethodBody.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4392
    (parseTree == #Error) ifFalse:[
1171
0c43ce981f1b oops - remove unused vars does not work (yet)
Claus Gittinger <cg@exept.de>
parents: 1169
diff changeset
  4393
        self tree:parseTree
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4394
    ].
1186
014c3db76517 oops - end of input check should not be done when simply evaluating
Claus Gittinger <cg@exept.de>
parents: 1182
diff changeset
  4395
    self checkForEndOfInput.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4396
    ^ parseTree
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  4397
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  4398
    "Modified: 20.4.1996 / 20:09:26 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4399
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4400
1842
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4401
parseMethod:aString in:aClass ignoreErrors:ignoreErrors ignoreWarnings:ignoreWarnings
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4402
    "parse a method in a given class.
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4403
     Return a parser (if ok), nil (empty) or #Error (syntax).
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4404
     The parser can be queried for selector, receiver, args, locals,
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4405
     used selectors, modified instvars, referenced classvars etc.
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4406
     The noErrors and noWarnings arguments specify if error and warning 
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4407
     messages should be sent to the Transcript or suppressed."
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4408
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4409
    |parser tree|
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4410
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4411
    aString isNil ifTrue:[^ nil].
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4412
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4413
    self initializeFor:(ReadStream on:aString).
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4414
    self setClassToCompileFor:aClass.
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4415
    self ignoreErrors:ignoreErrors.
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4416
    self ignoreWarnings:ignoreWarnings.
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4417
    tree := self parseMethod.
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4418
    (self errorFlag or:[tree == #Error]) ifTrue:[^ nil].
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4419
    ^ tree
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4420
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4421
    "Created: / 21-08-2006 / 18:26:36 / cg"
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4422
!
dfc0639340e4 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1820
diff changeset
  4423
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4424
parseMethodBody
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4425
    "parse a methods body (locals & statements). 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4426
     No more tokens may follow.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4427
     Return a node-tree, or #Error
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4428
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4429
     methodBody ::= '<' st80Primitive '>' #EOF
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4430
                    | '<' st80Primitive '>' methodBodyVarSpec statementList #EOF
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4431
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4432
    "
1222
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4433
    |stats|
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4434
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4435
    stats := self parseMethodBodyOrEmpty.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4436
    (stats == #Error) ifFalse:[
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4437
        self checkForEndOfInput.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4438
    ].
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  4439
    ignoreWarnings ifFalse:[
1714
ba7113f4bce1 honor disabled warning flags
Claus Gittinger <cg@exept.de>
parents: 1710
diff changeset
  4440
        parserFlags warnings ifTrue:[
ba7113f4bce1 honor disabled warning flags
Claus Gittinger <cg@exept.de>
parents: 1710
diff changeset
  4441
            self checkUnusedMethodVars.
ba7113f4bce1 honor disabled warning flags
Claus Gittinger <cg@exept.de>
parents: 1710
diff changeset
  4442
            self checkReturnedValues.
ba7113f4bce1 honor disabled warning flags
Claus Gittinger <cg@exept.de>
parents: 1710
diff changeset
  4443
        ]
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  4444
    ].
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4445
    ^ stats
165
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
  4446
1222
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4447
    "Modified: / 17.11.2001 / 10:31:12 / cg"
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4448
!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4449
79
26f81a94a6ea *** empty log message ***
claus
parents: 78
diff changeset
  4450
parseMethodBodyOrEmpty
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4451
    "parse a methods body (locals & statements);
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4452
     return  a node-tree, nil or #Error. 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4453
     empty (or comment only) input is accepted and returns nil.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4454
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4455
     methodBodyOrNil ::= '<' st80Primitive '>'
1182
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4456
                         | '<' st80Primitive '>' methodBodyVarSpec statementList
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4457
                         | <empty>
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4458
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4459
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  4460
    |stats|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4461
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4462
    (self parseMethodBodyVarSpec == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4463
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4464
    (tokenType ~~ #EOF) ifTrue:[
1182
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4465
        stats := self statementList
34aac67e6e72 care for unexpected stuff at the end (in a doit)
Claus Gittinger <cg@exept.de>
parents: 1180
diff changeset
  4466
    ].
1186
014c3db76517 oops - end of input check should not be done when simply evaluating
Claus Gittinger <cg@exept.de>
parents: 1182
diff changeset
  4467
"/    (tokenType ~~ #EOF) ifTrue:[
014c3db76517 oops - end of input check should not be done when simply evaluating
Claus Gittinger <cg@exept.de>
parents: 1182
diff changeset
  4468
"/        self parseError:'nothing more expected here' position:tokenPosition to:tokenPosition.
014c3db76517 oops - end of input check should not be done when simply evaluating
Claus Gittinger <cg@exept.de>
parents: 1182
diff changeset
  4469
"/        ^ #Error
014c3db76517 oops - end of input check should not be done when simply evaluating
Claus Gittinger <cg@exept.de>
parents: 1182
diff changeset
  4470
"/    ].
1231
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  4471
    (stats notNil
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  4472
    and:[stats ~~ #Error]) ifTrue:[
1512
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  4473
        (self isStatementAnUnconditionalReturn:stats last) ifFalse:[
1231
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  4474
            "/ remember a returned self here.
1262
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  4475
            self rememberReturnedValue:(self selfNode)
1231
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  4476
        ].
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  4477
    ].
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  4478
    tree notNil ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  4479
        tree last nextStatement:stats.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  4480
        ^ tree.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  4481
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4482
    ^ stats
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  4483
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  4484
    "Modified: 27.4.1996 / 16:57:56 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4485
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4486
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4487
parseMethodBodyVarSpec
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  4488
    "parse a methods local variable specification, handling
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  4489
     possible primitive or resourceSpecs.
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  4490
     . 
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4491
     Leave spec of locals in methodLocals as a side effect.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4492
     Return #Error or nil.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4493
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4494
     methodBodyVarSpec ::= '|' { IDENTIFIER } '|'
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4495
                            | <empty>
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  4496
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4497
1597
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  4498
    |var pos pos2 msg classHint|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4499
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  4500
    ((tokenType == #BinaryOperator) and:[tokenName = '<']) ifTrue:[
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4501
        self parsePrimitiveOrResourceSpecOrEmpty.
265
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  4502
    ].
a8617dc49bbf examples
Claus Gittinger <cg@exept.de>
parents: 263
diff changeset
  4503
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4504
    (tokenType == $|) ifTrue:[
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4505
        "memorize position for declaration in correction"
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4506
1638
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4507
        localVarDefPosition := Array with:tokenPosition with:nil.
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4508
        self nextToken.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4509
        pos := tokenPosition.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4510
        [tokenType == #Identifier] whileTrue:[
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4511
            pos2 := tokenPosition + tokenName size - 1.
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4512
            self markLocalIdentifierFrom:tokenPosition to:pos2.
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  4513
            self checkMethodVariableNameConventionsFor:tokenName.
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4514
            var := Variable name:tokenName.
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4515
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4516
            methodVars isNil ifTrue:[
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4517
                methodVars := OrderedCollection with:var.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4518
                methodVarNames := OrderedCollection with:tokenName
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4519
            ] ifFalse:[
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4520
                (methodVarNames includes:tokenName) ifTrue:[
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4521
                    "/ redefinition
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4522
                    self isSyntaxHighlighter ifTrue:[
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4523
                        self markBadIdentifierFrom:tokenPosition to:pos2.
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4524
                    ] ifFalse:[
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4525
                        self 
1638
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4526
                            parseError:'redefinition of ''' , tokenName , ''' in local variables.'
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4527
                            position:tokenPosition to:pos2.
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4528
                    ]
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4529
                ] ifFalse:[
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4530
                    methodVars add:var.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4531
                    methodVarNames add:tokenName
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4532
                ]
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4533
            ].
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4534
1638
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4535
            parserFlags warnHiddenVariables ifTrue:[
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4536
                methodArgNames notNil ifTrue:[
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4537
                    (methodArgNames includes:tokenName) ifTrue:[
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4538
                        self 
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4539
                            warning:'local variable "' , tokenName allBold , '" hides method argument.'
1683
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4540
                            doNotShowAgainAction:[ ParserFlags warnHiddenVariables:false ]
1638
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4541
                            position:tokenPosition to:pos2
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4542
                    ]
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4543
                ].
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4544
                classToCompileFor notNil ifTrue:[
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4545
                    (self classesInstVarNames includes:tokenName) ifTrue:[
1675
7812281ecfbd some errors are really warnings.
Claus Gittinger <cg@exept.de>
parents: 1664
diff changeset
  4546
                        classToCompileFor isMeta ifTrue:[
7812281ecfbd some errors are really warnings.
Claus Gittinger <cg@exept.de>
parents: 1664
diff changeset
  4547
                            self 
7812281ecfbd some errors are really warnings.
Claus Gittinger <cg@exept.de>
parents: 1664
diff changeset
  4548
                                warning:'local variable "' , tokenName allBold , '" hides class instance variable.'
1683
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4549
                                doNotShowAgainAction:[ ParserFlags warnHiddenVariables:false ]
1675
7812281ecfbd some errors are really warnings.
Claus Gittinger <cg@exept.de>
parents: 1664
diff changeset
  4550
                                position:tokenPosition to:pos2
7812281ecfbd some errors are really warnings.
Claus Gittinger <cg@exept.de>
parents: 1664
diff changeset
  4551
                        ] ifFalse:[
7812281ecfbd some errors are really warnings.
Claus Gittinger <cg@exept.de>
parents: 1664
diff changeset
  4552
                            self 
7812281ecfbd some errors are really warnings.
Claus Gittinger <cg@exept.de>
parents: 1664
diff changeset
  4553
                                warning:'local variable "' , tokenName allBold , '" hides instance variable.'
1683
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4554
                                doNotShowAgainAction:[ ParserFlags warnHiddenVariables:false ]
1675
7812281ecfbd some errors are really warnings.
Claus Gittinger <cg@exept.de>
parents: 1664
diff changeset
  4555
                                position:tokenPosition to:pos2
7812281ecfbd some errors are really warnings.
Claus Gittinger <cg@exept.de>
parents: 1664
diff changeset
  4556
                        ]
1638
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4557
                    ]
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4558
                ].
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4559
            ].
1638
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4560
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4561
            self nextToken.
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4562
1597
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  4563
            classHint := nil.
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  4564
            lastDirective notNil ifTrue:[
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  4565
                lastDirective isClassHintDirective ifTrue:[
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  4566
                    var classHint:lastDirective className.
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  4567
                ].
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  4568
                lastDirective := nil.
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  4569
            ].
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  4570
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  4571
            parserFlags allowLocalVariableDeclarationWithInitializerExpression == true ifTrue:[
1471
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4572
                ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4573
                    self nextToken.
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4574
                    "/ Q: should we allow literals only, or arbitrary expressions ?
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4575
                    self halt:'unimplemented feature'.
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4576
                ]
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4577
            ].
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  4578
            parserFlags allowDomainVariables == true ifTrue:[
1471
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4579
                (tokenType == $() ifTrue:[
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4580
                    self variableTypeDeclarationFor:var.
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4581
                ].
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4582
            ].
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4583
            pos := tokenPosition
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4584
        ].
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4585
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4586
        (tokenType ~~ $|) ifTrue:[
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4587
            (#(True False Self Nil Super ThisContext) includes:tokenType) ifTrue:[
1638
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4588
                msg := 'reserved keyword "',tokenName allBold,'" in local var declaration'. 
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4589
                pos2 := tokenPosition + tokenName size - 1.
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4590
                self markBadIdentifierFrom:tokenPosition to:pos2.
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4591
            ] ifFalse:[
1371
de4c37ac12fc code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 1369
diff changeset
  4592
                pos2 := source position1Based-1.
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4593
                msg := 'Identifier or | expected in local var declaration' 
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4594
            ].
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4595
            self syntaxError:msg position:tokenPosition to:pos2.
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4596
            ^ #Error
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4597
        ].
1638
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4598
        localVarDefPosition at:2 put:tokenPosition.
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4599
        self nextToken
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4600
    ].
984
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4601
1690
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  4602
    (parserFlags allowSqueakPrimitives
1744
b5241887a350 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1741
diff changeset
  4603
    or:[ parserFlags allowSqueakExtensions
1710
78346eeddbec ST/V parsing support
Claus Gittinger <cg@exept.de>
parents: 1696
diff changeset
  4604
    or:[ parserFlags allowVisualAgePrimitives
1744
b5241887a350 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1741
diff changeset
  4605
    or:[ parserFlags allowSTVPrimitives ]]]) ifTrue:[
984
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4606
        "/ allow for primitiveSpec after local-var decl.
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4607
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4608
        ((tokenType == #BinaryOperator) and:[tokenName = '<']) ifTrue:[
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4609
            self parsePrimitiveOrResourceSpecOrEmpty.
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4610
        ]
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4611
    ].
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4612
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4613
    ^ nil
139
65eaf1a009f5 warn if method local hides method arg
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  4614
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4615
    "Modified: / 31.3.1998 / 17:30:33 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4616
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  4617
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4618
parseMethodSpec
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4619
    "parse a methods selector & arg specification;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4620
     Set selector and methodArgs in the receiver as a side effect.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4621
     Return the receiver or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4622
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4623
     methodSpec ::= { KEYWORD IDENTIFIER }
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4624
                    | binaryOperator IDENTIFIER
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4625
                    | IDENTIFIER
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4626
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4627
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4628
    |arg pos2|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4629
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  4630
    tokenType isNil ifTrue:[
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4631
        self nextToken.
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  4632
    ].
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  4633
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4634
    (tokenType == #Keyword) ifTrue:[
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4635
        selector := ''.
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4636
        [tokenType == #Keyword] whileTrue:[
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4637
            self markMethodSelectorFrom:tokenPosition to:(tokenPosition+tokenName size-1).
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4638
            selector := selector , tokenName.
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4639
            self nextToken.
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4640
1259
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4641
            (tokenType ~~ #Identifier) ifTrue:[
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4642
                "/ ^ #Error].
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4643
                ^ self identifierExpectedIn:'method-arg declaration'
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4644
            ].
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4645
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4646
            pos2 := tokenPosition+tokenName size-1.
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  4647
            self markArgumentIdentifierFrom:tokenPosition to:pos2.
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  4648
            self checkMethodArgumentNameConventionsFor:tokenName.
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4649
            arg := Variable name:tokenName.
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4650
            methodArgs isNil ifTrue:[
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4651
                methodArgs := Array with:arg.
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4652
                methodArgNames := Array with:tokenName
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4653
            ] ifFalse:[
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4654
                (methodArgNames includes:tokenName) ifTrue:[
1259
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4655
                    self methodArgRedefined:tokenName from:tokenPosition to:pos2
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4656
                ].
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4657
                methodArgs := methodArgs copyWith:arg.
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4658
                methodArgNames := methodArgNames copyWith:tokenName
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4659
            ].
1638
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4660
            parserFlags warnHiddenVariables ifTrue:[
1776
65df22979f49 plausibilityCheck of unary expression fixed
Claus Gittinger <cg@exept.de>
parents: 1774
diff changeset
  4661
                classToCompileFor isClass ifTrue:[
1638
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4662
                    (self classesInstVarNames includes:tokenName) ifTrue:[
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4663
                        self 
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4664
                            warning:'argument "' , tokenName allBold , '" hides instance variable.'
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4665
                            position:tokenPosition to:pos2
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4666
                    ]
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4667
                ].
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  4668
            ].
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4669
            self nextToken.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4670
"/            ((tokenType == #BinaryOperator) and:[token = '#']) ifTrue:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4671
"/                self nextToken.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4672
"/                arg domain:nil.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4673
"/            ].
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4674
        ].
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4675
        selector := selector asSymbol.
1581
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  4676
        endOfSelectorPosition := pos2.
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  4677
        beginOfBodyPosition := tokenPosition.
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4678
        ^ self
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4679
    ].
1306
90f45715a0d7 optionally allow nil, true, false etc. as unary selector
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  4680
90f45715a0d7 optionally allow nil, true, false etc. as unary selector
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  4681
    (self isValidUnarySelector:tokenType) ifTrue:[
1581
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  4682
        pos2 := tokenPosition+tokenName size-1.
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  4683
        self markMethodSelectorFrom:tokenPosition to:pos2.
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4684
        selector := tokenName asSymbol.
1581
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  4685
        endOfSelectorPosition := pos2.
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4686
        self nextToken.
1581
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  4687
        beginOfBodyPosition := tokenPosition.
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4688
        ^ self
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4689
    ].
1306
90f45715a0d7 optionally allow nil, true, false etc. as unary selector
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  4690
461
1d24cc165fac oops - did not allow | as method-selector
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
  4691
    "/ 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
  4692
    tokenType == $| ifTrue:[
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4693
        tokenType := #BinaryOperator.
1103
b75a71996388 ensure that token follows tomeName & tokenValue
Claus Gittinger <cg@exept.de>
parents: 1100
diff changeset
  4694
        token := tokenName := '|'
461
1d24cc165fac oops - did not allow | as method-selector
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
  4695
    ].
1d24cc165fac oops - did not allow | as method-selector
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
  4696
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4697
    (tokenType == #BinaryOperator) ifTrue:[
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  4698
        self markMethodSelectorFrom:tokenPosition to:(tokenPosition+tokenName size-1).
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4699
        selector := tokenName asSymbol.
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4700
        self nextToken.
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4701
        (tokenType ~~ #Identifier) ifTrue:[^ #Error].
1581
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  4702
        pos2 := tokenPosition+tokenName size-1.
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  4703
        self markArgumentIdentifierFrom:tokenPosition to:pos2.
1519
2bf586494492 for christian
Claus Gittinger <cg@exept.de>
parents: 1518
diff changeset
  4704
        self checkMethodArgumentNameConventionsFor:tokenName.
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4705
        arg := Variable name:tokenName.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4706
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4707
        methodArgs := Array with:arg.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4708
        methodArgNames := Array with:tokenName.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4709
1581
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  4710
        endOfSelectorPosition := pos2.
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4711
        self nextToken.
1581
a2a4645fe3b8 keep endOfSelectorSpec and begonOfBody separate
Claus Gittinger <cg@exept.de>
parents: 1579
diff changeset
  4712
        beginOfBodyPosition := tokenPosition.
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4713
"/            ((tokenType == #BinaryOperator) and:[token = '#']) ifTrue:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4714
"/                self nextToken.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4715
"/                arg domain:nil.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4716
"/            ].
660
f68ddffc6921 support for syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
  4717
        ^ self
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4718
    ].
461
1d24cc165fac oops - did not allow | as method-selector
Claus Gittinger <cg@exept.de>
parents: 457
diff changeset
  4719
1259
c3d7847b92c1 error handling refactored
Claus Gittinger <cg@exept.de>
parents: 1257
diff changeset
  4720
    ^ self parseExtendedMethodSpec
255
13a059f6569d no need to send nextToken when parsing a method
Claus Gittinger <cg@exept.de>
parents: 229
diff changeset
  4721
1776
65df22979f49 plausibilityCheck of unary expression fixed
Claus Gittinger <cg@exept.de>
parents: 1774
diff changeset
  4722
    "Modified: / 17-07-2006 / 00:44:26 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4723
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  4724
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4725
statement
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4726
    "parse a statement; return a node-tree or #Error.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4727
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4728
     statement ::= '^' expression
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4729
                   | PRIMITIVECODE
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4730
                   | expression
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4731
    "
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4732
1276
f7f6e0c1aff9 code could be wrong in a primitive node
Claus Gittinger <cg@exept.de>
parents: 1275
diff changeset
  4733
    |expr node lnr code|
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4734
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4735
    (tokenType == $^) ifTrue:[
837
b09e08bb3d5e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 832
diff changeset
  4736
        self markReturnAt:tokenPosition.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4737
        lnr := tokenLineNr.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4738
        self nextToken.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4739
        expr := self expression.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4740
        (expr == #Error) ifTrue:[^ #Error].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4741
        node := ReturnNode expression:expr.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4742
        node home:self blockHome:currentBlock.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4743
        (lineNumberInfo == #full) ifTrue:[node lineNumber:lnr].
1222
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4744
1231
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  4745
        self rememberReturnedValue:expr.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4746
        ^ node
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4747
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4748
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4749
    (tokenType == #Primitive) ifTrue:[
1276
f7f6e0c1aff9 code could be wrong in a primitive node
Claus Gittinger <cg@exept.de>
parents: 1275
diff changeset
  4750
        code := tokenValue.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4751
        self nextToken.
1276
f7f6e0c1aff9 code could be wrong in a primitive node
Claus Gittinger <cg@exept.de>
parents: 1275
diff changeset
  4752
        node := PrimitiveNode code:code.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4753
        node isOptional ifFalse:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4754
            hasNonOptionalPrimitiveCode := true
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4755
        ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4756
        hasPrimitiveCode := true.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4757
        ^ node
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4758
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4759
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4760
    (tokenType == #EOF) ifTrue:[
733
6859b56d5bd2 better error message for missing ']' at end of block.
Claus Gittinger <cg@exept.de>
parents: 732
diff changeset
  4761
        currentBlock notNil ifTrue:[
6859b56d5bd2 better error message for missing ']' at end of block.
Claus Gittinger <cg@exept.de>
parents: 732
diff changeset
  4762
            self syntaxError:'missing '']'' at end of block'.
6859b56d5bd2 better error message for missing ']' at end of block.
Claus Gittinger <cg@exept.de>
parents: 732
diff changeset
  4763
        ] ifFalse:[
6859b56d5bd2 better error message for missing ']' at end of block.
Claus Gittinger <cg@exept.de>
parents: 732
diff changeset
  4764
            self syntaxError:'period after last statement'.
6859b56d5bd2 better error message for missing ']' at end of block.
Claus Gittinger <cg@exept.de>
parents: 732
diff changeset
  4765
        ].
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4766
        ^ #Error
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4767
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4768
984
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4769
    (tokenType == $.) ifTrue:[
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  4770
        parserFlags allowSqueakExtensions == true ifTrue:[
984
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4771
            "/ allow empty statement
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4772
            ^ StatementNode expression:nil.
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4773
        ].
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4774
    ].
0994fa625709 more squeak-parsing
Claus Gittinger <cg@exept.de>
parents: 977
diff changeset
  4775
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4776
    expr := self expression.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4777
    (expr == #Error) ifTrue:[^ #Error].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4778
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4779
"/    classToCompileFor notNil ifTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4780
"/        currentBlock isNil ifTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4781
"/            expr isPrimary ifTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4782
"/                self warning:'useless computation - missing ^ ?'
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4783
"/            ]
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4784
"/        ]
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4785
"/    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4786
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4787
    node := StatementNode expression:expr.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4788
    (lineNumberInfo == #full) ifTrue:[node lineNumber:lnr].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4789
    ^ node
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4790
1222
f3f602267070 check if returning both boolean / non-boolean
Claus Gittinger <cg@exept.de>
parents: 1221
diff changeset
  4791
    "Modified: / 17.11.2001 / 10:22:33 / cg"
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4792
!
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4793
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4794
statementList
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4795
    "parse a statementlist; return a node-tree, nil or #Error.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4796
     Statements must be separated by periods.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4797
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4798
     statementList ::= <statement>
988
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4799
                       | <statementList> . <statement>
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4800
    "
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4801
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4802
    |thisStatement prevStatement firstStatement correctIt periodPos
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4803
     prevExpr|
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4804
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4805
    thisStatement := self statement.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4806
    (thisStatement == #Error) ifTrue:[^ #Error].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4807
    firstStatement := thisStatement.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4808
    [tokenType == $.] whileTrue:[
988
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4809
        prevExpr := thisStatement expression.
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4810
        (prevExpr notNil 
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4811
        and:[prevExpr isMessage
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4812
        and:[thisStatement isReturnNode not]]) ifTrue:[
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4813
            (#(#'=' #'==') includes:prevExpr selector) ifTrue:[
1487
c3af432fdd7c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1482
diff changeset
  4814
                self warning:'useless computation - mistyped assignment (i.e. did you mean '':='') ?' position:prevExpr selectorPosition
988
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4815
            ].
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4816
        ].
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4817
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4818
        periodPos := tokenPosition.
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4819
        self nextToken.
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4820
        (tokenType == $]) ifTrue:[
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4821
            currentBlock isNil ifTrue:[
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4822
                self parseError:'block nesting error'.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4823
"
988
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4824
            *** I had a warning here (since it was not defined
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4825
            *** in the blue-book; but PD-code contains a lot of
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4826
            *** code with periods at the end so that the warnings
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4827
            *** became annoying
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4828
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4829
            ] ifFalse:[
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4830
                self warning:'period after last statement' position:periodPos
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4831
"
988
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4832
            ].
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4833
            ^ firstStatement
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4834
        ].
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4835
        (tokenType == #EOF) ifTrue:[
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4836
            currentBlock notNil ifTrue:[
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4837
                self parseError:'block nesting error (expected '']'')'.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4838
"
988
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4839
            *** I had a warning here (since it was not defined
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4840
            *** in the blue-book; but PD-code contains a lot of
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4841
            *** code with periods at the end so that the warnings
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4842
            *** became annoying
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4843
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4844
            ] ifFalse:[
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4845
                self warning:'period after last statement' position:periodPos
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4846
"
988
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4847
            ].
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4848
            ^ firstStatement
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4849
        ].
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4850
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4851
        prevStatement := thisStatement.
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4852
        prevStatement isReturnNode ifTrue:[
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4853
            self warning:'statements after return' position:tokenPosition
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4854
        ].
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4855
"
988
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4856
        periodPos := tokenPosition.
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4857
        self nextToken.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4858
"
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4859
988
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4860
        ((tokenType == $]) or:[tokenType == #EOF]) ifTrue:[
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4861
            (currentBlock isNil and:[tokenType == $]]) ifTrue:[
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4862
                self parseError:'block nesting error'.
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4863
            ] ifFalse:[
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4864
                correctIt := self correctableError:'period after last statement in block'
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4865
                                          position:periodPos to:(periodPos + 1).
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4866
                correctIt ifTrue:[
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4867
                    (self correctByDeleting == #Error) ifTrue:[
1564
fa3538426964 empty expression -> nil handling
Claus Gittinger <cg@exept.de>
parents: 1562
diff changeset
  4868
                        self errorFlag:true
988
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4869
                    ]
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4870
                ]
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4871
            ].
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4872
            ^ firstStatement
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4873
        ].
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4874
        thisStatement := self statement.
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4875
        (thisStatement == #Error) ifTrue:[^ #Error].
5b38d970fb1a checkin from browser
Claus Gittinger <cg@exept.de>
parents: 984
diff changeset
  4876
        prevStatement nextStatement:thisStatement
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4877
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4878
    ^ firstStatement
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4879
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4880
    "Modified: 14.4.1997 / 20:46:46 / cg"
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4881
!
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4882
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4883
variableTypeDeclarationFor:aVariable
1471
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4884
    "experimental support for Domain variables (constraint programming support):
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4885
     a variable-declaration of the form
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4886
        |var (domain) ... |
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4887
     declares var as a domainVariable.
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4888
     Valid domains are:
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4889
        min %% max      - integer range domain
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4890
        Bool            - boolean domain
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4891
        Nat             - positive integer domain
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4892
        Int             - integer domain
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4893
        #sym1 ... #sym2 - enumerated symbolic domain
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4894
    "
8752bd8a5581 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1468
diff changeset
  4895
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4896
    |min max domain enumValues|
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4897
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4898
    (tokenType == $() ifFalse:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4899
        self syntaxError:'''('' expected' position:tokenPosition.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4900
        ^ #Error
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4901
    ].    
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4902
    self nextToken.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4903
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4904
    (tokenType == #Integer) ifTrue:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4905
        min := token.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4906
        self nextToken.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4907
        ((tokenType == #BinaryOperator) and:[token = '%%']) ifFalse:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4908
            self syntaxError:'''%%'' expected' position:tokenPosition.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4909
        ].
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4910
        self nextToken.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4911
        (tokenType == #Integer) ifFalse:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4912
            self syntaxError:'Integer (upper bound) expected' position:tokenPosition.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4913
        ].
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4914
        max := token.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4915
        self nextToken.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4916
        domain := IntegerDomain min:min max:max.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4917
    ] ifFalse:[
1696
4b0db823d6a2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1692
diff changeset
  4918
        ((tokenType == #Identifier) and:[token isUppercaseFirst]) ifTrue:[
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4919
            token = 'Bool' ifTrue:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4920
                self nextToken.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4921
                domain := BooleanDomain new.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4922
            ].
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4923
            token = 'Nat' ifTrue:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4924
                self nextToken.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4925
                domain := IntegerDomain min:0 max:(SmallInteger maxVal).
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4926
            ].
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4927
            token = 'Int' ifTrue:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4928
                self nextToken.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4929
                domain := IntegerDomain min:(SmallInteger minVal) max:(SmallInteger maxVal).
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4930
            ].
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4931
        ] ifFalse:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4932
            ((tokenType == #Symbol) or:[(tokenType == #Identifier)]) ifTrue:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4933
                enumValues := OrderedCollection new.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4934
                [((tokenType == #Symbol) or:[(tokenType == #Identifier)])] whileTrue:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4935
                    enumValues add:token.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4936
                    self nextToken.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4937
                ].
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4938
                domain := EnumeratedDomain new values:enumValues.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4939
            ].
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4940
        ].
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4941
    ].
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4942
    domain isNil ifTrue:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4943
        self syntaxError:'invalid domain' position:tokenPosition.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4944
    ].
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4945
    aVariable domain:domain.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4946
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4947
    (tokenType == $)) ifFalse:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4948
        self syntaxError:''')'' expected' position:tokenPosition.
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4949
        ^ #Error
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4950
    ].    
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  4951
    self nextToken.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4952
! !
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4953
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4954
!Parser methodsFor:'parsing-expressions'!
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4955
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4956
array
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4957
    |arr elements elem pos1|
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4958
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4959
    pos1 := tokenPosition.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4960
    elements := OrderedCollection new:20.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4961
    [tokenType ~~ $) ] whileTrue:[
1165
09d40e1ff75d oops - invalid literal array const was not signalling an error
Claus Gittinger <cg@exept.de>
parents: 1164
diff changeset
  4962
        elem := self arrayConstant.
09d40e1ff75d oops - invalid literal array const was not signalling an error
Claus Gittinger <cg@exept.de>
parents: 1164
diff changeset
  4963
1062
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
  4964
"/        (elem == #Error) ifTrue:[
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
  4965
"/            (tokenType == #EOF) ifTrue:[
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
  4966
"/                self syntaxError:'unterminated array-constant; '')'' expected' 
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
  4967
"/                        position:pos1 to:tokenPosition
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
  4968
"/            ].
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
  4969
"/            ^ #Error
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
  4970
"/        ].
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4971
        elem isSymbol ifTrue:[
1371
de4c37ac12fc code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 1369
diff changeset
  4972
            self markSymbolFrom:tokenPosition to:(source position1Based-1).
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4973
        ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4974
        elements add:elem.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4975
        self nextToken
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4976
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4977
    arr := Array withAll:elements.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4978
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  4979
    parserFlags arraysAreImmutable ifTrue:[
1615
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  4980
        ^ self makeImmutableArray:arr
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4981
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4982
    ^ arr
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4983
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4984
    "Modified: / 14.4.1998 / 17:03:29 / cg"
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4985
!
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4986
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4987
arrayConstant
1042
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  4988
    |val|
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  4989
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  4990
    (tokenType == #Nil) ifTrue:[
1683
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4991
        self warnPossibleIncompatibility:'nil in array constant is interpreted as #nil (symbol) in other smalltalks' position:tokenPosition to:tokenPosition+token size - 1.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4992
        ^ tokenValue
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4993
    ].
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4994
    (tokenType == #True) ifTrue:[
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4995
        self warnPossibleIncompatibility:'true in array constant is interpreted as #true (symbol) in other smalltalks' position:tokenPosition to:tokenPosition+token size - 1.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4996
        ^ tokenValue
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4997
    ].
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4998
    (tokenType == #False) ifTrue:[
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  4999
        self warnPossibleIncompatibility:'false in array constant is interpreted as #false (symbol) in other smalltalks' position:tokenPosition to:tokenPosition+token size - 1.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  5000
        ^ tokenValue
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5001
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5002
    ((tokenType == #Integer) 
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5003
    or:[tokenType == #Float]) ifTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5004
        ^ tokenValue
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5005
    ].
1615
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  5006
    (tokenType == #String) ifTrue:[
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5007
        parserFlags stringsAreImmutable ifTrue:[^ self makeImmutableString:tokenValue].
1615
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  5008
        ^ tokenValue
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  5009
    ].
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  5010
    (tokenType == #Character) ifTrue:[
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5011
        ^ tokenValue
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5012
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5013
    (tokenType == #Error) ifTrue:[
1062
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
  5014
        ^ ParseErrorSignal raise.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5015
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5016
    (tokenType == #BinaryOperator) ifTrue:[
1604
841e69c7bdaf usedSymbols: also remember symbols in literal arrays
Claus Gittinger <cg@exept.de>
parents: 1601
diff changeset
  5017
        val := tokenName asSymbol.
841e69c7bdaf usedSymbols: also remember symbols in literal arrays
Claus Gittinger <cg@exept.de>
parents: 1601
diff changeset
  5018
        parseForCode ifFalse:[
841e69c7bdaf usedSymbols: also remember symbols in literal arrays
Claus Gittinger <cg@exept.de>
parents: 1601
diff changeset
  5019
            self rememberSymbolUsed:val.
841e69c7bdaf usedSymbols: also remember symbols in literal arrays
Claus Gittinger <cg@exept.de>
parents: 1601
diff changeset
  5020
        ].
841e69c7bdaf usedSymbols: also remember symbols in literal arrays
Claus Gittinger <cg@exept.de>
parents: 1601
diff changeset
  5021
        ^ val
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5022
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5023
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5024
    "/ some more special symbol consts ...
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5025
    (tokenType == $| ) ifTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5026
        ^ #| 
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5027
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5028
    (tokenType == #Self ) ifTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5029
        ^ #'self' 
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5030
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5031
    (tokenType == #Super ) ifTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5032
        ^ #'super' 
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5033
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5034
    (tokenType == #Here ) ifTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5035
        ^ #'here' 
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5036
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5037
    (tokenType == #ThisContext ) ifTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5038
        ^ #'thisContext' 
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5039
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5040
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5041
    ((tokenType == #Keyword) 
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5042
    or:[tokenType == #Identifier]) ifTrue:[
1604
841e69c7bdaf usedSymbols: also remember symbols in literal arrays
Claus Gittinger <cg@exept.de>
parents: 1601
diff changeset
  5043
        val := tokenName asSymbol.
841e69c7bdaf usedSymbols: also remember symbols in literal arrays
Claus Gittinger <cg@exept.de>
parents: 1601
diff changeset
  5044
        parseForCode ifFalse:[
841e69c7bdaf usedSymbols: also remember symbols in literal arrays
Claus Gittinger <cg@exept.de>
parents: 1601
diff changeset
  5045
            self rememberSymbolUsed:val.
841e69c7bdaf usedSymbols: also remember symbols in literal arrays
Claus Gittinger <cg@exept.de>
parents: 1601
diff changeset
  5046
        ].
841e69c7bdaf usedSymbols: also remember symbols in literal arrays
Claus Gittinger <cg@exept.de>
parents: 1601
diff changeset
  5047
        ^ val
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5048
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5049
    ((tokenType == $()
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5050
    or:[tokenType == #HashLeftParen]) ifTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5051
        self nextToken.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5052
        ^ self array
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5053
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5054
    ((tokenType == $[) 
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5055
    or:[tokenType == #HashLeftBrack]) ifTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5056
        self nextToken.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5057
        ^ self byteArray
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5058
    ].
1042
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  5059
    (tokenType == #HashLeftBrace) ifTrue:[
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  5060
        val := self qualifiedName.
1716
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  5061
        "/ val := QualifiedName for:val name.
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  5062
        val := val value.
1042
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  5063
        ^ val
1683
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  5064
    ].                         
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5065
    (tokenType == #Symbol) ifTrue:[
1066
ba626f00f709 remember symbols used in arrayConstant
Claus Gittinger <cg@exept.de>
parents: 1065
diff changeset
  5066
        parseForCode ifFalse:[
ba626f00f709 remember symbols used in arrayConstant
Claus Gittinger <cg@exept.de>
parents: 1065
diff changeset
  5067
            self rememberSymbolUsed:tokenValue.
ba626f00f709 remember symbols used in arrayConstant
Claus Gittinger <cg@exept.de>
parents: 1065
diff changeset
  5068
        ].
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5069
        ^ tokenValue
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5070
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5071
    (tokenType == #EOF) ifTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5072
        "just for the better error-hilight; let caller handle error"
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5073
        self syntaxError:'EOF unexpected in array-constant'. 
1062
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
  5074
        ^ ParseErrorSignal raise.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5075
    ].
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5076
    self syntaxError:('"' 
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5077
                      , tokenType printString 
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5078
                      , '" unexpected in array-constant').
1062
119b394e10b5 parse bug: #(#Error)
Claus Gittinger <cg@exept.de>
parents: 1061
diff changeset
  5079
    ^ ParseErrorSignal raise.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5080
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5081
    "Modified: / 22-08-2006 / 14:21:16 / cg"
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5082
!
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5083
1405
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5084
arrayIndexingExpression
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5085
    "parse an array index expression; this is a squeak/stx extension.
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5086
     foo[idx] is syntactic sugar for foo matrixAt:x
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5087
     and foo[idx] := expr is syntactic sugar for foo matrixAt:x put:expr"
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5088
1412
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5089
    |receiver argList selectorStream valNode|
1405
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5090
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5091
    receiver := self functionCallExpression.
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5092
    tokenType == $[ ifFalse:[^ receiver].
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5093
    parserFlags allowArrayIndexSyntaxExtension == true ifFalse:[^ receiver.].
1405
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5094
    (receiver == #Error) ifTrue:[^ #Error].
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5095
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5096
    selectorStream := WriteStream on: (String new: 32).
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5097
    argList := OrderedCollection new.
1412
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5098
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5099
    [
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5100
        [      
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5101
            |indexNode|
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5102
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5103
            self nextToken.
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5104
            indexNode := self primary.
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5105
            argList isEmpty ifTrue:[selectorStream nextPutAll:'_'].
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5106
            selectorStream nextPutAll:'at:'.
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5107
            argList add: indexNode.
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5108
            (tokenType == #BinaryOperator ) and:[ token = ',']  
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5109
        ] whileTrue.
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5110
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5111
        tokenType == $] ifFalse:[ 
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5112
            self parseError:''']'' expected'.
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5113
            ^ #Error
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5114
        ].
1405
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5115
        self nextToken.
1412
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5116
        
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5117
        tokenType == $[ ifTrue:[
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5118
            receiver := MessageNode 
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5119
                    receiver:receiver 
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5120
                    selector:(selectorStream contents)
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5121
                    args:argList.
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5122
            selectorStream := WriteStream on: (String new: 32).
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5123
        ].
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5124
        tokenType == $[ 
1405
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5125
    ] whileTrue.
1411
c71cf8b2be10 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1410
diff changeset
  5126
1405
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5127
    tokenType == #':=' ifTrue:[
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5128
        self nextToken.
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5129
        selectorStream nextPutAll:'put:'.
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5130
        valNode := self expression.
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5131
        valNode == #Error ifTrue:[
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5132
            ^ valNode
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5133
        ].
1412
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5134
"/ this was found in squeak - why make it a block ?
1405
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5135
"/        (valNode isKindOf: BlockNode) ifFalse:[
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5136
"/                valNode _ BlockNode new
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5137
"/                                        arguments: #()
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5138
"/                                        statements: (OrderedCollection with: valNode)
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5139
"/                                        returns: false
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5140
"/                                        from: encoder.
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5141
"/        ].
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5142
        argList add: valNode
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5143
    ].
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5144
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5145
    ^ MessageNode 
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5146
            receiver:receiver 
1412
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5147
            selector:selectorStream contents
1405
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5148
            args:argList.
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5149
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5150
    "
1412
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5151
     AllowArrayIndexSyntaxExtension := true.
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5152
     AllowArrayIndexSyntaxExtension := false.
1405
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5153
    "
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5154
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5155
    "
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5156
     |foo|
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5157
1412
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5158
     foo := Array new:10 withAll:2.
1405
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5159
     1 + foo[1].     
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5160
    "
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5161
    "
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5162
     |foo|
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5163
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5164
     foo := Array new:10.
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5165
     foo[1] := 'hello'.     
1412
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5166
     foo[2].     
af3ec9f24a38 array indexing extension (experimental)
Claus Gittinger <cg@exept.de>
parents: 1411
diff changeset
  5167
     foo[1].     
1405
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5168
    "
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5169
!
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  5170
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5171
binaryExpression
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5172
    "parse a binary-expression; return a node-tree, nil or #Error"
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5173
1328
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5174
    |receiver|
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5175
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5176
    receiver := self unaryExpression.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5177
    (receiver == #Error) ifTrue:[^ #Error].
1328
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5178
    ^ self binaryExpressionFor:receiver
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5179
!
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5180
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5181
binaryExpressionFor:receiverArg
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5182
    "parse a binary-expression; return a node-tree, nil or #Error"
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5183
1547
485ee78fce9d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1546
diff changeset
  5184
    |receiver expr arg sel pos1 pos2 lno note|
1328
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5185
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5186
    receiver := receiverArg.
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5187
    (receiver == #Error) ifTrue:[^ #Error].
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5188
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5189
    "special kludge: since Scanner cannot know if -digit is a binary
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5190
     expression or a negative constant, handle cases here"
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5191
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5192
    [(tokenType == #BinaryOperator) 
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5193
     or:[(tokenType == $|)
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5194
         or:[((tokenType == #Integer) or:[tokenType == #Float])
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5195
             and:[tokenValue < 0]]]
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5196
    ] whileTrue:[
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5197
        "/ kludge alarm: in a function-call argList, #, is not a binarySelector
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5198
        inFunctionCallArgument == true ifTrue:[
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5199
            ((tokenType == #BinaryOperator) and:[tokenName = ',']) ifTrue:[
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5200
                ^ receiver
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5201
            ].
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5202
        ].
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5203
1547
485ee78fce9d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1546
diff changeset
  5204
        pos1 := tokenPosition.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5205
        lno := tokenLineNr.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5206
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5207
        "/ kludge alarm: bar and minus are not scanned as binop
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5208
        (tokenType == $|) ifTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5209
            sel := '|'.
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5210
            sel := self selectorCheck:sel for:receiver position:tokenPosition to:tokenPosition.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5211
            self nextToken
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5212
        ] ifFalse:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5213
            (tokenType == #BinaryOperator) ifTrue:[
977
c1afbaf48a23 remember used & modified local vars;
Claus Gittinger <cg@exept.de>
parents: 971
diff changeset
  5214
                sel := tokenName.
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  5215
                sel := self selectorCheck:sel for:receiver position:tokenPosition to:(tokenPosition + tokenName size - 1).
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5216
                self nextToken
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5217
            ] ifFalse:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5218
                sel := '-'.
1683
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  5219
                token := tokenValue := tokenValue negated.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  5220
                tokenPosition := tokenPosition + 1. "/ to skip the sign
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5221
            ]
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5222
        ].
1547
485ee78fce9d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1546
diff changeset
  5223
485ee78fce9d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1546
diff changeset
  5224
        pos2 := pos1 + sel size - 1.
485ee78fce9d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1546
diff changeset
  5225
        self markSelector:sel from:pos1 to:pos2 receiverNode:receiver.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5226
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5227
        arg := self unaryExpression.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5228
        (arg == #Error) ifTrue:[^ #Error].
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5229
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5230
        expr := BinaryNode receiver:receiver selector:sel arg:arg fold:foldConstants.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5231
        expr isErrorNode ifTrue:[
1547
485ee78fce9d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1546
diff changeset
  5232
            self parseError:(expr errorString) position:pos1 to:tokenPosition.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5233
            errorFlag := false. "ok, user wants it - so he'll get it"
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5234
            expr := BinaryNode receiver:receiver selector:sel arg:arg fold:nil.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5235
        ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5236
        expr lineNumber:lno.
1547
485ee78fce9d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1546
diff changeset
  5237
        expr selectorPosition:pos1.
1687
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  5238
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  5239
        (ignoreErrors or:[ignoreWarnings]) ifFalse:[
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  5240
            note := self plausibilityCheck:expr.
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  5241
            note notNil ifTrue:[
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  5242
                self warning:note position:pos1 to:pos2
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  5243
            ].
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  5244
        ].
1060
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  5245
        parseForCode ifFalse:[
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5246
            self rememberSelectorUsed:sel receiver:receiver
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5247
        ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5248
        receiver := expr.   "/ for next message
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5249
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5250
    ^ receiver
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5251
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5252
    "Modified: / 9.1.1998 / 19:05:18 / stefan"
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  5253
    "Modified: / 19.1.2000 / 16:22:04 / cg"
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5254
!
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5255
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5256
byteArray
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5257
    "started with ST-80 R4 - allow byteArray constants as #[ ... ]"
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5258
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5259
    |bytes index limit newArray elem pos1 pos2|
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5260
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5261
    pos1 := tokenPosition.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5262
    bytes := ByteArray uninitializedNew:5000.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5263
    index := 0. limit := 5000.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5264
    [tokenType ~~ $] ] whileTrue:[
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5265
        pos2 := tokenPosition.
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5266
        "
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5267
         this is not good programming style, but speeds up
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5268
         reading of huge byte arrays (i.e. stored Images ...)
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5269
        "
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5270
        (tokenType == #Integer) ifTrue:[
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5271
            elem := tokenValue
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5272
        ] ifFalse:[
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5273
            elem := self arrayConstant.
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5274
            (elem == #Error) ifTrue:[
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5275
                (tokenType == #EOF) ifTrue:[
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5276
                    self syntaxError:'unterminated bytearray-constant; '']'' expected' 
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5277
                            position:pos1 to:tokenPosition
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5278
                ].
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5279
                ^ #Error
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5280
            ].
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5281
        ].
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5282
        ((elem isMemberOf:SmallInteger) and:[elem between:0 and:255]) ifTrue:[
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5283
            index := index + 1.
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5284
            bytes at:index put:elem.
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5285
            index == limit ifTrue:[
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5286
                newArray := ByteArray uninitializedNew:(limit * 2).
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5287
                newArray replaceFrom:1 to:limit with:bytes startingAt:1.
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5288
                limit := limit * 2.
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5289
                bytes := newArray
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5290
            ].
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5291
        ] ifFalse:[
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5292
            self parseError:'invalid ByteArray element' position:pos2 to:tokenPosition - 1
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5293
        ].
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5294
        self nextToken.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5295
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5296
    newArray := ByteArray uninitializedNew:index.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5297
    newArray replaceFrom:1 to:index with:bytes startingAt:1.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5298
    ^ newArray
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5299
!
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5300
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5301
degeneratedKeywordExpressionForSelector
1406
cb80600efd76 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1405
diff changeset
  5302
    "parse a keyword-expression without receiver - for the selector only. 
cb80600efd76 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1405
diff changeset
  5303
     Return the selector or nil (if it cannot be determined). 
cb80600efd76 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1405
diff changeset
  5304
     This is not used in normal parsing, but instead to extract the selector from a code fragment.
cb80600efd76 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1405
diff changeset
  5305
     (for example, the system browsers 'implementors'-function uses this to extract a selector from
cb80600efd76 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1405
diff changeset
  5306
      the selection)"
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5307
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5308
    |sel arg rec|
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5309
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5310
    (tokenType == #Keyword) ifTrue:[
1271
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5311
        sel := tokenName.
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5312
        self nextToken.
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5313
        arg := self binaryExpression.
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5314
        (arg == #Error) ifTrue:[^ sel].
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5315
        [tokenType == #Keyword] whileTrue:[
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5316
            sel := sel , tokenName.
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5317
            self nextToken.
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5318
            arg := self binaryExpression.
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5319
            (arg == #Error) ifTrue:[^ sel].
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5320
        ].
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5321
        ^ sel
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5322
    ].
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5323
1406
cb80600efd76 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1405
diff changeset
  5324
    (rec := self arrayIndexingExpression) == #Error ifTrue:[ ^ nil].
cb80600efd76 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1405
diff changeset
  5325
    sel := self degeneratedKeywordExpressionForSelector.
cb80600efd76 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1405
diff changeset
  5326
    sel notNil ifTrue:[ ^ sel].
cb80600efd76 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1405
diff changeset
  5327
1407
d8c34d91199e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1406
diff changeset
  5328
    rec isAssignment ifTrue:[
d8c34d91199e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1406
diff changeset
  5329
        rec := rec expression
d8c34d91199e checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1406
diff changeset
  5330
    ].
1406
cb80600efd76 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1405
diff changeset
  5331
    rec isMessage ifTrue:[
cb80600efd76 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1405
diff changeset
  5332
        ^ rec selector
cb80600efd76 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1405
diff changeset
  5333
    ].        
cb80600efd76 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1405
diff changeset
  5334
    ^ nil
1524
078c644495de example
penk
parents: 1523
diff changeset
  5335
078c644495de example
penk
parents: 1523
diff changeset
  5336
    "
078c644495de example
penk
parents: 1523
diff changeset
  5337
     (self new source:'hello:world:') nextToken; degeneratedKeywordExpressionForSelector   
078c644495de example
penk
parents: 1523
diff changeset
  5338
     (self new source:'hello:world') nextToken; degeneratedKeywordExpressionForSelector     
078c644495de example
penk
parents: 1523
diff changeset
  5339
     (self new source:'hello:') nextToken; degeneratedKeywordExpressionForSelector  
078c644495de example
penk
parents: 1523
diff changeset
  5340
    "
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5341
!
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5342
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5343
expression
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5344
    "parse a cascade-expression; return a node-tree, nil or #Error.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5345
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5346
     expression ::= keywordExpression
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5347
                    | keywordExpression cascade
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5348
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5349
     cascade ::= ';' expressionSendPart
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5350
                 | cascade ';' expressionSendPart
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5351
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5352
     expressionSendPart ::= { KEYWORD binaryExpression }
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5353
                            | BINARYOPERATOR unaryExpression
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5354
                            | IDENTIFIER
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5355
    "
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5356
864
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  5357
    |receiver arg sel args pos pos2 lno tokenEnd realReceiver positions|
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5358
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5359
    pos := tokenPosition.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5360
    receiver := self keywordExpression.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5361
    (receiver == #Error) ifTrue:[^ #Error].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5362
    (tokenType == $;) ifTrue:[
743
3ced4791090c changes for cascades to super/here semantics.
Claus Gittinger <cg@exept.de>
parents: 739
diff changeset
  5363
        receiver isMessage ifFalse:[
3ced4791090c changes for cascades to super/here semantics.
Claus Gittinger <cg@exept.de>
parents: 739
diff changeset
  5364
            self syntaxError:'left side of cascade must be a message expression'
3ced4791090c changes for cascades to super/here semantics.
Claus Gittinger <cg@exept.de>
parents: 739
diff changeset
  5365
                    position:pos to:tokenPosition.
3ced4791090c changes for cascades to super/here semantics.
Claus Gittinger <cg@exept.de>
parents: 739
diff changeset
  5366
            realReceiver := receiver. "/ only to allow continuing.
3ced4791090c changes for cascades to super/here semantics.
Claus Gittinger <cg@exept.de>
parents: 739
diff changeset
  5367
        ] ifTrue:[
3ced4791090c changes for cascades to super/here semantics.
Claus Gittinger <cg@exept.de>
parents: 739
diff changeset
  5368
            realReceiver := receiver receiver.
3ced4791090c changes for cascades to super/here semantics.
Claus Gittinger <cg@exept.de>
parents: 739
diff changeset
  5369
        ].
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5370
        [tokenType == $;] whileTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5371
            self nextToken.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5372
            (tokenType == #Identifier) ifTrue:[
739
18bce3ea44f5 fixed syntax-highlight for cascade-selectors.
Claus Gittinger <cg@exept.de>
parents: 738
diff changeset
  5373
                tokenEnd := tokenPosition + tokenName size - 1.
864
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  5374
                self markSelector:tokenName from:tokenPosition to:tokenEnd receiverNode:realReceiver.
977
c1afbaf48a23 remember used & modified local vars;
Claus Gittinger <cg@exept.de>
parents: 971
diff changeset
  5375
                sel := tokenName.
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  5376
                sel := self selectorCheck:tokenName for:realReceiver position:tokenPosition to:tokenEnd.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5377
                receiver := CascadeNode receiver:receiver selector:sel.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5378
                receiver lineNumber:tokenLineNr.
1060
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  5379
                parseForCode ifFalse:[
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  5380
                    self rememberSelectorUsed:sel
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  5381
                ].
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5382
                self nextToken.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5383
            ] ifFalse:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5384
                (tokenType == #BinaryOperator) ifTrue:[
739
18bce3ea44f5 fixed syntax-highlight for cascade-selectors.
Claus Gittinger <cg@exept.de>
parents: 738
diff changeset
  5385
                    tokenEnd := tokenPosition + tokenName size - 1.
864
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  5386
                    self markSelector:tokenName from:tokenPosition to:tokenEnd receiverNode:realReceiver.
977
c1afbaf48a23 remember used & modified local vars;
Claus Gittinger <cg@exept.de>
parents: 971
diff changeset
  5387
                    sel := tokenName.
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  5388
                    sel := self selectorCheck:tokenName for:realReceiver position:tokenPosition to:tokenEnd.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5389
                    lno := tokenLineNr. 
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5390
                    self nextToken.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5391
                    arg := self unaryExpression.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5392
                    (arg == #Error) ifTrue:[^ #Error].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5393
                    receiver := CascadeNode receiver:receiver selector:sel arg:arg.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5394
                    receiver lineNumber:lno.
1060
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  5395
                    parseForCode ifFalse:[
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  5396
                        self rememberSelectorUsed:sel
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  5397
                    ].
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5398
                ] ifFalse:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5399
                    (tokenType == #Keyword) ifTrue:[
739
18bce3ea44f5 fixed syntax-highlight for cascade-selectors.
Claus Gittinger <cg@exept.de>
parents: 738
diff changeset
  5400
                        tokenEnd := tokenPosition + tokenName size - 1.
864
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  5401
                        positions := OrderedCollection with:(tokenPosition to:tokenEnd).
739
18bce3ea44f5 fixed syntax-highlight for cascade-selectors.
Claus Gittinger <cg@exept.de>
parents: 738
diff changeset
  5402
                        pos := tokenPosition.
18bce3ea44f5 fixed syntax-highlight for cascade-selectors.
Claus Gittinger <cg@exept.de>
parents: 738
diff changeset
  5403
                        pos2 := tokenEnd.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5404
                        lno := tokenLineNr. 
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5405
                        sel := tokenName.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5406
                        self nextToken.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5407
                        arg := self binaryExpression.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5408
                        (arg == #Error) ifTrue:[^ #Error].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5409
                        args := Array with:arg.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5410
                        [tokenType == #Keyword] whileTrue:[
739
18bce3ea44f5 fixed syntax-highlight for cascade-selectors.
Claus Gittinger <cg@exept.de>
parents: 738
diff changeset
  5411
                            tokenEnd := tokenPosition + tokenName size - 1.
864
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  5412
                            positions add:(tokenPosition to:tokenEnd).
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5413
                            sel := sel , tokenName.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5414
                            self nextToken.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5415
                            arg := self binaryExpression.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5416
                            (arg == #Error) ifTrue:[^ #Error].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5417
                            args := args copyWith:arg.
739
18bce3ea44f5 fixed syntax-highlight for cascade-selectors.
Claus Gittinger <cg@exept.de>
parents: 738
diff changeset
  5418
                            pos2 := tokenEnd
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5419
                        ].
864
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  5420
                        positions do:[:p |
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  5421
                            self markSelector:sel from:p start to:p stop receiverNode:realReceiver.
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  5422
                        ].
1597
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  5423
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  5424
                        sel := self selectorCheck:sel for:realReceiver position:pos to:pos2.
4866fce1e050 inplausible selector marking
Claus Gittinger <cg@exept.de>
parents: 1581
diff changeset
  5425
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5426
                        receiver := CascadeNode receiver:receiver selector:sel args:args.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5427
                        receiver lineNumber:lno.
1060
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  5428
                        parseForCode ifFalse:[
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  5429
                            self rememberSelectorUsed:sel
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  5430
                        ].
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5431
                    ] ifFalse:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5432
                        (tokenType == #Error) ifTrue:[^ #Error].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5433
                        self syntaxError:('invalid cascade; ' , tokenType printString , ' unexpected')
1371
de4c37ac12fc code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 1369
diff changeset
  5434
                                position:tokenPosition to:source position1Based - 1.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5435
                        ^ #Error
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5436
                    ]
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5437
                ]
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5438
            ]
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5439
        ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5440
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5441
        "obscure (unspecified ?) if selector follows; Question:
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5442
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5443
        is
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5444
                'expr sel1; sel2 sel3'
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5445
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5446
        to be parsed as: 
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5447
                (t := expr.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5448
                 t sel1.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5449
                 t sel2) sel3
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5450
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5451
         or:
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5452
                (t := expr.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5453
                 t sel1.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5454
                 t sel2 sel3)
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5455
        "
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5456
        ((tokenType == #Identifier) 
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5457
         or:[(tokenType == #BinaryOperator)
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5458
             or:[tokenType == #Keyword]]) ifTrue:[
1328
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5459
            self syntaxError:'ambigous cascade - please group using (...)'
1371
de4c37ac12fc code rewritten to be independent of stream zero-base
Claus Gittinger <cg@exept.de>
parents: 1369
diff changeset
  5460
                    position:tokenPosition to:source position1Based - 1.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5461
            ^ #Error
1328
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5462
"/            self warning: "syntaxError:" 'possibly ambigous cascade - please group using (...)'
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5463
"/                    position:tokenPosition to:source position - 1.
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5464
"/            tokenType == #Identifier ifTrue:[
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5465
"/                ^ self unaryExpressionFor:receiver
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5466
"/            ].
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5467
"/            tokenType == #BinaryOperator ifTrue:[
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5468
"/                ^ self binaryExpressionFor:receiver
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5469
"/            ].
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5470
"/            ^ self keywordExpressionFor:receiver
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5471
        ]
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5472
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5473
    ^ receiver
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5474
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  5475
    "Modified: / 19.1.2000 / 16:22:16 / cg"
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5476
!
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5477
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5478
functionCallArgList
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5479
    |argList arg prevInFunctionCallArgument|
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5480
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5481
    self nextToken.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5482
    tokenType == $) ifTrue:[ self nextToken. ^ #() ].
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5483
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5484
    argList := OrderedCollection new.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5485
    [ true ] whileTrue:[
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5486
        prevInFunctionCallArgument := inFunctionCallArgument.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5487
        inFunctionCallArgument := true.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5488
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5489
        arg := self expression.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5490
        argList add:arg.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5491
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5492
        inFunctionCallArgument := prevInFunctionCallArgument.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5493
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5494
        tokenType == $) ifTrue:[
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5495
            self nextToken.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5496
            ^ argList 
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5497
        ].
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5498
        ((tokenType == #BinaryOperator) and:[tokenName = ',']) ifFalse:[
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5499
            self parseError:'"," or ")" expected'.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5500
        ].
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5501
        self nextToken.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5502
    ].
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5503
!
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5504
1271
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5505
functionCallExpression
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5506
    "parse a functionCall; 
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5507
     this is an st/x extension.
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5508
        foo(x) 
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5509
     is syntactic sugar for 
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5510
        foo value:x
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5511
    "
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5512
1342
65f8f4d0ce09 only autoDefine workspace vars on the top level (i.e. not within blocks)
Claus Gittinger <cg@exept.de>
parents: 1341
diff changeset
  5513
    |receiver numArgs argList evalSelectors evalSelector|
1271
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5514
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5515
    receiver := self primary.
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5516
    tokenType == $( ifFalse:[^ receiver].
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5517
    parserFlags allowFunctionCallSyntaxForBlockEvaluation ifFalse:[^ receiver.].
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5518
1271
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5519
    (receiver == #Error) ifTrue:[^ #Error].
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5520
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5521
    receiver isVariable ifFalse:[
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5522
        ((receiver isMessage or:[receiver isAssignment]) and:[receiver parenthized]) ifFalse:[
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5523
            receiver isBlock ifFalse:[
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5524
                ^ receiver
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5525
            ]
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5526
        ].
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5527
    ].
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5528
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5529
    argList := self functionCallArgList.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5530
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5531
    "/ make it a block evaluation
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5532
    numArgs := argList size.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5533
    numArgs == 0 ifTrue:[
1341
e6cb61331a88 eval -> value
Claus Gittinger <cg@exept.de>
parents: 1340
diff changeset
  5534
        ^ UnaryNode receiver:receiver selector:#value
e6cb61331a88 eval -> value
Claus Gittinger <cg@exept.de>
parents: 1340
diff changeset
  5535
    ].
1579
22f4d629eeee *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1576
diff changeset
  5536
    evalSelectors := #(#'value:'
1341
e6cb61331a88 eval -> value
Claus Gittinger <cg@exept.de>
parents: 1340
diff changeset
  5537
                       #'value:value:'
e6cb61331a88 eval -> value
Claus Gittinger <cg@exept.de>
parents: 1340
diff changeset
  5538
                       #'value:value:value:'
e6cb61331a88 eval -> value
Claus Gittinger <cg@exept.de>
parents: 1340
diff changeset
  5539
                       #'value:value:value:value:'
e6cb61331a88 eval -> value
Claus Gittinger <cg@exept.de>
parents: 1340
diff changeset
  5540
                       #'value:value:value:value:value:'
e6cb61331a88 eval -> value
Claus Gittinger <cg@exept.de>
parents: 1340
diff changeset
  5541
                       #'value:value:value:value:value:value:'
e6cb61331a88 eval -> value
Claus Gittinger <cg@exept.de>
parents: 1340
diff changeset
  5542
                       #'value:value:value:value:value:value:value:'
e6cb61331a88 eval -> value
Claus Gittinger <cg@exept.de>
parents: 1340
diff changeset
  5543
                       #'value:value:value:value:value:value:value:value:'
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5544
                     ).
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5545
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5546
    numArgs <= evalSelectors size ifTrue:[
1342
65f8f4d0ce09 only autoDefine workspace vars on the top level (i.e. not within blocks)
Claus Gittinger <cg@exept.de>
parents: 1341
diff changeset
  5547
        evalSelector := evalSelectors at:numArgs.
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5548
        ^ MessageNode 
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5549
                receiver:receiver 
1342
65f8f4d0ce09 only autoDefine workspace vars on the top level (i.e. not within blocks)
Claus Gittinger <cg@exept.de>
parents: 1341
diff changeset
  5550
                selector:evalSelector
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5551
                args:argList.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5552
    ].
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5553
    "/ gen argument vector
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5554
    ^ MessageNode 
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5555
            receiver:receiver 
1341
e6cb61331a88 eval -> value
Claus Gittinger <cg@exept.de>
parents: 1340
diff changeset
  5556
            selector:#valueWithArguments:
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5557
            args:(self genMakeArrayWith:argList).
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5558
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5559
    "
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5560
     Parser allowFunctionCallSyntaxForBlockEvaluation:true.
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5561
    "
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5562
1271
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5563
    "
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5564
     |foo|
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5565
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5566
     foo := [:x | x + 1].
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5567
     1 + foo(1).     
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5568
     foo(1).     
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5569
    "
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5570
    "
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5571
     |addN add1|
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5572
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5573
     addN := [:n | [:x | x + n]].
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5574
     add1 := addN(1).
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5575
     add1(10).       
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5576
    "
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5577
    "AllowFunctionCallSyntaxForBlockEvaluation := false."
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5578
    "
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5579
     |addN add1|
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5580
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5581
     addN := [:n | [:x | x + n]].
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5582
     add1 := addN value:1.
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5583
     add1 value:10       
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5584
    "
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5585
!
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  5586
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5587
keywordExpression
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5588
    "parse a keyword-expression; return a node-tree, nil or #Error.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5589
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5590
     keywordExpression ::= binaryexpression
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5591
                           | { KEYWORD-PART binaryExpression }
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5592
    "
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5593
1328
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5594
    |receiver|
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5595
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5596
    receiver := self binaryExpression.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5597
    (receiver == #Error) ifTrue:[^ #Error].
1328
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5598
    ^ self keywordExpressionFor:receiver
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5599
!
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5600
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5601
keywordExpressionFor:receiverArg
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5602
    "parse a keyword-expression; return a node-tree, nil or #Error.
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5603
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5604
     keywordExpression ::= binaryexpression
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5605
                           | { KEYWORD-PART binaryExpression }
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5606
    "
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5607
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5608
    |expr receiver sel arg args posR1 posR2 pos1 pos2 lno note positions|
1328
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5609
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5610
    receiver := receiverArg.
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5611
    posR1 := tokenPosition.
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5612
    (tokenType == #Keyword) ifFalse:[^ receiver].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5613
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5614
    pos1 := posR2 := tokenPosition.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5615
    pos2 := tokenPosition + tokenName size - 1.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5616
    positions := OrderedCollection with:(pos1 to:pos2).
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5617
    sel := tokenName.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5618
    lno := tokenLineNr.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5619
    self nextToken.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5620
    arg := self binaryExpression.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5621
    (arg == #Error) ifTrue:[^ #Error].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5622
    args := Array with:arg.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5623
    [tokenType == #Keyword] whileTrue:[
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5624
        sel := sel , tokenName.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5625
        pos2 := tokenPosition + tokenName size - 1.
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5626
        positions add:(tokenPosition to:pos2).
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5627
        self nextToken.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5628
        arg := self binaryExpression.
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5629
        (arg == #Error) ifTrue:[^ #Error].
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5630
        args := args copyWith:arg.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5631
    ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5632
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5633
    positions do:[:p |
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5634
        self markSelector:sel from:p start to:p stop receiverNode:receiver.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5635
    ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5636
    sel := self selectorCheck:sel for:receiver positions:positions.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5637
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5638
    ignoreErrors ifFalse:[
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5639
        (Class definitionSelectors includes:sel) ifTrue:[
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5640
            receiver isVariable ifTrue:[
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5641
                receiver isUndeclared ifTrue:[
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5642
                    self parseError:('undefined superclass: ' , receiver name) position:pos1 to:pos2.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5643
                ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5644
            ]
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5645
        ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5646
    ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5647
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5648
    expr := MessageNode receiver:receiver selector:sel args:args fold:foldConstants.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5649
    expr isErrorNode ifTrue:[
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5650
        self parseError:(expr errorString) position:pos1 to:pos2.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5651
        errorFlag := false. "ok, user wants it - so he'll get it"
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5652
        expr := MessageNode receiver:receiver selector:sel args:args fold:nil.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5653
    ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5654
    expr lineNumber:lno.
1687
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  5655
    (ignoreErrors or:[ignoreWarnings]) ifFalse:[
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  5656
        note := self plausibilityCheck:expr.
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  5657
        note notNil ifTrue:[
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  5658
            self warning:note position:pos1 to:pos2
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  5659
        ].
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5660
    ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5661
    parseForCode ifFalse:[
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5662
        self rememberSelectorUsed:sel receiver:receiver
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5663
    ].
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5664
1193
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  5665
"/        (contextToEvaluateIn isNil and:[selfValue isNil]) ifTrue:[    "/ do not check this for doits
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  5666
"/            receiver isSuper ifTrue:[
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  5667
"/                sel ~= selector ifTrue:[
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  5668
"/                    self warnCommonMistake:'possible bad super message (selector should be same as in current method) ?'
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  5669
"/                                  position:posR1 to:posR2-1
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  5670
"/                ].
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  5671
"/            ].
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  5672
"/        ].
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  5673
"/
1685
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5674
    (ignoreErrors or:[ignoreWarnings]) ifFalse:[
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5675
        (sel = #and: or:[sel = #or:]) ifTrue:[
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5676
            expr arg1 isBlock ifFalse:[
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5677
                (expr arg1 isVariable
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5678
                and:[ (expr arg1 name asLowercase includesString:'block')]) ifFalse:[
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5679
                    self warnCommonMistake:'(possible common mistake) missing block brackets ?'
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5680
                              position:pos2+1 to:tokenPosition-1
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5681
                ]
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5682
            ].
1685
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5683
            ^ expr.
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5684
        ].
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5685
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5686
        (sel = #whileTrue: or:[sel = #whileFalse:]) ifTrue:[
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5687
            expr receiver isBlock ifFalse:[
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5688
                (expr receiver isVariable
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5689
                and:[ (expr receiver name asLowercase includesString:'block')]) ifFalse:[
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5690
                    self warnCommonMistake:'(possible common mistake) missing block brackets ?'
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5691
                              position:posR1 to:posR2-1
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5692
                ]
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5693
            ].
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5694
            ^ expr.
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5695
        ].
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5696
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5697
        (sel = #ifTrue: or:[sel = #ifFalse:]) ifTrue:[
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5698
            expr receiver isMessage ifTrue:[
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5699
                (expr receiver selector = #whileTrue or:[expr receiver selector = #whileFalse]) ifTrue:[
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5700
                    self warnCommonMistake:'strange receiver expression'
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5701
                              position:posR1 to:posR2-1
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5702
                ].
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5703
            ].
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5704
            ^ expr
bd86bb0dfb8c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1683
diff changeset
  5705
        ].
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5706
    ].
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  5707
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  5708
    ^ expr.
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5709
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  5710
    "Modified: / 19.1.2000 / 16:22:22 / cg"
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5711
!
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  5712
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5713
primary
1028
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  5714
    "parse a primary-expression; return a node-tree, nil or #Error.
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  5715
     This also cares for namespace-access-pathes."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5716
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5717
    |val pos node eMsg endPos|
924
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  5718
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  5719
    (tokenType == #Self) ifTrue:[
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5720
        ^ self primary_self.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5721
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5722
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5723
    pos := tokenPosition.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5724
    (tokenType == #Identifier) ifTrue:[
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5725
        "
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5726
         must check for variable first, to be backward compatible
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5727
         with other smalltalks. 
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5728
        "
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5729
        tokenName = 'here' ifTrue:[
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5730
            (self variableOrError:tokenName) == #Error ifTrue:[
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5731
                self warnSTXHereExtensionUsedAt:pos.
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5732
                tokenType := #Here.
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5733
                ^ self primary_here.
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5734
            ]
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  5735
        ].
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5736
        ^ self primary_identifier
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5737
    ].
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  5738
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  5739
    ((tokenType == #Integer) 
120
claus
parents: 117
diff changeset
  5740
     or:[(tokenType == #String)
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  5741
     or:[(tokenType == #Character) 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  5742
     or:[(tokenType == #Float)
1657
451328cc3264 ESSymbols
Claus Gittinger <cg@exept.de>
parents: 1654
diff changeset
  5743
     or:[(tokenType == #Symbol)
451328cc3264 ESSymbols
Claus Gittinger <cg@exept.de>
parents: 1654
diff changeset
  5744
     or:[(tokenType == #ESSymbol)]]]]]) ifTrue:[
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5745
        ^ self primary_simpleLiteral.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5746
    ].
924
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  5747
1347
6168b045f2ef preps for fixedPoint literals
Claus Gittinger <cg@exept.de>
parents: 1342
diff changeset
  5748
    (tokenType == #FixedPoint) ifTrue:[
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5749
        parserFlags allowFixedPointLiterals == true ifFalse:[
1347
6168b045f2ef preps for fixedPoint literals
Claus Gittinger <cg@exept.de>
parents: 1342
diff changeset
  5750
            self parseError:'non-Standard literal: FixedPoint. Please enable in settings.' position:pos to:tokenPosition.
6168b045f2ef preps for fixedPoint literals
Claus Gittinger <cg@exept.de>
parents: 1342
diff changeset
  5751
            ^ #Error
6168b045f2ef preps for fixedPoint literals
Claus Gittinger <cg@exept.de>
parents: 1342
diff changeset
  5752
        ].
6168b045f2ef preps for fixedPoint literals
Claus Gittinger <cg@exept.de>
parents: 1342
diff changeset
  5753
        ^ self primary_simpleLiteral.
6168b045f2ef preps for fixedPoint literals
Claus Gittinger <cg@exept.de>
parents: 1342
diff changeset
  5754
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5755
    (tokenType == #Nil) ifTrue:[
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5756
        ^ self primary_nil.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5757
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5758
    (tokenType == #True) ifTrue:[
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5759
        ^ self primary_true
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5760
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5761
    (tokenType == #False) ifTrue:[
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5762
        ^ self primary_false
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5763
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5764
    (tokenType  == #Super) ifTrue:[
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5765
        ^ self primary_super.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5766
    ].
924
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  5767
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5768
    (tokenType == #ThisContext) ifTrue:[
1262
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  5769
        ^ self primary_thisContext
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5770
    ].
924
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  5771
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5772
    (tokenType == #HashLeftParen) ifTrue:[
1538
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5773
        self nextToken.
1202
95abdd4272cd scanning of keyword symbols in array consts fixed
Claus Gittinger <cg@exept.de>
parents: 1200
diff changeset
  5774
        self inArrayLiteral:true.
1165
09d40e1ff75d oops - invalid literal array const was not signalling an error
Claus Gittinger <cg@exept.de>
parents: 1164
diff changeset
  5775
        ParseErrorSignal handle:[:ex |
1202
95abdd4272cd scanning of keyword symbols in array consts fixed
Claus Gittinger <cg@exept.de>
parents: 1200
diff changeset
  5776
            self inArrayLiteral:false.
1165
09d40e1ff75d oops - invalid literal array const was not signalling an error
Claus Gittinger <cg@exept.de>
parents: 1164
diff changeset
  5777
            ^ #Error
09d40e1ff75d oops - invalid literal array const was not signalling an error
Claus Gittinger <cg@exept.de>
parents: 1164
diff changeset
  5778
        ] do:[
09d40e1ff75d oops - invalid literal array const was not signalling an error
Claus Gittinger <cg@exept.de>
parents: 1164
diff changeset
  5779
            val := self array.
09d40e1ff75d oops - invalid literal array const was not signalling an error
Claus Gittinger <cg@exept.de>
parents: 1164
diff changeset
  5780
        ].
1202
95abdd4272cd scanning of keyword symbols in array consts fixed
Claus Gittinger <cg@exept.de>
parents: 1200
diff changeset
  5781
        self inArrayLiteral:false.
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5782
        self nextToken.
1003
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  5783
        (self noAssignmentAllowed:'assignment to a constant' at:pos) ifFalse:[
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5784
            ^ #Error
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5785
        ].
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5786
        ^ ConstantNode type:#Array value:val
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5787
    ].
924
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  5788
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  5789
    (tokenType == #HashLeftBrace) ifTrue:[
1042
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  5790
        val := self qualifiedName.
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  5791
        self nextToken.
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  5792
        ^ val.
924
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  5793
    ].
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  5794
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5795
    (tokenType == #HashLeftBrack) ifTrue:[
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5796
        self nextToken.
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5797
        val := self byteArray.
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5798
        self nextToken.
1003
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  5799
        (self noAssignmentAllowed:'assignment to a constant' at:pos) ifFalse:[
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5800
            ^ #Error
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5801
        ].
924
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  5802
        ^ ConstantNode type:#ByteArray value:val
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5803
    ].
432
2b7b75f1ee12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 429
diff changeset
  5804
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5805
    (tokenType == $() ifTrue:[
1640
261459ccc704 emphasize parenthesis nesting
Claus Gittinger <cg@exept.de>
parents: 1638
diff changeset
  5806
        parenthesisLevel := parenthesisLevel + 1.
261459ccc704 emphasize parenthesis nesting
Claus Gittinger <cg@exept.de>
parents: 1638
diff changeset
  5807
        self markParenthesisAt:tokenPosition.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5808
        ^ self primary_expression.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5809
    ].
924
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  5810
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5811
    (tokenType == $[ ) ifTrue:[
673
0c66b7cb1d2f checkin from browser
ca
parents: 672
diff changeset
  5812
        self markBracketAt:tokenPosition.
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5813
        val := self block.
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5814
        self nextToken.
1003
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  5815
        (self noAssignmentAllowed:'invalid assignment' at:pos) ifFalse:[
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5816
            ^ #Error
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5817
        ].
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5818
        ^ val
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5819
    ].
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  5820
1262
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  5821
    "/ EXPERIMENTAL - may be in next release
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5822
    parserFlags allowVariableReferences == true ifTrue:[
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5823
        ((tokenType == #BinaryOperator) and:[token = '&']) ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5824
            self nextToken.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5825
            node := self primary_identifier.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5826
            "/ generate a Reference
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5827
            ^ self makeReferenceFor:node
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5828
        ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5829
    ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5830
894
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  5831
    (tokenType == ${ ) ifTrue:[
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5832
        parserFlags allowSqueakExtensions == true ifFalse:[
1335
59e2664cb564 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1328
diff changeset
  5833
            self parseError:'non-Standard Squeak extension: Brace Computed Array. Enable in settings.' position:pos to:tokenPosition.
1453
205e70e12abe squeak-brace extension error is now proceedable
Claus Gittinger <cg@exept.de>
parents: 1446
diff changeset
  5834
            errorFlag := false.
894
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  5835
        ].
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5836
        ^ self primary_squeakComputedArray.
894
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  5837
    ].
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  5838
502
410af1c0df1d parse primitive-primary expression
Claus Gittinger <cg@exept.de>
parents: 501
diff changeset
  5839
    (tokenType == #Primitive) ifTrue:[
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5840
        self nextToken.
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5841
        node := PrimitiveNode code:tokenValue.
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5842
        hasNonOptionalPrimitiveCode := true.
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5843
        hasPrimitiveCode := true.
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5844
        ^ node
502
410af1c0df1d parse primitive-primary expression
Claus Gittinger <cg@exept.de>
parents: 501
diff changeset
  5845
    ].
410af1c0df1d parse primitive-primary expression
Claus Gittinger <cg@exept.de>
parents: 501
diff changeset
  5846
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5847
    tokenType == #HashHashLeftParen ifTrue:[
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5848
        self nextToken.
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5849
        parserFlags allowDolphinExtensions == true ifFalse:[
1335
59e2664cb564 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1328
diff changeset
  5850
            self parseError:'non-Standard Dolphin extension: ##(..). Enable in settings.' position:pos to:tokenPosition.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5851
            ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5852
        ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5853
        ^ self primary_dolphinComputedLiteral.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5854
    ].
1299
6c182cd87b6c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1297
diff changeset
  5855
    tokenType == #ExclaLeftBrack ifTrue:[
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5856
        self nextToken.
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5857
        parserFlags allowLazyValueExtension == true ifFalse:[
1335
59e2664cb564 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1328
diff changeset
  5858
            self parseError:'non-Standard LazyValue extension. Enable in classVariable.' position:pos to:tokenPosition.
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5859
            ^ #Error
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5860
        ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5861
        ^ self primary_lazyValue.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5862
    ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5863
    tokenType == #HashHash ifTrue:[
1301
677ca6e364d4 + warnPossible incompatibility
Claus Gittinger <cg@exept.de>
parents: 1299
diff changeset
  5864
        self warnPossibleIncompatibility:'''##'' might be interpreted differently in other smalltalk systems' position:pos to:tokenPosition.
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5865
        tokenType := #Symbol.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5866
        token := tokenValue := tokenName := '#'.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5867
        ^ self primary_simpleLiteral.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5868
    ].
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5869
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  5870
    parserFlags allowSqueakExtensions == true ifTrue:[
1538
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5871
        ((tokenType == #BinaryOperator) and:[token = '#']) ifTrue:[
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5872
            self nextToken.
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5873
            (tokenType == $( ) ifFalse:[
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5874
                self parseError:'''('' expected after #.' position:pos to:tokenPosition.
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5875
                ^ self.
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5876
            ].
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5877
            self nextToken.
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5878
            self inArrayLiteral:true.
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5879
            ParseErrorSignal handle:[:ex |
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5880
                self inArrayLiteral:false.
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5881
                ^ #Error
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5882
            ] do:[
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5883
                val := self array.
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5884
            ].
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5885
            self inArrayLiteral:false.
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5886
            self nextToken.
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5887
            (self noAssignmentAllowed:'assignment to a constant' at:pos) ifFalse:[
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5888
                ^ #Error
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5889
            ].
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5890
            ^ ConstantNode type:#Array value:val
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5891
        ].
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5892
    ].
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5893
1537
de5fc45c2f10 squeak allows whiteSpace between sign and number
Claus Gittinger <cg@exept.de>
parents: 1535
diff changeset
  5894
    ((tokenType == #BinaryOperator) and:[token = '-']) ifTrue:[
de5fc45c2f10 squeak allows whiteSpace between sign and number
Claus Gittinger <cg@exept.de>
parents: 1535
diff changeset
  5895
        self nextToken.
de5fc45c2f10 squeak allows whiteSpace between sign and number
Claus Gittinger <cg@exept.de>
parents: 1535
diff changeset
  5896
        ((tokenType == #Integer) 
de5fc45c2f10 squeak allows whiteSpace between sign and number
Claus Gittinger <cg@exept.de>
parents: 1535
diff changeset
  5897
        or:[(tokenType == #Float)]) ifFalse:[
de5fc45c2f10 squeak allows whiteSpace between sign and number
Claus Gittinger <cg@exept.de>
parents: 1535
diff changeset
  5898
            self parseError:'number expected after sign.' position:pos to:tokenPosition.
1539
fd0b2792a8bd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1538
diff changeset
  5899
            ^ #Error.
1537
de5fc45c2f10 squeak allows whiteSpace between sign and number
Claus Gittinger <cg@exept.de>
parents: 1535
diff changeset
  5900
        ].
1710
78346eeddbec ST/V parsing support
Claus Gittinger <cg@exept.de>
parents: 1696
diff changeset
  5901
        ((parserFlags allowSqueakExtensions == true)
78346eeddbec ST/V parsing support
Claus Gittinger <cg@exept.de>
parents: 1696
diff changeset
  5902
        or:[parserFlags allowSTVExtensions == true]) ifFalse:[
78346eeddbec ST/V parsing support
Claus Gittinger <cg@exept.de>
parents: 1696
diff changeset
  5903
            self parseError:'non-Standard Squeak (or ST/V) extension: space between sign and number. Enable in settings.' position:pos to:tokenPosition.
1538
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5904
            errorFlag := false.
c55990043eb6 squeak allow space between '#" and '('
Claus Gittinger <cg@exept.de>
parents: 1537
diff changeset
  5905
        ].
1537
de5fc45c2f10 squeak allows whiteSpace between sign and number
Claus Gittinger <cg@exept.de>
parents: 1535
diff changeset
  5906
de5fc45c2f10 squeak allows whiteSpace between sign and number
Claus Gittinger <cg@exept.de>
parents: 1535
diff changeset
  5907
        node := self primary_simpleLiteral.
de5fc45c2f10 squeak allows whiteSpace between sign and number
Claus Gittinger <cg@exept.de>
parents: 1535
diff changeset
  5908
        node isConstant ifFalse:[
de5fc45c2f10 squeak allows whiteSpace between sign and number
Claus Gittinger <cg@exept.de>
parents: 1535
diff changeset
  5909
            self parseError:'number expected after sign.' position:pos to:tokenPosition.
1539
fd0b2792a8bd *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1538
diff changeset
  5910
            ^ #Error.
1537
de5fc45c2f10 squeak allows whiteSpace between sign and number
Claus Gittinger <cg@exept.de>
parents: 1535
diff changeset
  5911
        ].
1557
311e94185248 oops - parser clobbered Const1Node (negated)
Claus Gittinger <cg@exept.de>
parents: 1556
diff changeset
  5912
        ^ ConstantNode type:(node type) value:(node value negated).
1537
de5fc45c2f10 squeak allows whiteSpace between sign and number
Claus Gittinger <cg@exept.de>
parents: 1535
diff changeset
  5913
    ].
de5fc45c2f10 squeak allows whiteSpace between sign and number
Claus Gittinger <cg@exept.de>
parents: 1535
diff changeset
  5914
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5915
    (tokenType == #Error) ifTrue:[^ #Error].
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  5916
    tokenType isCharacter ifTrue:[
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5917
        eMsg := '"',tokenType printString,'" unexpected in primary.'.
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5918
        endPos := tokenPosition.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5919
    ] ifFalse:[
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5920
        (#(BinaryOperator Keyword) includes:tokenType) ifTrue:[
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5921
            eMsg := tokenType printString,' ("' , tokenName , '") ',' unexpected in primary. (missing receiver ?)'
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  5922
        ] ifFalse:[
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5923
            (#(Integer Float) includes:tokenType) ifTrue:[
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5924
                eMsg := tokenType printString,' (' , tokenValue , ') ',' unexpected in primary. (missing receiver ?)'
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5925
            ] ifFalse:[
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5926
                eMsg := '"',(token ? ''),'" (',tokenType printString,') unexpected in primary.' 
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5927
            ]
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5928
        ].
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5929
        endPos :=source position1Based - 1.
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5930
    ].
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5931
    self syntaxError:eMsg position:tokenPosition to:endPos.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5932
    ^ #Error
120
claus
parents: 117
diff changeset
  5933
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5934
    "Created: / 13-09-1995 / 12:50:50 / claus"
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  5935
    "Modified: / 22-08-2006 / 14:28:46 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5936
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  5937
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5938
primary_dolphinComputedLiteral
1273
3a9541cd8fef dolphin compile-time constant strings
Claus Gittinger <cg@exept.de>
parents: 1272
diff changeset
  5939
    "parse a dolphin computed literal; return a node-tree, or raise an Error.
3a9541cd8fef dolphin compile-time constant strings
Claus Gittinger <cg@exept.de>
parents: 1272
diff changeset
  5940
     In dolphin, these are written as: ##( expression )
3a9541cd8fef dolphin compile-time constant strings
Claus Gittinger <cg@exept.de>
parents: 1272
diff changeset
  5941
     and create a literal constant for the expressions value.
1274
7d4a3391a81a comments
Claus Gittinger <cg@exept.de>
parents: 1273
diff changeset
  5942
     Right now, only a subset is supported - Strings, ByteArrays and Characters.
7d4a3391a81a comments
Claus Gittinger <cg@exept.de>
parents: 1273
diff changeset
  5943
     WARNING: this is only supported to allow filing in dolphin code.
7d4a3391a81a comments
Claus Gittinger <cg@exept.de>
parents: 1273
diff changeset
  5944
     since stc cannot handle this (at the moment), you should rewrite the code
7d4a3391a81a comments
Claus Gittinger <cg@exept.de>
parents: 1273
diff changeset
  5945
     if you ever plan to stc-compile it into a shared library"
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5946
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5947
    |pos expr val|
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5948
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5949
    pos := tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5950
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5951
    expr := self expression.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5952
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5953
    tokenType ~~ $) ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5954
        self parseError:''')'' expected' position:tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5955
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5956
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5957
    self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5958
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5959
    (self noAssignmentAllowed:'invalid assignment' at:pos) ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5960
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5961
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5962
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5963
    val := expr evaluate.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5964
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5965
    val isLiteral ifTrue:[
1272
2a429e2293d1 dolphin compile-time constant strings
Claus Gittinger <cg@exept.de>
parents: 1271
diff changeset
  5966
        val isString ifTrue:[
2a429e2293d1 dolphin compile-time constant strings
Claus Gittinger <cg@exept.de>
parents: 1271
diff changeset
  5967
            ^ ConstantNode type:#String value:val
2a429e2293d1 dolphin compile-time constant strings
Claus Gittinger <cg@exept.de>
parents: 1271
diff changeset
  5968
        ].
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5969
        val isByteArray ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5970
            ^ ConstantNode type:#ByteArray value:val
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5971
        ].
1234
9aeab4cef9ba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1231
diff changeset
  5972
        val isCharacter ifTrue:[
9aeab4cef9ba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1231
diff changeset
  5973
            ^ ConstantNode type:#Character value:val
9aeab4cef9ba *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1231
diff changeset
  5974
        ].
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5975
        val isInteger ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5976
            ^ ConstantNode type:#Integer value:val
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5977
        ].
1328
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5978
        val isLimitedPrecisionReal ifTrue:[
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5979
            ^ ConstantNode type:#Float value:val
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  5980
        ].
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5981
        val isArray ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5982
            ^ ConstantNode type:#Array value:val
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  5983
        ].
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5984
    ] ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5985
        self parseError:'must be representable as a literal (for now)' position:pos.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5986
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5987
    ].
1326
Claus Gittinger <cg@exept.de>
parents: 1325
diff changeset
  5988
self halt:'unimplemented'.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5989
"/    "/ make it an array creation expression ...
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5990
"/    expr := MessageNode 
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  5991
"/            receiver:(VariableNode globalNamed:#Array)
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5992
"/            selector:#new:
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5993
"/            arg:(ConstantNode type:#Integer value:(exprList size)).
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5994
"/
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5995
"/    exprList size == 0 ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5996
"/        ^ expr.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5997
"/    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5998
"/    exprList keysAndValuesDo:[:idx :e |
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  5999
"/        expr := (idx == 1 ifTrue:[MessageNode] ifFalse:[CascadeNode])
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6000
"/                    receiver:expr
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6001
"/                    selector:#at:put:
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6002
"/                    arg1:(ConstantNode type:#Integer value:idx)
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6003
"/                    arg2:e
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6004
"/                    fold:false.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6005
"/    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6006
"/    expr := CascadeNode
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6007
"/                receiver:expr
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6008
"/                selector:#yourself.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6009
"/    ^ expr
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6010
!
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6011
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6012
primary_expression
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6013
    "parse a parentized expression primary; return a node-tree, or raise an Error."
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6014
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6015
    |pos val eMsg|
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6016
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6017
    pos := tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6018
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6019
    self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6020
    val := self expression.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6021
    (val == #Error) ifTrue:[^ #Error].
1758
75ec68a356c2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1756
diff changeset
  6022
    (tokenType == $) ) ifFalse:[
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6023
        tokenType isCharacter ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6024
            eMsg := 'missing '')'' (i.e. ''' , tokenType asString , ''' unexpected)'.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6025
        ] ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6026
            eMsg := 'missing '')'''.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6027
        ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6028
        self syntaxError:eMsg withCRs position:pos to:tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6029
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6030
    ].
1640
261459ccc704 emphasize parenthesis nesting
Claus Gittinger <cg@exept.de>
parents: 1638
diff changeset
  6031
    self markParenthesisAt:tokenPosition.
261459ccc704 emphasize parenthesis nesting
Claus Gittinger <cg@exept.de>
parents: 1638
diff changeset
  6032
    parenthesisLevel := parenthesisLevel - 1.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6033
    self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6034
    (self noAssignmentAllowed:'invalid assignment' at:pos) ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6035
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6036
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6037
    val parenthized:true.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6038
    ^ val
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6039
!
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6040
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6041
primary_false
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6042
    "parse a false primary; return a node-tree, or raise an Error."
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6043
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6044
    |pos|
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6045
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6046
    pos := tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6047
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6048
    self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6049
    (self noAssignmentAllowed:'assignment to ''false''' at:pos) ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6050
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6051
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6052
    self markBooleanConstantFrom:pos to:pos+4.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6053
    ^ ConstantNode type:#False value:false
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6054
!
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6055
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6056
primary_here
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6057
    "parse a here primary; return a node-tree, nil or #Error."
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6058
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6059
    |pos|
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6060
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6061
    pos := tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6062
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6063
    self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6064
    (self noAssignmentAllowed:'assignment to pseudo variable ''here''' at:pos) ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6065
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6066
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6067
    classToCompileFor isNil ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6068
        self warning:'in which class are you ?' position:pos to:(pos + 3).
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6069
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6070
    self markSelfFrom:pos to:pos+3.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6071
    ^ SuperNode value:selfValue inClass:classToCompileFor here:true
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6072
!
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6073
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6074
primary_identifier
1638
d6c83055d28d warn about hidden variables
Claus Gittinger <cg@exept.de>
parents: 1636
diff changeset
  6075
    "parse a primary; return a node-tree, or raise an Error."
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6076
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6077
    |pos1 pos2 expr varName rawName var globlName nameSpace nameSpaceGlobal
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6078
     t cls lnr node holder autoHow assignmentAllowed|
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6079
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6080
    pos1 := tokenPosition.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6081
    pos2 := tokenPosition + tokenName size - 1.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6082
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6083
    varName := tokenName.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6084
1440
7084ae99ced7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1439
diff changeset
  6085
    (self isDoIt 
1342
65f8f4d0ce09 only autoDefine workspace vars on the top level (i.e. not within blocks)
Claus Gittinger <cg@exept.de>
parents: 1341
diff changeset
  6086
    and:[currentBlock isNil
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6087
    and:[(requestor askFor:#isWorkspace)
1359
af2b37656df3 autoDefine as doIt added
Claus Gittinger <cg@exept.de>
parents: 1351
diff changeset
  6088
    and:[(autoHow := requestor autoDefineVariables) notNil]]]) ifTrue:[
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6089
        var := self variableOrError:varName.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6090
        self nextToken.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6091
        (var == #Error) ifTrue:[
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6092
            ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
1359
af2b37656df3 autoDefine as doIt added
Claus Gittinger <cg@exept.de>
parents: 1351
diff changeset
  6093
                autoHow == #workspace ifTrue:[
af2b37656df3 autoDefine as doIt added
Claus Gittinger <cg@exept.de>
parents: 1351
diff changeset
  6094
                    holder := Workspace addWorkspaceVariable:varName.
af2b37656df3 autoDefine as doIt added
Claus Gittinger <cg@exept.de>
parents: 1351
diff changeset
  6095
                    var := VariableNode type:#WorkspaceVariable holder:holder name:varName
af2b37656df3 autoDefine as doIt added
Claus Gittinger <cg@exept.de>
parents: 1351
diff changeset
  6096
                ] ifFalse:[
af2b37656df3 autoDefine as doIt added
Claus Gittinger <cg@exept.de>
parents: 1351
diff changeset
  6097
                    holder := self addDoItTemporary:varName.
af2b37656df3 autoDefine as doIt added
Claus Gittinger <cg@exept.de>
parents: 1351
diff changeset
  6098
                    var := VariableNode type:#DoItTemporary holder:holder name:varName
af2b37656df3 autoDefine as doIt added
Claus Gittinger <cg@exept.de>
parents: 1351
diff changeset
  6099
                ].
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6100
            ] ifFalse:[
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6101
                var := self correctVariable:varName atPosition:pos1 to:pos2.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6102
            ].
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6103
        ]
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6104
    ] ifFalse:[
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6105
        var := self variable.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6106
        self nextToken.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6107
    ].
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6108
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6109
    "/ errorFlag == true ifTrue:[self halt].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6110
    (var == #Error) ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6111
        errorFlag := true
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6112
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6113
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6114
    (tokenType == #'::') ifTrue:[
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6115
        globlName := rawName := varName.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6116
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6117
        "is it in a namespace ?"
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6118
        nameSpace := self findNameSpaceWith:globlName.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6119
        nameSpace notNil ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6120
            globlName := nameSpace name , '::' , globlName
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6121
        ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6122
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6123
        [tokenType == #'::'] whileTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6124
            nameSpace := globlName.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6125
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6126
            self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6127
            (tokenType == #Identifier) ifTrue:[
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  6128
                self warnSTXNameSpaceUseAt:pos1.
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6129
                varName := tokenName.
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6130
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6131
                globlName := (nameSpace , '::' , varName).
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6132
                rawName := (rawName , '::' , varName).
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6133
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6134
                nameSpaceGlobal := Smalltalk at:nameSpace asSymbol ifAbsent:nil.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6135
                nameSpaceGlobal isNil ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6136
                    warnedUnknownNamespaces isNil ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6137
                        warnedUnknownNamespaces := Set new.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6138
                    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6139
                    (warnedUnknownNamespaces includes:nameSpace) ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6140
                        self warning:('unknown nameSpace: ', nameSpace) 
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6141
                             position:pos1 to:tokenPosition-1.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6142
"/                            self parseError:('unknown nameSpace: ', nameSpace) position:pos to:tokenPosition-1.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6143
                        warnedUnknownNamespaces add:nameSpace.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6144
                    ]
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6145
                ] ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6146
                    nameSpaceGlobal isNameSpace ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6147
                        "/ for now: only Smalltalk is allowed
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6148
                        nameSpaceGlobal ~~ Smalltalk ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6149
"/                                self parseError:('(currently) the only valid nameSpace is `Smalltalk''') position:pos to:tokenPosition-1.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6150
                        ] ifFalse:[
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6151
                            globlName := varName
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6152
                        ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6153
                    ] ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6154
                        nameSpaceGlobal isBehavior ifFalse:[
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6155
                            self parseError:('invalid nameSpace: ' , nameSpace)  position:pos1 to:tokenPosition-1.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6156
                        ] ifTrue:[
1391
6139f0c7abf3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1386
diff changeset
  6157
                            nameSpaceGlobal isLoaded ifTrue:[
6139f0c7abf3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1386
diff changeset
  6158
                                (nameSpaceGlobal privateClassesAt:varName asSymbol) isNil ifTrue:[
1570
8ce7594e9b55 copyright
Claus Gittinger <cg@exept.de>
parents: 1569
diff changeset
  6159
                                    (Smalltalk at:rawName asSymbol) notNil ifTrue:[
8ce7594e9b55 copyright
Claus Gittinger <cg@exept.de>
parents: 1569
diff changeset
  6160
                                        self warning:('Possible name clash (global: ' , rawName , ' vs. private: ' , (nameSpace , '::', varName) , ') - assume globl.') 
8ce7594e9b55 copyright
Claus Gittinger <cg@exept.de>
parents: 1569
diff changeset
  6161
                                             position:pos1 to:tokenPosition-1.
8ce7594e9b55 copyright
Claus Gittinger <cg@exept.de>
parents: 1569
diff changeset
  6162
                                        globlName := rawName asSymbol.
8ce7594e9b55 copyright
Claus Gittinger <cg@exept.de>
parents: 1569
diff changeset
  6163
                                    ] ifFalse:[
8ce7594e9b55 copyright
Claus Gittinger <cg@exept.de>
parents: 1569
diff changeset
  6164
                                        self warning:('no private class: ' , varName , ' in class: ' , nameSpace) 
8ce7594e9b55 copyright
Claus Gittinger <cg@exept.de>
parents: 1569
diff changeset
  6165
                                             position:pos1 to:tokenPosition-1.
1391
6139f0c7abf3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1386
diff changeset
  6166
"/                                        self parseError:('no private class: ' , name , ' in class: ' , nameSpace)  position:pos to:tokenPosition-1.                                
1570
8ce7594e9b55 copyright
Claus Gittinger <cg@exept.de>
parents: 1569
diff changeset
  6167
                                    ]
1391
6139f0c7abf3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1386
diff changeset
  6168
                                ]
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6169
                            ]
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6170
                        ]
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6171
                    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6172
                ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6173
                self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6174
            ].
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  6175
            var := VariableNode globalNamed:globlName.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6176
            parseForCode ifFalse:[self rememberGlobalUsed:globlName].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6177
        ].
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6178
        self markVariable:var from:pos1 to:pos1 + rawName size - 1.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6179
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6180
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6181
    var == #Error ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6182
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6183
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6184
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6185
    errorFlag ~~ true ifTrue:[
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6186
        self markVariable:var from:pos1 to:pos1 + varName size - 1.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6187
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6188
    (ignoreErrors or:[ignoreWarnings or:[parseForCode not]]) ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6189
        errorFlag := false.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6190
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6191
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6192
    ((tokenType ~~ $_) and:[tokenType ~~ #':=']) ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6193
        parseForCode ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6194
            var isInstanceVariable ifTrue:[ self rememberInstVarRead:var name].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6195
            var isClassVariable ifTrue:[ self rememberClassVarRead:var name].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6196
        ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6197
        ^ var
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6198
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6199
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6200
    "/ assignment...
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6201
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6202
    "/ careful: it could already be an implicit self send
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  6203
    parserFlags implicitSelfSends ifTrue:[
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6204
        var isMessage ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6205
            self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6206
            expr := self expression.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6207
            self isSyntaxHighlighter ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6208
                (errorFlag or:[expr == #Error]) ifTrue:[^ #Error].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6209
            ].
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6210
            ^ MessageNode receiver:(self selfNode) selector:('__' , varName , ':') asSymbol arg:expr.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6211
        ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6212
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6213
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6214
    assignmentAllowed := true.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6215
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6216
    (var ~~ #Error) ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6217
        t := var type.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6218
        t == #MethodVariable ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6219
            modifiedLocalVars isNil ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6220
                modifiedLocalVars := Set new.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6221
            ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6222
            modifiedLocalVars add:var name.
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6223
        ] ifFalse:[ (t == #InstanceVariable) ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6224
            varName := self classesInstVarNames at:(var index).
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6225
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6226
            "/ ca once did this to "name" and wondered what happened to his class ...
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6227
            "/ (not really a beginners bug, but may happen as a typo or missing local variable;
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6228
            "/  and is hard to track down later)
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6229
1664
c49ce86307bf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1657
diff changeset
  6230
            ignoreWarnings ifFalse:[
1756
beccb048a798 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1753
diff changeset
  6231
                parserFlags warnings ifTrue:[
beccb048a798 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1753
diff changeset
  6232
                    parserFlags warnCommonMistakes ifTrue:[
beccb048a798 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1753
diff changeset
  6233
                        classToCompileFor isMeta ifTrue:[
beccb048a798 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1753
diff changeset
  6234
                            (classToCompileFor isSubclassOf:Class) ifTrue:[
beccb048a798 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1753
diff changeset
  6235
                                (Class allInstVarNames includes:(var name)) ifTrue:[
beccb048a798 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1753
diff changeset
  6236
                                    self warning:'assignment to a classInstanceVariable\(see hierarchy of "Class")' withCRs position:pos1 to:pos2.
beccb048a798 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1753
diff changeset
  6237
                                ]
1664
c49ce86307bf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1657
diff changeset
  6238
                            ]
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6239
                        ]
1756
beccb048a798 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1753
diff changeset
  6240
                    ].
1664
c49ce86307bf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1657
diff changeset
  6241
                ].
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6242
            ].
1664
c49ce86307bf *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1657
diff changeset
  6243
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6244
            parseForCode ifFalse:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6245
                modifiedInstVars isNil ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6246
                    modifiedInstVars := Set new
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6247
                ].
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6248
                modifiedInstVars add:varName
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6249
            ]
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6250
        ] ifFalse:[ (t == #ClassVariable) ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6251
            varName := var name.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6252
            varName := varName copyFrom:((varName indexOf:$:) + 1).
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6253
            parseForCode ifFalse:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6254
                modifiedClassVars isNil ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6255
                    modifiedClassVars := Set new
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6256
                ].
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6257
                modifiedClassVars add:varName
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6258
            ]
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6259
        ] ifFalse:[ (t == #GlobalVariable) ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6260
            (cls := Smalltalk classNamed:var name) notNil ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6261
                cls name = var name ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6262
                    self warning:'assignment to global which refers to a class' position:pos1 to:pos2.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6263
                ]
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6264
            ].
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6265
            parseForCode ifFalse:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6266
                modifiedGlobals isNil ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6267
                    modifiedGlobals := Set new
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6268
                ].
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6269
                modifiedGlobals add:var name
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6270
            ]
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6271
        ] ifFalse:[ 
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6272
            (t == #PrivateClass) ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6273
                assignmentAllowed := false.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6274
                self parseError:'assignment to private class' position:pos1 to:pos2.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6275
            ] ifFalse:[ (t == #MethodArg) ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6276
                assignmentAllowed := false.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6277
                self parseError:'assignment to method argument' position:pos1 to:pos2.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6278
            ] ifFalse:[ (t == #BlockArg) ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6279
                assignmentAllowed := false.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6280
                self parseError:'assignment to block argument' position:pos1 to:pos2.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6281
            ] ifFalse:[ (t == #PoolVariable) ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6282
                self isDoIt ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6283
                    self warning:'assignment to pool variable' position:pos1 to:pos2.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6284
                    assignmentAllowed := true.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6285
                ] ifFalse:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6286
                    self parseError:'assignment to pool variable' position:pos1 to:pos2.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6287
                ]
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6288
            ]]]]]]]
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6289
        ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6290
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6291
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6292
    lnr := tokenLineNr.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6293
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6294
    self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6295
    pos2 := tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6296
    expr := self expression.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6297
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6298
    "/ a typical beginner error:
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6299
    "/   expr ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6300
    "/      var := super
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6301
    "/   ] ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6302
    "/      var := something-else
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6303
    "/   ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6304
    "/   var messageSend
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6305
    "/
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6306
    "/   does not what a beginner might think.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6307
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6308
    self isSyntaxHighlighter ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6309
        (expr == #Error) ifTrue:[^ #Error].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6310
    ] ifFalse:[
1756
beccb048a798 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1753
diff changeset
  6311
        parserFlags warnings ifTrue:[
beccb048a798 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1753
diff changeset
  6312
            parserFlags warnCommonMistakes ifTrue:[
beccb048a798 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1753
diff changeset
  6313
                (expr ~~ #Error and:[expr isSuper]) ifTrue:[
beccb048a798 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1753
diff changeset
  6314
                    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:pos1 to:pos2.
beccb048a798 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1753
diff changeset
  6315
                ].
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6316
            ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6317
        ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6318
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6319
        (errorFlag or:[expr == #Error]) ifTrue:[^ #Error].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6320
        expr isVariable ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6321
            expr name = var name ifTrue:[
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6322
                self warning:('useless assignment to "' , var name, '"' ) position:pos1 to:pos2-1.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6323
            ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6324
        ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6325
    ].
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6326
    assignmentAllowed ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6327
        node := AssignmentNode variable:var expression:expr.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6328
        (lineNumberInfo == #full) ifTrue:[node lineNumber:lnr].
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6329
    ] ifFalse:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6330
        self parseError:('assignment to "' , var name, '" suppressed' ) position:pos1 to:pos2-1.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6331
        node := expr.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6332
    ].
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6333
    ^ node
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6334
!
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6335
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6336
primary_lazyValue
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6337
    |pos block expr|
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6338
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6339
    pos := tokenPosition.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6340
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6341
    (tokenType == $: ) ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6342
        self parseError:'lazyValues have no arguments' position:tokenPosition.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6343
        ^ #Error
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6344
    ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6345
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6346
    block := self blockBody:#().
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6347
    self nextToken.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6348
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6349
    expr := MessageNode 
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  6350
                receiver:(VariableNode globalNamed:#LazyValue)
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6351
                selector:#'block:'
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6352
                arg:block.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6353
    ^ expr
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6354
!
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6355
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6356
primary_nil
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6357
    "parse a nil primary; return a node-tree, nil or #Error."
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6358
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6359
    |pos|
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6360
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6361
    pos := tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6362
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6363
    self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6364
    (self noAssignmentAllowed:'assignment to ''nil''' at:pos) ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6365
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6366
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6367
"/        self markConstantFrom:pos to:pos+2.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6368
    nilNode isNil ifTrue:[ 
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6369
        nilNode := ConstantNode type:#Nil value:nil
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6370
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6371
    ^ nilNode
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6372
!
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6373
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6374
primary_self
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6375
    "parse a self primary; return a node-tree, nil or #Error."
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6376
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6377
    |pos|
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6378
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6379
    pos := tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6380
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6381
    self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6382
    (self noAssignmentAllowed:'assignment to pseudo variable ''self''' at:pos) ifFalse:[
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  6383
        ^ ParseError raiseErrorString:'Assignment to self'.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6384
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6385
    self markSelfFrom:pos to:pos+3.
1262
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6386
    ^ self selfNode
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  6387
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  6388
    "Modified: / 22-08-2006 / 13:42:44 / cg"
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6389
!
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6390
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6391
primary_simpleLiteral
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6392
    "parse a simple literal primary; return a node-tree, or raise an Error."
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6393
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6394
    |pos val|
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6395
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6396
    pos := tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6397
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6398
    "/
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6399
    "/ ImmutableStrings are experimental
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6400
    "/
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6401
    ((tokenType == #String)
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  6402
    and:[(parserFlags stringsAreImmutable)]) ifTrue:[
1615
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  6403
        token := tokenValue := self makeImmutableString:tokenValue.
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6404
    ].
1657
451328cc3264 ESSymbols
Claus Gittinger <cg@exept.de>
parents: 1654
diff changeset
  6405
451328cc3264 ESSymbols
Claus Gittinger <cg@exept.de>
parents: 1654
diff changeset
  6406
    ((tokenType == #Symbol) or:[tokenType == #ESSymbol]) ifTrue:[
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6407
        parseForCode ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6408
            self rememberSymbolUsed:tokenValue
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6409
        ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6410
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6411
    val := ConstantNode type:tokenType value:tokenValue.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6412
1683
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  6413
    ((tokenType == #Symbol) or:[tokenType == #ESSymbol]) ifTrue:[
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6414
        self markSymbolFrom:tokenPosition to:tokenPosition+tokenValue size-1.
1683
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  6415
    ] ifFalse:[
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  6416
        tokenType == #String ifTrue:[
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  6417
            self markStringFrom:pos to:source position1Based-1.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  6418
        ] ifFalse:[
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  6419
            self markConstantFrom:pos to:source position1Based-1.
faa80a7dac3d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1675
diff changeset
  6420
        ].
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6421
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6422
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6423
    self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6424
    (self noAssignmentAllowed:'assignment to a constant' at:pos) ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6425
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6426
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6427
    ^ val
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6428
!
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6429
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6430
primary_squeakComputedArray
1274
7d4a3391a81a comments
Claus Gittinger <cg@exept.de>
parents: 1273
diff changeset
  6431
    "parse a squeak computed array literal; return a node-tree, or raise an Error.
7d4a3391a81a comments
Claus Gittinger <cg@exept.de>
parents: 1273
diff changeset
  6432
     In squeak, these are written as: { expr1 . expr2 . ... exprN )
1762
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  6433
     and create a message to construct an Array containing the exprI values.
1274
7d4a3391a81a comments
Claus Gittinger <cg@exept.de>
parents: 1273
diff changeset
  6434
     WARNING: this is only supported to allow filing in squeak code.
7d4a3391a81a comments
Claus Gittinger <cg@exept.de>
parents: 1273
diff changeset
  6435
     since stc cannot handle this (at the moment), you should rewrite the code
7d4a3391a81a comments
Claus Gittinger <cg@exept.de>
parents: 1273
diff changeset
  6436
     if you ever plan to stc-compile it into a shared library"
7d4a3391a81a comments
Claus Gittinger <cg@exept.de>
parents: 1273
diff changeset
  6437
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6438
1271
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  6439
    |pos exprList|
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6440
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6441
    pos := tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6442
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6443
    self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6444
    exprList := self squeakComputedArray.
1277
f7c21ebe1520 squeak computed arrays again
Claus Gittinger <cg@exept.de>
parents: 1276
diff changeset
  6445
    (exprList == #Error) ifTrue:[ ^ #Error ].
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6446
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6447
    tokenType ~~ $} ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6448
        self parseError:'''}'' expected' position:tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6449
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6450
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6451
    self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6452
    (self noAssignmentAllowed:'invalid assignment' at:pos) ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6453
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6454
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6455
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6456
    "/ make it an array creation expression ...
1271
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  6457
    ^ self genMakeArrayWith:exprList
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  6458
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  6459
    "
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  6460
     Compiler allowSqueakExtensions:true.
1299
6c182cd87b6c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1297
diff changeset
  6461
    "
6c182cd87b6c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1297
diff changeset
  6462
6c182cd87b6c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1297
diff changeset
  6463
    "
6c182cd87b6c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1297
diff changeset
  6464
     { 1@2. 10 factorial. Date today }.     
6c182cd87b6c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1297
diff changeset
  6465
    "
6c182cd87b6c *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1297
diff changeset
  6466
1762
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  6467
    "
1271
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  6468
     Compiler allowSqueakExtensions:false.
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  6469
    "
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6470
!
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6471
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6472
primary_super
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6473
    "parse a super primary; return a node-tree, nil or #Error."
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6474
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6475
    |pos|
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6476
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6477
    pos := tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6478
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6479
    usesSuper := true.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6480
    self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6481
    (self noAssignmentAllowed:'assignment to pseudo variable ''super''' at:pos) ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6482
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6483
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6484
    (classToCompileFor isNil or:[classToCompileFor superclass isNil]) ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6485
        self warning:'superclass is (currently ?) nil' position:pos to:(pos + 4).
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6486
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6487
    superNode isNil ifTrue:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6488
        superNode := SuperNode value:selfValue inClass:classToCompileFor
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6489
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6490
    self markSelfFrom:pos to:pos+4.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6491
    ^ superNode
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6492
!
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6493
1262
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6494
primary_thisContext
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6495
    "parse a thisContext primary; return a node-tree, or raise an Error."
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6496
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6497
    |pos|
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6498
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6499
    pos := tokenPosition.
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6500
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6501
    self nextToken.
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6502
    (self noAssignmentAllowed:'assignment to pseudo variable ''thisContext''' at:pos) ifFalse:[
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6503
        ^ #Error
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6504
    ].
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6505
    self markIdentifierFrom:pos to:pos+10.
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6506
    ^ VariableNode type:#ThisContext context:contextToEvaluateIn. "/ often nil
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6507
!
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  6508
1227
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6509
primary_true
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6510
    "parse a true primary; return a node-tree, or raise an Error."
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6511
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6512
    |pos|
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6513
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6514
    pos := tokenPosition.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6515
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6516
    self nextToken.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6517
    (self noAssignmentAllowed:'assignment to ''true''' at:pos) ifFalse:[
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6518
        ^ #Error
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6519
    ].
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6520
    self markBooleanConstantFrom:pos to:pos+3.
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6521
    ^ ConstantNode type:#True value:true
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6522
!
74d5695ce8dc dolphin compatibility;
Claus Gittinger <cg@exept.de>
parents: 1225
diff changeset
  6523
924
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6524
qualifiedName
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6525
    "a vw3.x (and later) feature: QualifiedName is #{ id ... id }
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6526
     and mapped to a global variable here.
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6527
     The initial #{ is supposed to be not yet skipped."
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6528
1436
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6529
    |elements elem pos1 nm|
924
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6530
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6531
    pos1 := tokenPosition.
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6532
    self nextToken.
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6533
    elements := OrderedCollection new.
1436
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6534
    [ tokenType ~~ $} ] whileTrue:[
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6535
        (tokenType == #Identifier) ifFalse:[
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6536
            self syntaxError:'bad qualifiedName; Identifier expected' 
924
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6537
                    position:pos1 to:tokenPosition
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6538
        ].
1436
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6539
        elem := tokenName.
924
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6540
        elements add:elem.
1028
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6541
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6542
        self nextToken.
1436
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6543
        tokenType = $} ifTrue:[
1028
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6544
        ] ifFalse:[
1436
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6545
            tokenType == #'::' ifTrue:[
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6546
                "/ notice that Foo.Bar has already been scanned as Foo::Bar
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6547
                "/(which is a kludge)
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6548
                self nextToken.
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6549
            ] ifFalse:[
1028
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6550
                self syntaxError:'bad qualifiedName syntax; ''.'' or ''}'' expected' 
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6551
                        position:pos1 to:tokenPosition.
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6552
            ].
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6553
        ].
1436
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6554
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6555
"/        elem := self variable.
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6556
"/        (elem == #Error) ifTrue:[
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6557
"/            (tokenType == #EOF) ifTrue:[
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6558
"/                self syntaxError:'unterminated qualifiedName; ''}'' expected' 
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6559
"/                        position:pos1 to:tokenPosition
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6560
"/            ].
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6561
"/            ^ #Error
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6562
"/        ].
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6563
"/        errorFlag := false.
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6564
"/        (elem isVariable and:[elem isGlobal]) ifFalse:[
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6565
"/            self warning:'elements of a qualifiedName should be globalIdentifiers' 
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6566
"/                    position:pos1 to:tokenPosition
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6567
"/        ].
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6568
"/        elements add:elem.
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6569
"/
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6570
"/        self nextToken.
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6571
"/        tokenType == #'::' ifTrue:[
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6572
"/            "/ notice that Foo.Bar has already been scanned as Foo::Bar
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6573
"/            "/(which is a kludge)
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6574
"/            self nextToken.
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6575
"/        ] ifFalse:[
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6576
"/            tokenType ~~ $} ifTrue:[
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6577
"/                self syntaxError:'bad qualifiedName syntax; ''.'' or ''}'' expected' 
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6578
"/                        position:pos1 to:tokenPosition.
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6579
"/                ^ #Error
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6580
"/            ].
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6581
"/        ].
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6582
    ].
1716
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  6583
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  6584
    parserFlags flattenVisualWorksNamespaces ifTrue:[
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  6585
        "/ temporary kludge when loading VW UIBuilder code...
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  6586
        ( #('UI' 'Core' 'Graphics') includes:elements first) ifTrue:[
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  6587
            elements := elements copyFrom:2.
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  6588
        ].
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  6589
    ].
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  6590
1437
a7a5db01ad12 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1436
diff changeset
  6591
    nm := (elements asStringWith:'::') asSymbol.
1436
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6592
    ^ ConstantNode type:#Symbol value:nm
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6593
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6594
"/    elements size > 1 ifTrue:[
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6595
"/        self syntaxError:'Sorry: qualified names are not yet implemented.'.
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6596
"/    ].
e345acd83456 qualified name stuff
Claus Gittinger <cg@exept.de>
parents: 1434
diff changeset
  6597
"/    ^ elements first.
924
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6598
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6599
    "Modified: / 14.4.1998 / 17:03:29 / cg"
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6600
!
6214afc7e312 qualifiedName support
Claus Gittinger <cg@exept.de>
parents: 921
diff changeset
  6601
894
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6602
squeakComputedArray
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6603
    |expressions elem pos1|
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6604
1275
91a0eead9e0e oops - stc bug workaround - scans keyword selectors
Claus Gittinger <cg@exept.de>
parents: 1274
diff changeset
  6605
    tokenType == $} ifTrue:[
91a0eead9e0e oops - stc bug workaround - scans keyword selectors
Claus Gittinger <cg@exept.de>
parents: 1274
diff changeset
  6606
        ^ #()
91a0eead9e0e oops - stc bug workaround - scans keyword selectors
Claus Gittinger <cg@exept.de>
parents: 1274
diff changeset
  6607
    ].
91a0eead9e0e oops - stc bug workaround - scans keyword selectors
Claus Gittinger <cg@exept.de>
parents: 1274
diff changeset
  6608
894
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6609
    pos1 := tokenPosition.
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6610
    expressions := OrderedCollection new:20.
1275
91a0eead9e0e oops - stc bug workaround - scans keyword selectors
Claus Gittinger <cg@exept.de>
parents: 1274
diff changeset
  6611
    [true] whileTrue:[
894
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6612
        elem := self expression.
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6613
        (elem == #Error) ifTrue:[
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6614
            (tokenType == #EOF) ifTrue:[
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6615
                self syntaxError:'unterminated computed-array-element; ''}'' expected' 
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6616
                        position:pos1 to:tokenPosition
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6617
            ].
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6618
            ^ #Error
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6619
        ].
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6620
        expressions add:elem.
1277
f7c21ebe1520 squeak computed arrays again
Claus Gittinger <cg@exept.de>
parents: 1276
diff changeset
  6621
        tokenType == $. ifFalse:[
894
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6622
            ^ expressions
1277
f7c21ebe1520 squeak computed arrays again
Claus Gittinger <cg@exept.de>
parents: 1276
diff changeset
  6623
        ].
f7c21ebe1520 squeak computed arrays again
Claus Gittinger <cg@exept.de>
parents: 1276
diff changeset
  6624
        self nextToken.
f7c21ebe1520 squeak computed arrays again
Claus Gittinger <cg@exept.de>
parents: 1276
diff changeset
  6625
        tokenType == $} ifTrue:[
f7c21ebe1520 squeak computed arrays again
Claus Gittinger <cg@exept.de>
parents: 1276
diff changeset
  6626
            ^ expressions
f7c21ebe1520 squeak computed arrays again
Claus Gittinger <cg@exept.de>
parents: 1276
diff changeset
  6627
        ].
894
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6628
    ].
1275
91a0eead9e0e oops - stc bug workaround - scans keyword selectors
Claus Gittinger <cg@exept.de>
parents: 1274
diff changeset
  6629
    "/ not reached
894
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6630
!
943b6d0d26b3 changes to support loading squeak code containing computed
Claus Gittinger <cg@exept.de>
parents: 887
diff changeset
  6631
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6632
unaryExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6633
    "parse a unary-expression; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6634
1328
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  6635
    |receiver|
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6636
1405
f888caa1f2d8 refactored primitive-decl parsing;
Claus Gittinger <cg@exept.de>
parents: 1400
diff changeset
  6637
    receiver := self arrayIndexingExpression.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6638
    (receiver == #Error) ifTrue:[^ #Error].
1328
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  6639
    ^ self unaryExpressionFor:receiver
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  6640
!
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  6641
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  6642
unaryExpressionFor:receiverArg
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  6643
    "parse a unary-expression; return a node-tree, nil or #Error"
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  6644
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6645
    |receiver expr sel pos pos2 note lNr arguments|
1328
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  6646
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  6647
    receiver := receiverArg.
af0a47799078 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 1327
diff changeset
  6648
    (receiver == #Error) ifTrue:[^ #Error].
1776
65df22979f49 plausibilityCheck of unary expression fixed
Claus Gittinger <cg@exept.de>
parents: 1774
diff changeset
  6649
1306
90f45715a0d7 optionally allow nil, true, false etc. as unary selector
Claus Gittinger <cg@exept.de>
parents: 1304
diff changeset
  6650
    [ self isValidUnarySelector:tokenType ] whileTrue:[
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  6651
        pos := tokenPosition.
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  6652
        pos2 := pos + tokenName size - 1.
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6653
        lNr := tokenLineNr.
977
c1afbaf48a23 remember used & modified local vars;
Claus Gittinger <cg@exept.de>
parents: 971
diff changeset
  6654
        sel := tokenName.
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6655
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6656
        self markSelector:sel from:pos to:pos2 receiverNode:receiver.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6657
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6658
        self nextToken.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6659
        tokenType == $( ifTrue:[
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  6660
            parserFlags allowSqueakExtensions == true ifTrue:[
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6661
                "/ croquet/squeak extension - c/java-style arguments
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6662
                arguments := self functionCallArgList.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6663
                "/ synthetic selector: foo[:[with:[with:[...]]]]
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6664
                arguments notEmpty ifTrue:[
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6665
                    sel := sel , ':'.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6666
                    arguments size - 1 timesRepeat:[ sel := sel , 'with:' ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6667
                ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6668
                sel := self selectorCheck:sel for:receiver position:pos to:pos2.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6669
                expr := MessageNode receiver:receiver selector:sel args:arguments fold:foldConstants.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6670
                expr isErrorNode ifTrue:[
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6671
                    self parseError:(expr errorString) position:pos to:pos2.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6672
                    errorFlag := false. "ok, user wants it - so he'll get it"
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6673
                    expr := MessageNode receiver:receiver selector:sel args:arguments fold:nil.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6674
                ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6675
                expr lineNumber:lNr.
1687
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  6676
                (ignoreErrors or:[ignoreWarnings]) ifFalse:[
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  6677
                    note := self plausibilityCheck:receiver.
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  6678
                    note notNil ifTrue:[
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  6679
                        self warning:note position:pos to:pos2
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  6680
                    ].
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6681
                ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6682
                parseForCode ifFalse:[
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6683
                    self rememberSelectorUsed:sel receiver:receiver
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6684
                ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6685
                ^ expr.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6686
            ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6687
        ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6688
1022
32bc5fc06687 added selector correction.
Claus Gittinger <cg@exept.de>
parents: 1020
diff changeset
  6689
        sel := self selectorCheck:sel for:receiver position:pos to:pos2.
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6690
        expr := UnaryNode receiver:receiver selector:sel fold:foldConstants.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6691
        expr isErrorNode ifTrue:[
1675
7812281ecfbd some errors are really warnings.
Claus Gittinger <cg@exept.de>
parents: 1664
diff changeset
  6692
            self warning:(expr errorString , '.\\If you proceed, that error will happen at runtime.') withCRs position:pos to:pos2.
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  6693
            errorFlag := false. "ok, user wants it - so he'll get it"
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6694
            expr := UnaryNode receiver:receiver selector:sel fold:nil.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6695
        ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6696
        expr lineNumber:lNr.
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6697
1687
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  6698
        (ignoreErrors or:[ignoreWarnings]) ifFalse:[
1776
65df22979f49 plausibilityCheck of unary expression fixed
Claus Gittinger <cg@exept.de>
parents: 1774
diff changeset
  6699
            note := self plausibilityCheck:expr.
1687
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  6700
            note notNil ifTrue:[
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  6701
                self warning:note position:pos to:pos2
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  6702
            ].
1193
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  6703
        ].
1060
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  6704
        parseForCode ifFalse:[
1531
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6705
            self rememberSelectorUsed:sel receiver:receiver
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6706
        ].
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6707
47f714bc1981 squeak extension: c/java style arguments
Claus Gittinger <cg@exept.de>
parents: 1525
diff changeset
  6708
        receiver := expr.   "/ for next message
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6709
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6710
    ^ receiver
210
b22f4472833b allow enable/disable of constantFolding
Claus Gittinger <cg@exept.de>
parents: 207
diff changeset
  6711
1776
65df22979f49 plausibilityCheck of unary expression fixed
Claus Gittinger <cg@exept.de>
parents: 1774
diff changeset
  6712
    "Modified: / 16-07-2006 / 16:15:22 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6713
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6714
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6715
variable
1028
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6716
    "parse a simple (i.e. non-namespace-access path) variable; 
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6717
     return a node-tree, nil or #Error.
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6718
     Does not advance to next token.
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6719
     If undefined, notify error and correct if user wants to"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6720
864
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  6721
    |v pos1 pos2|
687
27565829b5d4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 685
diff changeset
  6722
454
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  6723
    v := self variableOrError:tokenName.
664
63d1460e8ee3 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 663
diff changeset
  6724
    (v ~~ #Error) ifTrue:[
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  6725
        (v isMemberOf:VariableNode) ifTrue:[
687
27565829b5d4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 685
diff changeset
  6726
            self markVariable:v.
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  6727
        ].
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  6728
        ^ v
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  6729
    ].
865
580b3f73021b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 864
diff changeset
  6730
687
27565829b5d4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 685
diff changeset
  6731
    pos1 := tokenPosition.
864
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  6732
    pos2 := pos1+tokenName size-1.
a716d90fa5a9 better selector marking
Claus Gittinger <cg@exept.de>
parents: 837
diff changeset
  6733
    self markUnknownIdentifierFrom:pos1 to:pos2.
664
63d1460e8ee3 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 663
diff changeset
  6734
1089
ac7a3f73e18f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1087
diff changeset
  6735
    parseForCode == true ifTrue:[    
1337
b558251f5e77 function call is now compiled into an #eval: message
Claus Gittinger <cg@exept.de>
parents: 1336
diff changeset
  6736
        v := self correctVariable:tokenName atPosition:pos1 to:pos2.
1089
ac7a3f73e18f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1087
diff changeset
  6737
        (v ~~ #Error) ifTrue:[^ v].
ac7a3f73e18f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1087
diff changeset
  6738
    ].
ac7a3f73e18f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1087
diff changeset
  6739
1564
fa3538426964 empty expression -> nil handling
Claus Gittinger <cg@exept.de>
parents: 1562
diff changeset
  6740
    self errorFlag:true.
664
63d1460e8ee3 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 663
diff changeset
  6741
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6742
    parseForCode ifFalse:[
1304
ade15708e7c1 undeclared variable handling was broken (to allow reference search)
penk
parents: 1301
diff changeset
  6743
        self rememberGlobalUsed:(Smalltalk undeclaredPrefix) , tokenName.
ade15708e7c1 undeclared variable handling was broken (to allow reference search)
penk
parents: 1301
diff changeset
  6744
        self rememberGlobalUsed:tokenName.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6745
    ] ifTrue:[
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  6746
        tokenName first isLowercase ifTrue:[
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  6747
            parserFlags implicitSelfSends ifTrue:[
1271
47c443af9bb9 better code for squeak computed array;
Claus Gittinger <cg@exept.de>
parents: 1262
diff changeset
  6748
                ^ UnaryNode receiver:(self selfNode) selector:('__' , tokenName) asSymbol.
663
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  6749
            ].
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  6750
            ^ #Error
6c6a20f144ea more syntaxHighlighting
Claus Gittinger <cg@exept.de>
parents: 660
diff changeset
  6751
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6752
    ].
865
580b3f73021b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 864
diff changeset
  6753
869
c483b1e6a0c3 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 866
diff changeset
  6754
"/    self markGlobalIdentifierFrom:pos1 to:pos2.
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  6755
    ^ VariableNode globalNamed:tokenName
454
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  6756
687
27565829b5d4 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 685
diff changeset
  6757
    "Modified: / 16.4.1998 / 18:46:45 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6758
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  6759
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6760
variableOrError
1028
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6761
    "parse a simple (i.e. non-namespace-access path) variable; 
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6762
     return a node-tree, nil or #Error.
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6763
     Does not advance to next token."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6764
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  6765
    ^ self variableOrError:tokenName
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  6766
!
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  6767
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  6768
variableOrError:varName
1028
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6769
    "parse a simple (i.e. non-namespace-access path) variable; 
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6770
     return a node-tree, nil or #Error.
cbdce68d87f6 fixed qualifiedName parsing
Claus Gittinger <cg@exept.de>
parents: 1025
diff changeset
  6771
     Does not advance to next token."
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  6772
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6773
    |varIndex aClass searchBlock args vars sharedPools
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  6774
     tokenSymbol space classVarIndex holder node|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6775
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6776
    "is it a block-arg or block-var ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6777
    searchBlock := currentBlock.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6778
    [searchBlock notNil] whileTrue:[
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6779
        vars := searchBlock variables.
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6780
        vars notNil ifTrue:[
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6781
            varIndex := vars findFirst:[:aBlockVar | aBlockVar name = varName].
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6782
            varIndex ~~ 0 ifTrue:[
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6783
                ^ VariableNode type:#BlockVariable
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6784
                               name:varName
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6785
                              token:(vars at:varIndex)
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6786
                              index:varIndex
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6787
                              block:searchBlock
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6788
                               from:currentBlock
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6789
            ].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6790
        ].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6791
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6792
        args := searchBlock arguments.
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6793
        args notNil ifTrue:[
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6794
            varIndex := args findFirst:[:aBlockArg | aBlockArg name = varName].
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6795
            varIndex ~~ 0 ifTrue:[
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6796
                ^ VariableNode type:#BlockArg
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6797
                               name:varName
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6798
                              token:(args at:varIndex)
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6799
                              index:varIndex
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6800
                              block:searchBlock
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6801
                               from:currentBlock 
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6802
            ].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6803
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6804
        ].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6805
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6806
        searchBlock := searchBlock home
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6807
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6808
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6809
    "is it a method-variable ?"
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  6810
    (node := self nodeForMethodVariable:varName) notNil
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  6811
    ifTrue:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  6812
        ^ node
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6813
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6814
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6815
    "is it a method-argument ?"
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  6816
    (node := self nodeForMethodArg:varName) notNil
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  6817
    ifTrue:[
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  6818
        ^ node
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6819
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6820
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6821
    contextToEvaluateIn notNil ifTrue:[
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6822
        |con varNames|
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6823
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6824
        "/ 
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6825
        "/ search names of the context.
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6826
        "/ 
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6827
        con := contextToEvaluateIn.
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6828
        [con notNil] whileTrue:[
1446
ac887ee4881a ** changed access to blockContexts source, args and vars -- please watch out
penk
parents: 1445
diff changeset
  6829
            varNames := con argAndVarNames.
690
936f55e3cc17 care for empty varNames
Claus Gittinger <cg@exept.de>
parents: 688
diff changeset
  6830
            varNames size > 0 ifTrue:[
936f55e3cc17 care for empty varNames
Claus Gittinger <cg@exept.de>
parents: 688
diff changeset
  6831
                varIndex := varNames lastIndexOf:varName.
936f55e3cc17 care for empty varNames
Claus Gittinger <cg@exept.de>
parents: 688
diff changeset
  6832
                varIndex ~~ 0 ifTrue:[
936f55e3cc17 care for empty varNames
Claus Gittinger <cg@exept.de>
parents: 688
diff changeset
  6833
                    ^ VariableNode type:#ContextVariable
936f55e3cc17 care for empty varNames
Claus Gittinger <cg@exept.de>
parents: 688
diff changeset
  6834
                                   name:varName
936f55e3cc17 care for empty varNames
Claus Gittinger <cg@exept.de>
parents: 688
diff changeset
  6835
                                context:con
936f55e3cc17 care for empty varNames
Claus Gittinger <cg@exept.de>
parents: 688
diff changeset
  6836
                                  index:varIndex
936f55e3cc17 care for empty varNames
Claus Gittinger <cg@exept.de>
parents: 688
diff changeset
  6837
                ].
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6838
            ].
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6839
            con := con home.
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6840
        ].
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6841
    ].
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6842
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6843
    classToCompileFor notNil ifTrue:[
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6844
        "is it an instance-variable ?"
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6845
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6846
        varIndex := (self classesInstVarNames) lastIndexOf:varName.
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6847
        varIndex ~~ 0 ifTrue:[
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6848
            classToCompileFor isMeta ifTrue:[
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6849
                classVarIndex := (self classesClassVarNames) lastIndexOf:varName.
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6850
                classVarIndex ~~ 0 ifTrue:[
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6851
                    "/ give a warning - that maybe a common error
825
ff00fb46342f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 822
diff changeset
  6852
                    alreadyWarnedClassInstVarRefs isNil ifTrue:[
ff00fb46342f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 822
diff changeset
  6853
                        alreadyWarnedClassInstVarRefs := Set new
ff00fb46342f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 822
diff changeset
  6854
                    ].
ff00fb46342f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 822
diff changeset
  6855
                    (alreadyWarnedClassInstVarRefs includes:varName) ifFalse:[
ff00fb46342f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 822
diff changeset
  6856
                        self warning:('there is both a class variable and a class-instance variable named ''' , varName , '''.\\Refering to the class-instance variable here.') withCRs.
ff00fb46342f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 822
diff changeset
  6857
                        alreadyWarnedClassInstVarRefs add:varName.
ff00fb46342f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 822
diff changeset
  6858
                    ].
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6859
                ].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6860
            ].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6861
            parseForCode ifFalse:[self rememberInstVarUsed:varName].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6862
            ^ VariableNode type:#InstanceVariable 
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6863
                           name:varName
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6864
                          index:varIndex
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6865
                      selfValue:selfValue
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6866
        ].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6867
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6868
        "/ see if there is a corresponding classVar (for the warning)
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6869
        classVarIndex := (self classesClassVarNames) lastIndexOf:varName.
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6870
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6871
        "/      "is it a class-instance-variable ?"
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6872
        "/
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6873
        "/ Notice:
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6874
        "/ it is no longer allowed to fetch class-instance variables
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6875
        "/ from instance methods ...
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6876
        "/ (used to be in previous ST/X versions)
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6877
        "/
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6878
        varIndex := (self classesClassInstVarNames) lastIndexOf:varName.
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6879
        varIndex ~~ 0 ifTrue:[
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6880
            aClass := self inWhichClassIsClassInstVar:varName.
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6881
            aClass notNil ifTrue:[
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6882
                classToCompileFor isMeta ifFalse:[
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6883
                    classVarIndex == 0 ifTrue:[
705
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  6884
                        "/ there is no corresponding classVar;
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  6885
                        "/ wants to access classInstVar ?
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  6886
                        contextToEvaluateIn notNil ifTrue:[
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  6887
                            "/ allow it in a doIt ...
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  6888
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  6889
                            ^ VariableNode type:#ClassInstanceVariable
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  6890
                                           name:varName
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  6891
                                          index:varIndex
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  6892
                                      selfClass:aClass
e22927413fe5 allow access to class-instVars from doIts;
Claus Gittinger <cg@exept.de>
parents: 694
diff changeset
  6893
                        ].
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6894
                        self parseError:'access to class-inst-var from inst method is not allowed'.
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6895
                        ^ #Error.
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6896
                    ] ifFalse:[
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6897
                        "/ give a warning - that maybe a common error
738
2c85becd8697 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 735
diff changeset
  6898
                        self warning:('there is both a class variable and a class-instance variable named ''' , varName , '''.\\Refering to the class variable here (instMethods dont see classInstVars).') withCRs.
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6899
                    ]
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6900
                ].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6901
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6902
"/ OLD CODE:
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6903
"/ self warning:'access to class-inst-var from inst method will soon be no longer supported'.
443
e7d0bad68d60 oops - previous versions allowed access to class-instance variables
Claus Gittinger <cg@exept.de>
parents: 432
diff changeset
  6904
"/
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6905
"/                    parseForCode ifFalse:[self rememberClassVarUsed:varName].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6906
"/                    ^ VariableNode type:#ClassInstanceVariable
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6907
"/                                   name:varName
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6908
"/                                  index:varIndex
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6909
"/                              selfClass:aClass
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6910
"/                ].
732
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  6911
            ] ifFalse:[
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  6912
                "/ self halt:'oops - should not happen'.
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6913
            ]
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6914
        ].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6915
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6916
        "is it a class-variable ?"
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6917
640
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6918
        varIndex := classVarIndex.
c3be1ba89df0 handle passed-in context (for evaluation in the debuggers code-frame)
Claus Gittinger <cg@exept.de>
parents: 637
diff changeset
  6919
        varIndex ~~ 0 ifTrue:[
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6920
            aClass := self inWhichClassIsClassVar:varName.
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6921
            aClass notNil ifTrue:[
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6922
                parseForCode ifFalse:[self rememberClassVarUsed:varName].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6923
                ^ VariableNode type:#ClassVariable class:aClass name:varName
732
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  6924
            ].
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  6925
            "/ self halt:'oops - should not happen'.
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6926
        ].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6927
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6928
        "is it a private-class ?"
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6929
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  6930
        aClass := self classToLookForClassVars.
1212
082618467e2c isMeta/soleInstance -> theMetaclass / theNonMetaclass
Claus Gittinger <cg@exept.de>
parents: 1207
diff changeset
  6931
        aClass := aClass theNonMetaclass.
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6932
        (aClass privateClassesAt:varName) notNil ifTrue:[
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6933
            parseForCode ifFalse:[self rememberGlobalUsed:(aClass name , '::' , varName)].
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6934
            ^ VariableNode type:#PrivateClass class:aClass name:varName
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6935
        ].
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6936
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6937
        " is it a pool-variable ?"
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6938
        sharedPools := classToCompileFor theNonMetaclass sharedPools.
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6939
        sharedPools notNil ifTrue:[
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6940
            sharedPools do:[:eachPoolName |
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6941
                |sharedPool|
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6942
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6943
                sharedPool := Smalltalk classNamed:eachPoolName.
1556
ce528f32646b care for missing pools
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
  6944
                sharedPool isNil ifTrue:[
1692
fd06df690316 send sharedPool error messages to the Transcript (for now)
Claus Gittinger <cg@exept.de>
parents: 1690
diff changeset
  6945
                    Transcript showCR:'No such pool: ' , eachPoolName.
fd06df690316 send sharedPool error messages to the Transcript (for now)
Claus Gittinger <cg@exept.de>
parents: 1690
diff changeset
  6946
"/                    self warning:('No such pool: ' , eachPoolName).
1556
ce528f32646b care for missing pools
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
  6947
                ] ifFalse:[
ce528f32646b care for missing pools
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
  6948
                    (sharedPool includesKey:varName) ifTrue:[
ce528f32646b care for missing pools
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
  6949
                        parseForCode ifFalse:[self rememberGlobalUsed:(sharedPool name , ':' , varName)].
ce528f32646b care for missing pools
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
  6950
                        ^ VariableNode type:#PoolVariable class:sharedPool name:varName
ce528f32646b care for missing pools
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
  6951
                    ].
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6952
                ].
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6953
            ].
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  6954
        ].
418
6a3d240e7db6 namespace support
Claus Gittinger <cg@exept.de>
parents: 412
diff changeset
  6955
    ].
6a3d240e7db6 namespace support
Claus Gittinger <cg@exept.de>
parents: 412
diff changeset
  6956
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  6957
    "is it in a namespace ?"
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  6958
    space := self findNameSpaceWith:varName.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  6959
    space notNil ifTrue:[
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6960
        space ~~ Smalltalk ifTrue:[
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6961
            parseForCode ifFalse:[self rememberGlobalUsed:(space name , '::' , varName)].
1042
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  6962
            space isNameSpace ifTrue:[
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  6963
                ^ VariableNode globalNamed:(space name , '::' , varName)
1212
082618467e2c isMeta/soleInstance -> theMetaclass / theNonMetaclass
Claus Gittinger <cg@exept.de>
parents: 1207
diff changeset
  6964
            ].
082618467e2c isMeta/soleInstance -> theMetaclass / theNonMetaclass
Claus Gittinger <cg@exept.de>
parents: 1207
diff changeset
  6965
            ^ VariableNode type:#PrivateClass class:space name:varName
082618467e2c isMeta/soleInstance -> theMetaclass / theNonMetaclass
Claus Gittinger <cg@exept.de>
parents: 1207
diff changeset
  6966
        ].
082618467e2c isMeta/soleInstance -> theMetaclass / theNonMetaclass
Claus Gittinger <cg@exept.de>
parents: 1207
diff changeset
  6967
        parseForCode ifFalse:[self rememberGlobalUsed:varName].
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  6968
        ^ VariableNode globalNamed:varName
454
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  6969
    ].
00a079c9832f handle uses: usedNameSpace info
Claus Gittinger <cg@exept.de>
parents: 451
diff changeset
  6970
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6971
    "is it a global-variable ?"
63
c30ce56de7a8 *** empty log message ***
claus
parents: 62
diff changeset
  6972
    tokenSymbol := varName asSymbolIfInterned.
c30ce56de7a8 *** empty log message ***
claus
parents: 62
diff changeset
  6973
    tokenSymbol notNil ifTrue:[
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6974
        (Smalltalk includesKey:tokenSymbol) ifTrue:[
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6975
            parseForCode ifFalse:[self rememberGlobalUsed:varName].
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  6976
            ^ VariableNode globalNamed:tokenSymbol
628
54fa351ac6be *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 624
diff changeset
  6977
        ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  6978
    ].
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  6979
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  6980
    "is it a workspace variable ?"
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  6981
    (requestor notNil and:[requestor isStream not]) ifTrue:[
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  6982
        "/ when parsing doits, this is done twice;
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  6983
        "/ first, for the parse, then as a block-code
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  6984
        "/ for the code.
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  6985
        "/ We only care for WorkspaceVars in doIts
1440
7084ae99ced7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1439
diff changeset
  6986
        (self isDoIt) ifTrue:[
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6987
            (Workspace notNil 
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6988
            and:[(holder := Workspace workspaceVariableAt:varName) notNil])
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6989
            ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6990
                ^ VariableNode type:#WorkspaceVariable holder:holder name:varName
877
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  6991
            ]
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  6992
        ]
e75488a39c46 workspace variables.
Claus Gittinger <cg@exept.de>
parents: 869
diff changeset
  6993
    ].
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6994
    "is it a doIt variable ?"
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6995
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6996
"/    (requestor notNil and:[requestor isStream not]) ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6997
        "/ when parsing doits, this is done twice;
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6998
        "/ first, for the parse, then as a block-code
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  6999
        "/ for the code.
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  7000
        "/ We only care for WorkspaceVars in doIts
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  7001
1440
7084ae99ced7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1439
diff changeset
  7002
        (self isDoIt) ifTrue:[
1295
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  7003
            (doItTemporaries notNil 
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  7004
            and:[(holder := doItTemporaries at:varName asSymbol ifAbsent:nil) notNil]) 
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  7005
            ifTrue:[
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  7006
                ^ VariableNode type:#DoItTemporary holder:holder name:varName
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  7007
            ]
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  7008
        ].
8d3e193bb30d experimental lazyValues
Claus Gittinger <cg@exept.de>
parents: 1286
diff changeset
  7009
"/    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  7010
    ^ #Error
1212
082618467e2c isMeta/soleInstance -> theMetaclass / theNonMetaclass
Claus Gittinger <cg@exept.de>
parents: 1207
diff changeset
  7011
    "Modified: / 5.11.2001 / 16:45:35 / cg"
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7012
! !
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7013
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7014
!Parser methodsFor:'parsing-primitives & pragmas'!
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7015
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7016
checkForClosingAngle
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7017
    ((tokenType == #BinaryOperator) and:[tokenName = '>']) ifTrue:[
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7018
        self nextToken.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7019
    ] ifFalse:[
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7020
        self parseError:'bad primitive definition (''>'' expected)'.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7021
    ]
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7022
!
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7023
1817
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7024
generateCallToExternalFunction:fn lineNr:lineNr
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7025
    |args sel node|
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7026
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7027
    fn argumentTypes size ~~ (methodArgNames size 
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7028
                             + (fn isCPPFunction ifTrue:1 ifFalse:0)) ifTrue:[
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7029
        self 
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7030
            ignorableParseError:('number of method args (%1) does not match function arg list'
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7031
                                bindWith: methodArgNames size).
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7032
    ].
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7033
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7034
    args := (methodArgNames ? #()) collect:[:eachArgName | self nodeForMethodArg:eachArgName].
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7035
    fn isVirtualCPP ifTrue:[
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7036
        sel := #(       
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7037
              invokeCPPVirtualOn: 
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7038
              invokeCPPVirtualOn:with:
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7039
              invokeCPPVirtualOn:with:with:
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7040
              invokeCPPVirtualOn:with:with:with:
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7041
            ) at:args size+1 ifAbsent:nil.
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7042
        sel isNil ifTrue:[
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7043
            args := Array with:(self selfNode) with:(self genMakeArrayWith:args).
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7044
            sel := #invokeCPPVirtualOn:withArguments:.
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7045
        ] ifFalse:[
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7046
            args := (Array with:(self selfNode)) , args.
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7047
        ].
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7048
    ] ifFalse:[
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7049
        fn isNonVirtualCPP ifTrue:[ 
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7050
            args := (Array with:(self selfNode)) , args
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7051
        ].
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7052
        sel := #(       
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7053
              invoke 
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7054
              invokeWith:
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7055
              invokeWith:with:
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7056
              invokeWith:with:with:
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7057
            ) at:args size+1 ifAbsent:nil.
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7058
        sel isNil ifTrue:[
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7059
            args := Array with:(self genMakeArrayWith:args).
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7060
            sel := #invokeWithArguments:.
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7061
        ].
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7062
    ].
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7063
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7064
    node := MessageNode 
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7065
                receiver:(ConstantNode type:nil value:fn) 
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7066
                selector:sel 
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7067
                args:args 
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7068
                fold:false.
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7069
    node lineNumber:lineNr.
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7070
    tree := ReturnNode new expression:node.
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7071
    tree lineNumber:lineNr.
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7072
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7073
    "Created: / 01-08-2006 / 13:47:44 / cg"
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7074
    "Modified: / 01-08-2006 / 15:29:14 / cg"
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7075
!
a46b6c33237f *** empty log message ***
ca
parents: 1816
diff changeset
  7076
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7077
generateReturnOfType:aType
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7078
    |node|
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7079
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7080
    node := ConstantNode type:nil value:aType.
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7081
    node lineNumber:tokenLineNr.
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7082
    tree := ReturnNode new expression:node.
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7083
!
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7084
1764
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7085
generateTrapCodeForUnavailableCParser
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7086
    |args node|
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7087
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7088
    self ignorableParseError:'CParser Missing'.
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7089
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7090
    args := Array with:(ConstantNode type:nil value:'External function call error - CParser missing.').
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7091
    node := MessageNode receiver:(self selfNode) selector:#error: args:args fold:false.
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7092
    node lineNumber:lineNr.
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7093
    tree := ReturnNode new expression:node.
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7094
    tree lineNumber:lineNr.
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7095
    ^ -1
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7096
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7097
    "Created: / 21-06-2006 / 09:58:43 / cg"
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7098
!
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7099
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7100
parseExternalFunctionCallDeclaration
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7101
    |callType cString cStream returnType 
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7102
     functionName argTypes moduleName fn node args sel 
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7103
     type dictionaryOfKnownTypes function functionOrType lineNr|
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7104
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7105
    "callType is one of c: / cdecl: / api: / apicall: ..."
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7106
    callType := tokenName asLowercase.
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7107
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7108
    lineNr := tokenLineNr.
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7109
    cString := source upTo:$>.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7110
    self nextToken.
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7111
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7112
    parseForCode ifFalse:[^ -1].
1764
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7113
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7114
    CParser notNil ifTrue:[
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7115
        "/ collect existing types...
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7116
        dictionaryOfKnownTypes := Dictionary new.
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7117
        classToCompileFor methodsDo:[:m |
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7118
            m literalsDo:[:lit |
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7119
                (lit isKindOf:CType) ifTrue:[
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7120
                    self assert:lit name notNil.
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7121
                    dictionaryOfKnownTypes at:lit name put:lit.
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7122
                ].
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7123
            ].
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7124
        ].
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7125
    ].
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7126
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7127
    cStream := cString readStream.
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7128
1748
6ba00add9039 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1747
diff changeset
  7129
    (#('apicall:' 'cdecl:' 'stdcall:' 'virtual') includes:callType ) ifTrue:[
6ba00add9039 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1747
diff changeset
  7130
        "/ squeak/dolphin external function definition
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7131
        self
1748
6ba00add9039 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1747
diff changeset
  7132
            parseSqueakOrDolphinExternalFunctionDeclarationFrom:cStream 
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7133
            definitionType:callType
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7134
            knownDefinitions:dictionaryOfKnownTypes
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7135
            lineNr:lineNr.
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7136
        ^ -1
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7137
    ].
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7138
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7139
    callType = 'c:' ifTrue:[
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7140
        "/ VW external function definition
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7141
        self
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7142
            parseVWTypeOrExternalFunctionDeclarationFrom:cStream 
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7143
            definitionType:callType
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7144
            knownDefinitions:dictionaryOfKnownTypes
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7145
            lineNr:lineNr.
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7146
        ^ -1
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7147
    ].
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7148
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7149
    (callType = 'api:' or:[ callType = 'ole:' ]) ifTrue:[
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7150
        "/ ST/V external function definition
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7151
        self
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7152
            parseSTVExternalFunctionDeclarationFrom:cStream 
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7153
            definitionType:callType
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7154
            knownDefinitions:dictionaryOfKnownTypes
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7155
            lineNr:lineNr.
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7156
        ^ -1
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7157
    ].
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7158
1710
78346eeddbec ST/V parsing support
Claus Gittinger <cg@exept.de>
parents: 1696
diff changeset
  7159
    self ignorableParseError:'unsupported external function call type: ' , callType.
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7160
    ^ -1
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7161
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7162
    "
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7163
     (Parser for:'foo <cdecl: void ''glFlush'' (void) module: ''GL''>')
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7164
        nextToken;
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7165
        parseMethod
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7166
    "
1764
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7167
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7168
    "Modified: / 21-06-2006 / 09:57:39 / cg"
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7169
!
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7170
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7171
parsePrimitive
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7172
    "parse an ST-80 type primitive as '< primitive: nr >';
1690
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7173
        (return primitive number or #Error)
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7174
     or a Squeak-style primitive, as '< primitive: string >';
1690
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7175
        (return primitive name or #Error)
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7176
     or a V'Age-style primitive, as '< primitive: identifier >';
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7177
        (return primitive name or #Error)
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7178
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7179
     Also, resource specs are parsed; the result is left (as side effect) in primitiveResource. 
1690
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7180
     It is used to flag methods, for faster finding of used keyboard accelerators,
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7181
     and to mark resource methods (image, menu or canvas resources).
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7182
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7183
     prim ::= st80Primitive | st80Pragma | stxPragma
1690
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7184
              squeakPrimitive | vAgePrimitive | newSTXPrimitive | resourceDecl
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7185
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7186
     st80Primitive ::= 'primitive:' INTEGER
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7187
     st80Pragma    ::= 'exception:' ( 'handle | 'raise' | 'unwind' )
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7188
     stxPragma     ::= 'context:' 'return'
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7189
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7190
     squeakPrimitive ::= 'primitive:' STRING
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7191
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7192
     newSTXPrimitive ::= 'primitive'
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7193
1690
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7194
     vAgePrimitive ::= 'primitive:' IDENTIFIER
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7195
                       | 'sysprim:' IDENTIFIER
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7196
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7197
     resourceDecl ::= 'resource:' SYMBOL       - leave SYMBOL in primitiveResource
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7198
                    | 'resource:' SYMBOL (...) - leave (SYMBOL (...)) in primitiveResource
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7199
    "
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7200
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7201
    |lcTokenName|
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7202
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7203
    (tokenType == #Keyword or:[tokenType == #Identifier]) ifFalse:[
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7204
        self parseError:'bad primitive definition (keyword expected)'.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7205
        ^ #Error
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7206
    ].
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7207
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7208
    (tokenName = 'primitive:') ifTrue:[
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7209
        ^ self parseTraditionalPrimitive.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7210
    ].
1690
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7211
    (tokenName = 'sysprim:') ifTrue:[
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7212
        parserFlags allowVisualAgePrimitives ifTrue:[
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7213
            ^ self parseTraditionalPrimitive.
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7214
        ].
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7215
    ].
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7216
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7217
    (tokenName = 'primitive') ifTrue:[
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7218
        self nextToken.
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7219
        self checkForClosingAngle.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7220
        ^ 0.    "/ no primitive number
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7221
    ].
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7222
    (tokenName = 'resource:') ifTrue:[
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7223
        self parseResourcePragma.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7224
        ^ nil.    "/ no primitive number
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7225
    ].
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7226
    (tokenName = 'exception:' 
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7227
    or:[tokenName = 'context:']) ifTrue:[
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7228
        self parseExceptionOrContextPragma.    
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7229
        self checkForClosingAngle.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7230
        ^ nil   "/ no primitive number
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7231
    ].
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7232
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7233
    lcTokenName := tokenName asLowercase.
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7234
    ((lcTokenName = 'c:')                 "/ vw external function definition
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7235
    or:[ lcTokenName = 'api:'             "/ st/v external function definition
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7236
    or:[ lcTokenName = 'ole:'             "/ st/v external function definition
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7237
    or:[ lcTokenName = 'apicall:'         "/ squeak external function definition
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7238
    or:[ lcTokenName = 'cdecl:'           "/ squeak external function definition
1748
6ba00add9039 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1747
diff changeset
  7239
    or:[ lcTokenName = 'stdcall:'         "/ dolphin external function definition
6ba00add9039 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1747
diff changeset
  7240
    ]]]]]) ifTrue:[
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7241
        self parseExternalFunctionCallDeclaration.
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7242
        ^ nil   "/ no primitive number
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7243
    ].
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7244
1716
cfbef30a7cb7 qualified names again (VW7);
Claus Gittinger <cg@exept.de>
parents: 1714
diff changeset
  7245
    self ignorableParseError:'unrecognized pragma: ' , tokenName.
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7246
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7247
    "/ skip
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7248
    [tokenType ~~ #EOF] whileTrue:[
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7249
        ((tokenType == #BinaryOperator) and:[tokenName = '>']) ifTrue:[
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7250
            self nextToken.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7251
            ^ nil "/ no primitive number
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7252
        ].
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7253
        self nextToken.
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7254
    ].
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7255
    ^ nil  "/ no primitive number
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7256
!
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7257
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7258
parsePrimitiveOrResourceSpecOrEmpty
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7259
    "parse a methods primitive or resource spec"
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7260
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7261
    |pos wmsg primNr primNrOrString|
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7262
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7263
    [(tokenType == #BinaryOperator) and:[tokenName = '<']] whileTrue:[
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7264
        pos := tokenPosition.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7265
        self nextToken.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7266
        primNrOrString := self parsePrimitive.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7267
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7268
        (primNrOrString == #Error) ifTrue:[^ #Error].
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7269
        wmsg := nil.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7270
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7271
        primNrOrString isString ifTrue:[
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7272
            primNr := self primitiveNumberFromName:primNrOrString
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7273
        ] ifFalse:[
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7274
            primNr := primNrOrString
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7275
        ].
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7276
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7277
        primNr notNil ifTrue:[
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7278
            primNr < 0 ifTrue:[
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  7279
                parserFlags warnST80Directives == true ifTrue:[
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7280
                    wmsg := 'ST-80/Squeak directive ignored'.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7281
                ].
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7282
            ] ifFalse:[
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7283
                primNr > 0 ifTrue:[
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7284
                    primitiveNr := primNr.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7285
                    wmsg := 'ST-80 primitive may not work'
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7286
                ] ifFalse:[
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7287
                    primitiveNr := primNr.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7288
                    wmsg := 'ST/X primitives only work in rel5 and newer'
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7289
                ]
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7290
            ].
1551
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7291
            wmsg notNil ifTrue:[self warning:wmsg position:pos]
29f4971331f9 c-callout;
ca
parents: 1548
diff changeset
  7292
        ].
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7293
    ].
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7294
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7295
    "Created: 27.4.1996 / 16:55:55 / cg"
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7296
    "Modified: 29.5.1996 / 17:25:52 / cg"
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7297
!
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7298
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7299
parseResourcePragma
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7300
    " '< resource:' has already been parsed."
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7301
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7302
    |keys resource resourceValue|
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7303
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7304
    self nextToken.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7305
    (tokenType ~~ #Symbol) ifTrue:[
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7306
        self parseError:'symbol expected'.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7307
        ^ #Error
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7308
    ].
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7309
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7310
    resource := tokenValue.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7311
    resourceValue := true.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7312
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7313
    self nextToken.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7314
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7315
    tokenType == $( ifTrue:[
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7316
        self nextToken.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7317
        keys := OrderedCollection new.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7318
        [(tokenType == $)) or:[tokenType == #EOF] ] whileFalse:[
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7319
            keys add:tokenValue.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7320
            self nextToken.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7321
        ].
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7322
        resourceValue := keys.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7323
        (tokenType == $)) ifFalse:[
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7324
            self parseError:'unterminated primitive/spec (missing '')'')'.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7325
        ].
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7326
        self nextToken.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7327
    ].
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7328
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7329
    primitiveResource isNil ifTrue:[
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7330
        primitiveResource := IdentityDictionary new.
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7331
    ].
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7332
    primitiveResource at:(resource asSymbol) put:resourceValue.
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7333
    self checkForClosingAngle.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7334
!
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7335
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7336
parseSTVExternalFunctionDeclarationFrom:aStream definitionType:definitionType knownDefinitions:dictionaryOfTypesOrNil lineNr:lineNr
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7337
    "parses ST/V function declarations of the forms 
1748
6ba00add9039 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1747
diff changeset
  7338
        '<api: functionName argType1 .. argTypeN returnType>' 
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7339
        '<ole: vFunctionIndex argType1 .. argTypeN returnType>'
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7340
    "
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7341
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7342
    |primParser function|
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7343
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7344
    primParser := PrimitiveSpecParser new.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7345
    function := primParser 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7346
        parseSTVExternalFunctionDeclarationFrom:aStream 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7347
        definitionType:definitionType 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7348
        lineNr:lineNr
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7349
        for:self.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7350
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7351
    function owningClass:classToCompileFor.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7352
    self generateCallToExternalFunction:function lineNr:lineNr.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7353
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7354
    "Modified: / 01-08-2006 / 16:16:53 / cg"
1748
6ba00add9039 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1747
diff changeset
  7355
!
6ba00add9039 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1747
diff changeset
  7356
6ba00add9039 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1747
diff changeset
  7357
parseSqueakOrDolphinExternalFunctionDeclarationFrom:aStream definitionType:definitionType 
6ba00add9039 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1747
diff changeset
  7358
    knownDefinitions:dictionaryOfTypesOrNil lineNr:lineNr
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7359
1748
6ba00add9039 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1747
diff changeset
  7360
    "parses squeak/dolphin function declarations of the forms 
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7361
        '<stdcall: [virtual|nonVirtual] returnType functionNameOrIndex argType1..argTypeN>'
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7362
        '<cdecl:   [virtual|nonVirtual] returnType functionNameOrIndex argType1..argTypeN>' 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7363
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7364
        '<cdecl:   [async] [virtual|nonVirtual] returnType functionNameOrIndex ( argType1..argTypeN ) module: moduleName >' 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7365
        '<apicall: [async] [virtual|nonVirtual] returnType functionNameOrIndex ( argType1..argTypeN ) module: moduleName >'
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7366
    "
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7367
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7368
    |primParser function|
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7369
1816
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  7370
    primParser := PrimitiveSpecParser new setClassToCompileFor:classToCompileFor.
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  7371
    primParser notifying:requestor.
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7372
    function := primParser 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7373
        parseSqueakOrDolphinExternalFunctionDeclarationFrom:aStream 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7374
        definitionType:definitionType 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7375
        lineNr:lineNr
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7376
        for:self.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7377
1816
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  7378
    function notNil ifTrue:[
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  7379
        function owningClass:classToCompileFor.
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  7380
        self generateCallToExternalFunction:function lineNr:lineNr.
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  7381
    ].
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7382
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7383
    "Modified: / 01-08-2006 / 16:16:57 / cg"
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7384
!
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7385
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7386
parseTraditionalPrimitive
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7387
    "parse everything after the initial '<primitive:'"
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7388
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7389
    |primNumber|
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7390
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7391
    self nextToken.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7392
    (tokenType == #Integer) ifFalse:[
1744
b5241887a350 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1741
diff changeset
  7393
        (parserFlags allowSqueakExtensions
b5241887a350 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1741
diff changeset
  7394
        or:[ parserFlags allowSqueakPrimitives ]) ifTrue:[
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7395
            (tokenType == #String) ifFalse:[
1690
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7396
                self parseError:'primitive name as string expected'.
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7397
                ^ #Error
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7398
            ]
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7399
        ] ifFalse:[
1690
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7400
            parserFlags allowVisualAgePrimitives ifTrue:[
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7401
                (tokenType == #Identifier) ifFalse:[
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7402
                    self parseError:'primitive name expected'.
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7403
                    ^ #Error
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7404
                ]
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7405
            ] ifFalse:[
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7406
                self parseError:'primitive number expected'.
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7407
                ^ #Error
9878628e15ac support parsing (at least) of V'Age primitives
Claus Gittinger <cg@exept.de>
parents: 1687
diff changeset
  7408
            ].
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7409
        ]
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7410
    ].
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7411
    primitiveNr notNil ifTrue:[
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7412
        self parseError:'only one primitive spec allowed'.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7413
        primNumber := -1.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7414
    ] ifFalse:[
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7415
        primNumber := tokenValue.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7416
    ].
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7417
    self nextToken.
1556
ce528f32646b care for missing pools
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
  7418
ce528f32646b care for missing pools
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
  7419
    (tokenType == #Keyword) ifTrue:[
ce528f32646b care for missing pools
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
  7420
        (tokenName = 'errorCode:') ifTrue:[
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7421
            self nextToken.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7422
            (tokenType == #Identifier) ifTrue:[
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7423
                self nextToken.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7424
            ] ifFalse:[
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7425
                self error:'not yet implemented'.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7426
            ]
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7427
        ].
1744
b5241887a350 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1741
diff changeset
  7428
        (tokenName = 'module:') ifTrue:[
b5241887a350 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1741
diff changeset
  7429
            self nextToken.
b5241887a350 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1741
diff changeset
  7430
            (tokenType == #String) ifTrue:[
1556
ce528f32646b care for missing pools
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
  7431
                self nextToken.
1744
b5241887a350 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1741
diff changeset
  7432
            ] ifFalse:[
b5241887a350 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1741
diff changeset
  7433
                self error:'not yet implemented'.
b5241887a350 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1741
diff changeset
  7434
            ]
1556
ce528f32646b care for missing pools
Claus Gittinger <cg@exept.de>
parents: 1551
diff changeset
  7435
        ].
1420
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7436
    ].
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7437
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7438
    self checkForClosingAngle.
57f3f5c8a070 more for exotic primitives/pragmas
Claus Gittinger <cg@exept.de>
parents: 1419
diff changeset
  7439
    ^ primNumber
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7440
!
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7441
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7442
parseVWTypeOrExternalFunctionDeclarationFrom:aStream definitionType:definitionType knownDefinitions:dictionaryOfTypesOrNil lineNr:lineNr
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7443
    "parses visualWorks type/function declarations of the form: 
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7444
        '<c: ...>'"
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7445
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7446
    |cParser functionOrType |
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7447
1764
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7448
    CParser isNil ifTrue:[
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7449
        self generateTrapCodeForUnavailableCParser.
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7450
        ^ self.
a95475f1f456 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1762
diff changeset
  7451
    ].
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7452
    functionOrType := PrimitiveSpecParser new
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7453
        parseVWTypeOrExternalFunctionDeclarationFrom:aStream 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7454
        definitionType:definitionType 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7455
        knownDefinitions:dictionaryOfTypesOrNil 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7456
        lineNr:lineNr
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7457
        for: self.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7458
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7459
    (functionOrType isKindOf:ExternalLibraryFunction) ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7460
        self generateReturnOfType:functionOrType.
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7461
        ^ self
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7462
    ].
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7463
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7464
    functionOrType owningClass:classToCompileFor.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7465
    self generateCallToExternalFunction:functionOrType lineNr:lineNr.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7466
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  7467
    "Modified: / 01-08-2006 / 16:21:36 / cg"
1741
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7468
!
467d7120e6bd c-call parsing
Claus Gittinger <cg@exept.de>
parents: 1739
diff changeset
  7469
1410
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7470
primitiveNumberFromName:aPrimitiveName
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7471
    "for future compatibility with Squeak ..."
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7472
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7473
    ^ nil
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7474
! !
e93635fe8c40 pragma & ffi stuff
Claus Gittinger <cg@exept.de>
parents: 1407
diff changeset
  7475
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7476
!Parser methodsFor:'private'!
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7477
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7478
currentNameSpace
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7479
    |spc|
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7480
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7481
    spc := currentNamespace.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7482
    spc isNil ifTrue:[
832
553c25252a78 Use #query instead of #raise when invoking QuerySignals
Stefan Vogel <sv@exept.de>
parents: 825
diff changeset
  7483
        (requestor respondsTo:#currentNameSpace) ifTrue:[
553c25252a78 Use #query instead of #raise when invoking QuerySignals
Stefan Vogel <sv@exept.de>
parents: 825
diff changeset
  7484
            spc := requestor currentNameSpace
553c25252a78 Use #query instead of #raise when invoking QuerySignals
Stefan Vogel <sv@exept.de>
parents: 825
diff changeset
  7485
        ] ifFalse:[
553c25252a78 Use #query instead of #raise when invoking QuerySignals
Stefan Vogel <sv@exept.de>
parents: 825
diff changeset
  7486
            spc := Class nameSpaceQuerySignal query.
553c25252a78 Use #query instead of #raise when invoking QuerySignals
Stefan Vogel <sv@exept.de>
parents: 825
diff changeset
  7487
        ].
553c25252a78 Use #query instead of #raise when invoking QuerySignals
Stefan Vogel <sv@exept.de>
parents: 825
diff changeset
  7488
        currentNamespace := spc.
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7489
    ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7490
    ^ spc
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7491
832
553c25252a78 Use #query instead of #raise when invoking QuerySignals
Stefan Vogel <sv@exept.de>
parents: 825
diff changeset
  7492
    "Created: / 19.12.1996 / 23:47:58 / cg"
553c25252a78 Use #query instead of #raise when invoking QuerySignals
Stefan Vogel <sv@exept.de>
parents: 825
diff changeset
  7493
    "Modified: / 14.10.1997 / 20:56:06 / cg"
553c25252a78 Use #query instead of #raise when invoking QuerySignals
Stefan Vogel <sv@exept.de>
parents: 825
diff changeset
  7494
    "Modified: / 18.3.1999 / 18:25:50 / stefan"
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7495
!
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7496
492
fe778fd0ce46 additional entry, passing the namespace
Claus Gittinger <cg@exept.de>
parents: 489
diff changeset
  7497
currentNameSpace:aNameSpace
fe778fd0ce46 additional entry, passing the namespace
Claus Gittinger <cg@exept.de>
parents: 489
diff changeset
  7498
    currentNamespace := aNameSpace.
fe778fd0ce46 additional entry, passing the namespace
Claus Gittinger <cg@exept.de>
parents: 489
diff changeset
  7499
fe778fd0ce46 additional entry, passing the namespace
Claus Gittinger <cg@exept.de>
parents: 489
diff changeset
  7500
    "Created: 8.2.1997 / 19:37:03 / cg"
fe778fd0ce46 additional entry, passing the namespace
Claus Gittinger <cg@exept.de>
parents: 489
diff changeset
  7501
!
fe778fd0ce46 additional entry, passing the namespace
Claus Gittinger <cg@exept.de>
parents: 489
diff changeset
  7502
1247
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7503
currentPackage
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7504
    |pkg|
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7505
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7506
    pkg := currentPackage.
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7507
    pkg isNil ifTrue:[
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7508
        (requestor respondsTo:#currentPackage) ifTrue:[
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7509
            pkg := requestor currentPackage
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7510
        ] ifFalse:[
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7511
            pkg := Class packageQuerySignal query.
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7512
        ].
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7513
        currentPackage := pkg.
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7514
    ].
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7515
    ^ pkg
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7516
!
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7517
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7518
currentPackage:aPackageName
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7519
    currentPackage := aPackageName.
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7520
!
ce0d19140248 care for package directive (remember)
Claus Gittinger <cg@exept.de>
parents: 1246
diff changeset
  7521
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7522
currentUsedNameSpaces
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7523
    |spaces|
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7524
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7525
    spaces := currentUsedNamespaces.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7526
    spaces isNil ifTrue:[
679
6a60e6d0ccd1 avoid redoing work in #currentUsedNameSpaces
Claus Gittinger <cg@exept.de>
parents: 673
diff changeset
  7527
        (requestor respondsTo:#usedNameSpaces) ifTrue:[
6a60e6d0ccd1 avoid redoing work in #currentUsedNameSpaces
Claus Gittinger <cg@exept.de>
parents: 673
diff changeset
  7528
            spaces := requestor usedNameSpaces
6a60e6d0ccd1 avoid redoing work in #currentUsedNameSpaces
Claus Gittinger <cg@exept.de>
parents: 673
diff changeset
  7529
        ] ifFalse:[
832
553c25252a78 Use #query instead of #raise when invoking QuerySignals
Stefan Vogel <sv@exept.de>
parents: 825
diff changeset
  7530
            spaces := Class usedNameSpaceQuerySignal query.
679
6a60e6d0ccd1 avoid redoing work in #currentUsedNameSpaces
Claus Gittinger <cg@exept.de>
parents: 673
diff changeset
  7531
        ].
6a60e6d0ccd1 avoid redoing work in #currentUsedNameSpaces
Claus Gittinger <cg@exept.de>
parents: 673
diff changeset
  7532
        spaces isNil ifTrue:[
6a60e6d0ccd1 avoid redoing work in #currentUsedNameSpaces
Claus Gittinger <cg@exept.de>
parents: 673
diff changeset
  7533
            spaces := #()
6a60e6d0ccd1 avoid redoing work in #currentUsedNameSpaces
Claus Gittinger <cg@exept.de>
parents: 673
diff changeset
  7534
        ].
6a60e6d0ccd1 avoid redoing work in #currentUsedNameSpaces
Claus Gittinger <cg@exept.de>
parents: 673
diff changeset
  7535
        currentUsedNamespaces := spaces.
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7536
    ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7537
    ^ spaces
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7538
679
6a60e6d0ccd1 avoid redoing work in #currentUsedNameSpaces
Claus Gittinger <cg@exept.de>
parents: 673
diff changeset
  7539
    "Created: / 19.12.1996 / 23:49:10 / cg"
6a60e6d0ccd1 avoid redoing work in #currentUsedNameSpaces
Claus Gittinger <cg@exept.de>
parents: 673
diff changeset
  7540
    "Modified: / 7.4.1998 / 08:59:28 / cg"
832
553c25252a78 Use #query instead of #raise when invoking QuerySignals
Stefan Vogel <sv@exept.de>
parents: 825
diff changeset
  7541
    "Modified: / 18.3.1999 / 18:25:57 / stefan"
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7542
!
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7543
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7544
findNameSpaceWith:aVariableName
692
78647d24f59a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 690
diff changeset
  7545
    |ns currentSpace usedSpaces|
486
e894035d5223 fixed name resolving for private classes when accessing
Claus Gittinger <cg@exept.de>
parents: 481
diff changeset
  7546
e894035d5223 fixed name resolving for private classes when accessing
Claus Gittinger <cg@exept.de>
parents: 481
diff changeset
  7547
    "/ private names have already been searched for.
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7548
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7549
    classToCompileFor notNil ifTrue:[
1042
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7550
        "/ Q:
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7551
        "/ consider private classes of superclasses.
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7552
        "/ or search in the top owing classes namespace only ?
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7553
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7554
        "/ for now, ignore other private classes - they are only
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7555
        "/ known to the corresponding ownerClass.
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7556
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7557
        "is it in the classes namespace ?"
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7558
1315
c82178f7d52e use #topNameSpace
Claus Gittinger <cg@exept.de>
parents: 1309
diff changeset
  7559
        ns := classToCompileFor topNameSpace.
1042
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7560
        (ns notNil
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7561
        and:[ns ~~ Smalltalk]) ifTrue:[
1142
8ed9215cba13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  7562
            ns isNameSpace ifTrue:[
8ed9215cba13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  7563
                (ns at:aVariableName) notNil ifTrue:[
8ed9215cba13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  7564
                    ^ ns
8ed9215cba13 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1139
diff changeset
  7565
                ]
1042
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7566
            ]
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7567
        ].
494
bb3e71c90dfd currentClasses nameSpace is first to look for globals.
Claus Gittinger <cg@exept.de>
parents: 493
diff changeset
  7568
495
Claus Gittinger <cg@exept.de>
parents: 494
diff changeset
  7569
"/        ns := classToCompileFor nameSpace.
Claus Gittinger <cg@exept.de>
parents: 494
diff changeset
  7570
"/        ns notNil ifTrue:[
Claus Gittinger <cg@exept.de>
parents: 494
diff changeset
  7571
"/            "is it in the current classes namespace ?"
Claus Gittinger <cg@exept.de>
parents: 494
diff changeset
  7572
"/            (ns at:aVariableName asSymbol) notNil ifTrue:[
Claus Gittinger <cg@exept.de>
parents: 494
diff changeset
  7573
"/                ^ ns
Claus Gittinger <cg@exept.de>
parents: 494
diff changeset
  7574
"/            ]
Claus Gittinger <cg@exept.de>
parents: 494
diff changeset
  7575
"/        ].
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7576
    ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7577
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7578
    "is it in the current namespace ?"
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7579
    currentSpace := self currentNameSpace.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7580
    (currentSpace notNil
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7581
    and:[currentSpace ~~ Smalltalk]) ifTrue:[
1043
08ad8eb7532d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1042
diff changeset
  7582
        currentSpace isNameSpace ifTrue:[
08ad8eb7532d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1042
diff changeset
  7583
            (currentSpace at:aVariableName) notNil ifTrue:[
08ad8eb7532d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1042
diff changeset
  7584
                ^ currentSpace
08ad8eb7532d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1042
diff changeset
  7585
            ]
08ad8eb7532d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1042
diff changeset
  7586
        ] ifFalse:[
08ad8eb7532d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1042
diff changeset
  7587
            (currentSpace privateClassesAt:aVariableName) notNil ifTrue:[
08ad8eb7532d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1042
diff changeset
  7588
                ^ currentSpace
08ad8eb7532d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1042
diff changeset
  7589
            ]
1042
d192446cb745 fixed qualifiedName handling (as array constant)
Claus Gittinger <cg@exept.de>
parents: 1041
diff changeset
  7590
        ]
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7591
    ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7592
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7593
    "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
  7594
    usedSpaces := self currentUsedNameSpaces.
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7595
    usedSpaces notNil ifTrue:[
1696
4b0db823d6a2 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1692
diff changeset
  7596
        ^ usedSpaces detect:[:aNameSpace | (aNameSpace at:aVariableName) notNil] ifNone:nil.
455
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7597
    ].
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7598
    ^ nil
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7599
2e234d3bc96d fixed parsing of private classes within a nameSpace
Claus Gittinger <cg@exept.de>
parents: 454
diff changeset
  7600
    "Created: 19.12.1996 / 23:51:02 / cg"
619
247c7807db14 empty source notification
Claus Gittinger <cg@exept.de>
parents: 607
diff changeset
  7601
    "Modified: 14.10.1997 / 20:56:35 / cg"
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7602
!
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7603
1762
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7604
genMakeArrayWith:elementExpressions
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7605
    "return a node to generate an array at runtime.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7606
     Will generate:
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7607
        Array with:el1 ... with:elN                             (if N <= 5)
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7608
     or:
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7609
        (Array new at:1 put:el1; ... at:N put:elN; yourself)    (otherwise)
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7610
    "
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7611
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7612
    |numEl arrRec sel expr|
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7613
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7614
    arrRec := VariableNode globalNamed:#Array.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7615
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7616
    numEl := elementExpressions size.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7617
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7618
    (numEl between:1 and:8) ifTrue:[
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7619
        sel := #( 
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7620
                  #'with:'
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7621
                  #'with:with:'
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7622
                  #'with:with:with:'
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7623
                  #'with:with:with:with:'
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7624
                  #'with:with:with:with:with:'
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7625
                  #'with:with:with:with:with:with:'
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7626
                  #'with:with:with:with:with:with:with:'
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7627
                  #'with:with:with:with:with:with:with:with:'
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7628
                ) at:numEl.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7629
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7630
        ^ MessageNode 
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7631
                    receiver:arrRec
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7632
                    selector:sel
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7633
                    args:elementExpressions.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7634
    ].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7635
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7636
    "/ array creation expression ...
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7637
    expr := MessageNode 
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7638
                receiver:arrRec
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7639
                selector:#new:
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7640
                arg:(ConstantNode type:#Integer value:numEl).
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7641
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7642
    numEl == 0 ifTrue:[
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7643
        ^ expr.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7644
    ].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7645
    "/ followed by a bunch of #at:put: messages...
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7646
    elementExpressions keysAndValuesDo:[:idx :e |
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7647
        expr := (idx == 1 ifTrue:[MessageNode] ifFalse:[CascadeNode])
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7648
                    receiver:expr
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7649
                    selector:#at:put:
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7650
                    arg1:(ConstantNode type:#Integer value:idx)
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7651
                    arg2:e
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7652
                    fold:false.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7653
    ].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7654
    "/ followed by a #yourself: message...
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7655
    expr := CascadeNode
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7656
                receiver:expr
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7657
                selector:#yourself.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7658
    ^ expr
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7659
!
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7660
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  7661
implementedInAnyClass:selector
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  7662
    Smalltalk allClassesAndMetaclassesDo:[:cls |
1518
ae1f95e5ab9f *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1517
diff changeset
  7663
        (cls includesSelector:selector) ifTrue:[^ true].
1327
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  7664
    ].
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  7665
    ^ false
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  7666
!
133a7d16f2a2 more checks
Claus Gittinger <cg@exept.de>
parents: 1326
diff changeset
  7667
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7668
inWhichClassIsClassInstVar:aString
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7669
    "search class-chain for the class-instance variable named aString
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7670
     - return the class or nil if not found"
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7671
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7672
    |aClass|
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7673
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7674
    aClass := self classToLookForClassVars.
732
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7675
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7676
    [aClass notNil] whileTrue:[
732
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7677
        (aClass class instVarNames includes:aString) ifTrue:[ ^ aClass].
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7678
        aClass := aClass superclass
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7679
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7680
    ^ nil
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7681
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7682
    "Modified: / 18.6.1998 / 15:45:34 / cg"
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7683
!
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7684
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7685
inWhichClassIsClassVar:aString
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7686
    "search class-chain for the classvariable named aString
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7687
     - return the class or nil if not found"
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7688
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7689
    |aClass className baseClass|
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7690
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7691
    aClass := self classToLookForClassVars.
732
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7692
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7693
    aClass isMeta ifTrue:[
732
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7694
        className := aClass name copyWithoutLast:6.
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7695
        baseClass := Smalltalk at:(className asSymbol).
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7696
        baseClass notNil ifTrue:[
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7697
            aClass := baseClass
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7698
        ]
713
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7699
    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7700
    ^ aClass whichClassDefinesClassVar:aString
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7701
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7702
"/    [aClass notNil] whileTrue:[
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7703
"/        (aClass classVarNames includes:aString) ifTrue:[ ^ aClass].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7704
"/        aClass := aClass superclass
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7705
"/    ].
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7706
"/    ^ nil
ae3141c892d7 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  7707
732
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7708
    "Modified: / 17.6.1996 / 17:18:41 / stefan"
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7709
    "Modified: / 18.6.1998 / 15:45:29 / cg"
787
9a178fa050b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 762
diff changeset
  7710
!
9a178fa050b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 762
diff changeset
  7711
1512
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7712
isStatementAnUnconditionalReturn:aStatementNode
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7713
    |expr selector block1 block2 stats1 stats2|
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7714
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7715
    aStatementNode isReturnNode ifTrue:[^ true ].
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7716
    ((expr := aStatementNode expression) notNil
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7717
    and:[expr isMessage]) ifTrue:[
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7718
        selector := expr selector.
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7719
        (selector == #'ifTrue:ifFalse:' or:[selector == #'ifFalse:ifTrue:']) ifTrue:[
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7720
            block1 := expr arg1.
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7721
            block2 := expr arguments at:2.
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7722
            (block1 isBlockNode and:[ block2 isBlockNode]) ifTrue:[
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7723
                stats1 := block1 statements.
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7724
                stats2 := block2 statements.
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7725
                    (stats1 notEmptyOrNil and:[ stats2 notEmptyOrNil]) ifTrue:[
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7726
                        ^ (self isStatementAnUnconditionalReturn:stats1 last)
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7727
                        and:[self isStatementAnUnconditionalReturn:stats2 last]
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7728
                ].
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7729
            ].
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7730
        ].
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7731
    ].
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7732
    ^ false.
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7733
!
52986e9b02af better isReturn (used when checking for consistent return value)
Claus Gittinger <cg@exept.de>
parents: 1507
diff changeset
  7734
1762
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7735
isValidUnarySelector:tokenType
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7736
    tokenType == #Identifier ifTrue:[^true].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7737
    tokenType == #Here ifTrue:[^true].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7738
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7739
    parserFlags allowReservedWordsAsSelectors == true ifTrue:[
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7740
        tokenType == #Self ifTrue:[^true].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7741
        tokenType == #Nil ifTrue:[^true].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7742
        tokenType == #True ifTrue:[^true].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7743
        tokenType == #False ifTrue:[^true].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7744
        tokenType == #Super ifTrue:[^true].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7745
        tokenType == #ThisContext ifTrue:[^true].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7746
    ].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7747
    ^ false
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7748
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7749
    "
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7750
     ParserFlags allowReservedWordsAsSelectors:true.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7751
     1234 self.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7752
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7753
     ParserFlags allowReservedWordsAsSelectors:false
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7754
     1234 self.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7755
    "
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7756
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7757
    "
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7758
     1234 self
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7759
     1234 nil
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7760
     1234 true
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7761
     1234 false
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7762
     1234 here
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7763
     1234 super
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7764
     1234 thisContext
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7765
    "
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7766
!
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7767
1615
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  7768
makeImmutableArray:anArray
1621
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  7769
    ^ self class makeImmutableArray:anArray
1615
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  7770
!
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  7771
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  7772
makeImmutableString:aString
1621
490b30bfc501 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1619
diff changeset
  7773
    ^ self class makeImmutableString:aString
1615
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  7774
!
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  7775
1262
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7776
makeReferenceFor:aNode
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7777
    |rec sel indexNode contextNode arg1 arg2|
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7778
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7779
    contextNode := VariableNode type:#ThisContext context:contextToEvaluateIn.
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7780
    indexNode := ConstantNode type:#Integer value:aNode index.
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7781
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7782
    aNode isArgument ifTrue:[
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7783
        sel := #forArgument:in:.
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7784
        arg1 := indexNode.
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7785
        arg2 := contextNode.
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7786
    ] ifFalse:[
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7787
        aNode isLocal ifTrue:[
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7788
            sel := #forLocal:in:.
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7789
            arg1 := indexNode.
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7790
            arg2 := contextNode.
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7791
        ] ifFalse:[
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7792
            self parseError:'unsupported variable reference (must be local or argument)'.
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7793
            ^ aNode
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7794
        ]
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7795
    ].
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7796
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7797
    parseForCode ifFalse:[self rememberGlobalUsed:'Reference'].
1309
f85561a7b90e preps for nonDeterministic and FD variables.
Claus Gittinger <cg@exept.de>
parents: 1306
diff changeset
  7798
    rec := VariableNode globalNamed:'Reference'.
1262
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7799
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7800
    ^ MessageNode receiver:rec selector:sel arg1:arg1 arg2:arg2.
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7801
!
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7802
1003
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  7803
noAssignmentAllowed:eMsg at:pos
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  7804
    ((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  7805
        self parseError:eMsg position:pos to:tokenPosition + tokenType size - 1.
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  7806
        self isSyntaxHighlighter ifFalse:[
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  7807
            ^ false
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  7808
        ].
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  7809
        self nextToken. "/ eat the assign when doing highlighting only
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  7810
    ].
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  7811
    ^ true
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  7812
!
37badd2eb5b0 dont stop syntaxHighlighting when a bad assignment is encountered
Claus Gittinger <cg@exept.de>
parents: 997
diff changeset
  7813
1762
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7814
nodeForMethodArg:varName
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7815
    |varIndex var|
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7816
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7817
    methodArgNames isNil ifTrue:[^ nil].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7818
    varIndex := methodArgNames indexOf:varName.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7819
    varIndex == 0 ifTrue:[^ nil].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7820
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7821
    var := methodArgs at:varIndex.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7822
"/    var used:true.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7823
    ^ VariableNode type:#MethodArg
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7824
                   name:varName
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7825
                  token:var
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7826
                  index:varIndex
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7827
!
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7828
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7829
nodeForMethodVariable:varName
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7830
    |varIndex var|
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7831
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7832
    methodVarNames isNil ifTrue:[^ nil].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7833
    varIndex := methodVarNames indexOf:varName.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7834
    varIndex == 0 ifTrue:[^ nil].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7835
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7836
    var := methodVars at:varIndex.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7837
    var used:true.
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7838
    parseForCode ifFalse:[self rememberLocalUsed:varName].
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7839
    ^ VariableNode type:#MethodVariable
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7840
                   name:varName
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7841
                  token:var
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7842
                  index:varIndex
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7843
!
219f7751c212 category
Claus Gittinger <cg@exept.de>
parents: 1758
diff changeset
  7844
787
9a178fa050b9 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 762
diff changeset
  7845
plausibilityCheck:aNode
1687
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  7846
    |note rcvr|
1193
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  7847
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  7848
    note := aNode plausibilityCheck.
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  7849
    note isNil ifTrue:[
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  7850
        aNode isMessage ifTrue:[
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  7851
            (contextToEvaluateIn isNil and:[selfValue isNil]) ifTrue:[    "/ do not check this for doits
1687
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  7852
                rcvr := aNode receiver.
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  7853
                (rcvr isSuper and:[rcvr isHere not]) ifTrue:[
ecc241457f4d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1685
diff changeset
  7854
                    aNode selector ~= selector ifTrue:[
1803
ea888d90dfef only warn once about bad super-message
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
  7855
                        didWarnAboutBadSupersend ifFalse:[
ea888d90dfef only warn once about bad super-message
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
  7856
                            didWarnAboutBadSupersend := true.
ea888d90dfef only warn once about bad super-message
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
  7857
                            ^ 'possible bad super message ? (selector should be same as in current method)'.
ea888d90dfef only warn once about bad super-message
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
  7858
                        ]
1193
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  7859
                    ].
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  7860
                ].
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  7861
            ].
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  7862
        ].
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  7863
    ].
c441d3b202e5 check bad super message
Claus Gittinger <cg@exept.de>
parents: 1190
diff changeset
  7864
    ^ note
1262
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7865
!
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7866
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7867
selfNode
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7868
    selfNode isNil ifTrue:[ 
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7869
        selfNode := SelfNode value:selfValue
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7870
    ].
85c57c7eee77 experimental: refs
Claus Gittinger <cg@exept.de>
parents: 1260
diff changeset
  7871
    ^ selfNode
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  7872
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  7873
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  7874
!Parser methodsFor:'queries'!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  7875
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7876
classToLookForClassVars
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7877
    "helper - return the class to look for classVars.
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7878
     If there is a context in which we evaluate, the
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7879
     methods implementing class is used instead of the
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7880
     class of the receiver."
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7881
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  7882
    |m who|
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7883
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7884
    contextToEvaluateIn notNil ifTrue:[
748
9c44179d6b03 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 743
diff changeset
  7885
        m := contextToEvaluateIn method.
9c44179d6b03 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 743
diff changeset
  7886
        m notNil ifTrue:[
9c44179d6b03 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 743
diff changeset
  7887
            who := contextToEvaluateIn method who.
9c44179d6b03 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 743
diff changeset
  7888
            who notNil ifTrue:[
9c44179d6b03 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 743
diff changeset
  7889
                ^ who methodClass.
9c44179d6b03 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 743
diff changeset
  7890
            ]
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7891
        ].
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7892
        "/ mhmh - might be a doIt ...
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7893
    ].
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7894
    ^ classToCompileFor
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7895
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7896
    "Created: / 18.6.1998 / 15:43:42 / cg"
748
9c44179d6b03 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 743
diff changeset
  7897
    "Modified: / 21.7.1998 / 18:19:52 / cg"
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7898
!
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7899
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  7900
classesClassInstVarNames
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  7901
    "caching allInstVarNames for next compilation saves time ..."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  7902
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7903
    |names|
694
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7904
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7905
    [
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7906
        |cls|
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7907
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7908
        cls := self classToLookForClassVars.
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7909
732
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7910
        (PrevClassInstVarNames isNil or:[PrevClass ~~ cls]) ifTrue:[
694
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7911
            PrevClass notNil ifTrue:[
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7912
                PrevClass removeDependent:Parser
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7913
            ].
732
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7914
            PrevClass := cls.
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7915
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7916
            PrevClassInstVarNames := cls class allInstVarNames.
694
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7917
            PrevClass addDependent:Parser.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7918
        ].
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7919
        names := PrevClassInstVarNames.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7920
    ] valueUninterruptably.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7921
    ^ names
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  7922
732
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7923
    "Created: / 14.10.1996 / 18:03:35 / cg"
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7924
    "Modified: / 18.6.1998 / 15:44:41 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  7925
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  7926
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  7927
classesClassVarNames
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  7928
    "caching allClassVarNames for next compilation saves time ..."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  7929
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7930
    |names|
694
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7931
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7932
    [
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7933
        |cls aClass|
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7934
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7935
        cls := self classToLookForClassVars.
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7936
732
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7937
        (PrevClassVarNames isNil or:[PrevClass ~~ cls]) ifTrue:[
694
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7938
            PrevClass notNil ifTrue:[
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7939
                PrevClass removeDependent:Parser
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7940
            ].
732
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7941
            aClass := PrevClass := cls.
694
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7942
            aClass isMeta ifTrue:[
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7943
                aClass := aClass soleInstance.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7944
                aClass isNil ifTrue:[
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7945
                    aClass := classToCompileFor
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7946
                ]
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7947
            ].
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7948
            PrevClassVarNames := aClass allClassVarNames.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7949
            PrevClass addDependent:Parser.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7950
        ].
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7951
        names := PrevClassVarNames.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7952
    ] valueUninterruptably.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7953
    ^ names
290
d1650b17b9e9 Change the name of a classes Metaclass from e.g. "SmallIntegerclass" to
Stefan Vogel <sv@exept.de>
parents: 285
diff changeset
  7954
732
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7955
    "Modified: / 17.6.1996 / 17:15:53 / stefan"
c36e5ef1e6ce oops - when evaluating in a context, classVars must be
Claus Gittinger <cg@exept.de>
parents: 725
diff changeset
  7956
    "Created: / 14.10.1996 / 18:02:41 / cg"
735
4012fa1611b1 code cleanup & fix for doIt (implementing class)
Claus Gittinger <cg@exept.de>
parents: 733
diff changeset
  7957
    "Modified: / 18.6.1998 / 15:44:30 / cg"
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  7958
!
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  7959
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  7960
classesInstVarNames
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  7961
    "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
  7962
694
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7963
    |names|
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7964
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7965
    [
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7966
        (PrevInstVarNames isNil or:[PrevClass ~~ classToCompileFor]) ifTrue:[
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7967
            PrevClass notNil ifTrue:[
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7968
                PrevClass removeDependent:Parser
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7969
            ].
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7970
            PrevClass := classToCompileFor.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7971
            PrevInstVarNames := classToCompileFor allInstVarNames.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7972
            PrevClassInstVarNames := nil.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7973
            PrevClassVarNames := nil.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7974
            PrevClass addDependent:Parser
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7975
        ].
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7976
        names := PrevInstVarNames
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7977
    ] valueUninterruptably.
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7978
1ec57d3a2592 must manage the PrevClass cached instVars/classInstVars
Claus Gittinger <cg@exept.de>
parents: 692
diff changeset
  7979
    ^ names
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  7980
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  7981
    "Created: 14.10.1996 / 18:00:26 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  7982
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  7983
934
716f9c76b06b pass down returnable-context flag via method.
Claus Gittinger <cg@exept.de>
parents: 931
diff changeset
  7984
contextMustBeReturnable
716f9c76b06b pass down returnable-context flag via method.
Claus Gittinger <cg@exept.de>
parents: 931
diff changeset
  7985
    ^ primitiveContextInfo notNil 
716f9c76b06b pass down returnable-context flag via method.
Claus Gittinger <cg@exept.de>
parents: 931
diff changeset
  7986
      and:[ ^ primitiveContextInfo includes:('context:' -> #return) ]
716f9c76b06b pass down returnable-context flag via method.
Claus Gittinger <cg@exept.de>
parents: 931
diff changeset
  7987
716f9c76b06b pass down returnable-context flag via method.
Claus Gittinger <cg@exept.de>
parents: 931
diff changeset
  7988
716f9c76b06b pass down returnable-context flag via method.
Claus Gittinger <cg@exept.de>
parents: 931
diff changeset
  7989
!
716f9c76b06b pass down returnable-context flag via method.
Claus Gittinger <cg@exept.de>
parents: 931
diff changeset
  7990
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  7991
hasNonOptionalPrimitiveCode
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  7992
    "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
  7993
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  7994
    ^ hasNonOptionalPrimitiveCode
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  7995
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  7996
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  7997
hasPrimitiveCode
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  7998
    "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
  7999
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8000
    ^ hasPrimitiveCode
98
claus
parents: 97
diff changeset
  8001
!
claus
parents: 97
diff changeset
  8002
1440
7084ae99ced7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1439
diff changeset
  8003
isDoIt
7084ae99ced7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1439
diff changeset
  8004
    ^ (selector isNil or:[selector == #'doIt' or:[selector == #'doIt:']])
7084ae99ced7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1439
diff changeset
  8005
!
7084ae99ced7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1439
diff changeset
  8006
883
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  8007
isSyntaxHighlighter
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  8008
    ^ false
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  8009
!
e595802b4853 mark badIdentifiers
Claus Gittinger <cg@exept.de>
parents: 879
diff changeset
  8010
385
425fc425516b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 382
diff changeset
  8011
lineNumberInfo
425fc425516b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 382
diff changeset
  8012
    ^ lineNumberInfo
425fc425516b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 382
diff changeset
  8013
425fc425516b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 382
diff changeset
  8014
    "Created: 21.10.1996 / 17:06:16 / cg"
425fc425516b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 382
diff changeset
  8015
!
425fc425516b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 382
diff changeset
  8016
391
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  8017
lineNumberInfo:how
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  8018
    lineNumberInfo := how
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  8019
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  8020
    "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
  8021
!
c556973a4b47 added method to extract a block, given a lineNumber within the
Claus Gittinger <cg@exept.de>
parents: 390
diff changeset
  8022
1082
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8023
messagesSent
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8024
    "return a collection with sent message selectors (valid after parsing).
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8025
     Includes all sent messages (i.e. also sent super messages)"
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8026
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8027
    ^ (messagesSent ? #()) collect:[:each | each asSymbol]
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8028
!
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8029
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8030
messagesSentToSelf
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8031
    "return a collection with message selectors sent to self only (valid after parsing)"
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8032
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8033
    ^ (messagesSentToSelf ? #()) collect:[:each | each asSymbol]
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8034
!
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8035
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8036
messagesSentToSuper
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8037
    "return a collection with message selectors sent to super only (valid after parsing)"
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8038
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8039
    ^ (messagesSentToSuper ? #()) collect:[:each | each asSymbol]
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8040
!
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8041
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8042
methodArgs
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8043
    "return an array with methodarg names (valid after parsing spec)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8044
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8045
    ^ methodArgNames
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8046
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8047
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8048
methodVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8049
    "return a collection with method variablenames (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8050
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8051
    ^ methodVarNames
23
1f7bcfff8d39 *** empty log message ***
claus
parents: 21
diff changeset
  8052
!
1f7bcfff8d39 *** empty log message ***
claus
parents: 21
diff changeset
  8053
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8054
modifiedClassVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8055
    "return a collection with classvariablenames modified by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8056
541
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8057
    ^ modifiedClassVars ? #()
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8058
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8059
    "Modified: 19.6.1997 / 17:54:48 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8060
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8061
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8062
modifiedGlobals
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8063
    "return a collection with globalnames modified by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8064
541
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8065
    ^ modifiedGlobals ? #()
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8066
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8067
    "Modified: 19.6.1997 / 17:54:51 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8068
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8069
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8070
modifiedInstVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8071
    "return a collection with instvariablenames modified by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8072
541
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8073
    ^ modifiedInstVars ? #()
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8074
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8075
    "Modified: 19.6.1997 / 17:54:27 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  8076
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  8077
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8078
numberOfMethodArgs
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8079
    "return the number of methodargs (valid after parsing spec)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8080
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8081
    ^ methodArgs size
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8082
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8083
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8084
numberOfMethodVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8085
    "return the number of method variables (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8086
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8087
    ^ methodVars size
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8088
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8089
1077
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8090
readClassVars
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8091
    "return a collection with classvariablenames read by method (valid after parsing)"
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8092
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8093
    ^ readClassVars ? #()
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8094
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8095
    "Modified: 19.6.1997 / 17:54:38 / cg"
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8096
!
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8097
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8098
readInstVars
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8099
    "return a collection with instvariablenames read by method (valid after parsing)"
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8100
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8101
    ^ readInstVars ? #()
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8102
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8103
    "Modified: 19.6.1997 / 17:54:38 / cg"
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8104
!
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8105
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8106
selector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8107
    "return the selector (valid after parsing spec)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8108
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8109
    ^ selector
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  8110
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  8111
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8112
usedClassVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8113
    "return a collection with classvariablenames refd by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8114
541
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8115
    ^ usedClassVars ? #()
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8116
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8117
    "Modified: 19.6.1997 / 17:54:56 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8118
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8119
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8120
usedGlobals
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8121
    "return a collection with globalnames refd by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8122
541
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8123
    ^ usedGlobals ? #()
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8124
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8125
    "Modified: 19.6.1997 / 17:55:00 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8126
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8127
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8128
usedInstVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8129
    "return a collection with instvariablenames refd by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8130
541
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8131
    ^ usedInstVars ? #()
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8132
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8133
    "Modified: 19.6.1997 / 17:54:38 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8134
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8135
1064
ecd50cdfb881 added #usedSymbols statistic
Claus Gittinger <cg@exept.de>
parents: 1063
diff changeset
  8136
usedSymbols
ecd50cdfb881 added #usedSymbols statistic
Claus Gittinger <cg@exept.de>
parents: 1063
diff changeset
  8137
    "return a collection with used symbols (except for sent messages) (valid after parsing)"
ecd50cdfb881 added #usedSymbols statistic
Claus Gittinger <cg@exept.de>
parents: 1063
diff changeset
  8138
ecd50cdfb881 added #usedSymbols statistic
Claus Gittinger <cg@exept.de>
parents: 1063
diff changeset
  8139
    ^ (usedSymbols ? #()) 
ecd50cdfb881 added #usedSymbols statistic
Claus Gittinger <cg@exept.de>
parents: 1063
diff changeset
  8140
!
ecd50cdfb881 added #usedSymbols statistic
Claus Gittinger <cg@exept.de>
parents: 1063
diff changeset
  8141
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8142
usedVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8143
    "return a collection with variablenames refd by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8144
541
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8145
    ^ usedVars ? #()
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8146
63f0c6734fb3 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 540
diff changeset
  8147
    "Modified: 19.6.1997 / 17:55:04 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  8148
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  8149
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8150
usesSuper
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8151
    "return true if the parsed method uses super (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8152
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8153
    ^ usesSuper
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8154
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8155
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8156
!Parser methodsFor:'setup'!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8157
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8158
arraysAreImmutable
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8159
    ^ parserFlags arraysAreImmutable
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8160
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8161
1615
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  8162
arraysAreImmutable:aBoolean
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8163
    parserFlags arraysAreImmutable:aBoolean.
1615
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  8164
!
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  8165
1220
53e6eeadee72 added declare instVar and classInstVar
Claus Gittinger <cg@exept.de>
parents: 1215
diff changeset
  8166
classToCompileFor
53e6eeadee72 added declare instVar and classInstVar
Claus Gittinger <cg@exept.de>
parents: 1215
diff changeset
  8167
    ^ classToCompileFor
53e6eeadee72 added declare instVar and classInstVar
Claus Gittinger <cg@exept.de>
parents: 1215
diff changeset
  8168
53e6eeadee72 added declare instVar and classInstVar
Claus Gittinger <cg@exept.de>
parents: 1215
diff changeset
  8169
    "Created: / 15.11.2001 / 17:21:10 / cg"
53e6eeadee72 added declare instVar and classInstVar
Claus Gittinger <cg@exept.de>
parents: 1215
diff changeset
  8170
!
53e6eeadee72 added declare instVar and classInstVar
Claus Gittinger <cg@exept.de>
parents: 1215
diff changeset
  8171
229
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  8172
foldConstants:aSymbolOrNil
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  8173
    "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
  8174
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  8175
    foldConstants := aSymbolOrNil
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  8176
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  8177
    "Created: 21.3.1996 / 16:03:22 / cg"
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  8178
    "Modified: 21.3.1996 / 16:05:04 / cg"
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  8179
!
7aecb52d907d dont fold constants with immediate evaluations
Claus Gittinger <cg@exept.de>
parents: 223
diff changeset
  8180
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8181
initialize
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8182
    super initialize.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8183
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8184
    hasPrimitiveCode := hasNonOptionalPrimitiveCode := false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8185
    usesSuper := false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8186
    parseForCode := false.
377
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
  8187
    foldConstants := FoldConstants.
bee1c21ecc62 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 376
diff changeset
  8188
    lineNumberInfo := LineNumberInfo.
1640
261459ccc704 emphasize parenthesis nesting
Claus Gittinger <cg@exept.de>
parents: 1638
diff changeset
  8189
    parenthesisLevel := 0.
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8190
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8191
    didWarnAboutSTXNameSpaceUse := false.
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8192
    didWarnAboutSTXHereExtensionUsed := false.
1803
ea888d90dfef only warn once about bad super-message
Claus Gittinger <cg@exept.de>
parents: 1782
diff changeset
  8193
    didWarnAboutBadSupersend := false.
607
118452a23976 allow dollars in identifiers
Claus Gittinger <cg@exept.de>
parents: 603
diff changeset
  8194
118452a23976 allow dollars in identifiers
Claus Gittinger <cg@exept.de>
parents: 603
diff changeset
  8195
    "Modified: 7.9.1997 / 02:04:34 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8196
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8197
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8198
parseForCode
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8199
    "turns off certain statistics (keeping referenced variables, modified vars etc.)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8200
     Use this when parsing for compilation or evaluation"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8201
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8202
    parseForCode := true
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  8203
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  8204
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8205
setClassToCompileFor:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8206
    "set the class to be used for parsing/evaluating"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8207
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8208
    classToCompileFor := aClass.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8209
    (classToCompileFor ~~ PrevClass) ifTrue:[
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  8210
        PrevClass notNil ifTrue:[
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  8211
            Parser update:PrevClass
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  8212
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8213
    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8214
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8215
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8216
setContext:aContext
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8217
    "set the context used while evaluating"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8218
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8219
    contextToEvaluateIn := aContext
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8220
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8221
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8222
setSelf:anObject
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8223
    "set the value to be used for self while evaluating"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8224
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8225
    selfValue := anObject.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8226
    classToCompileFor := anObject class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8227
    (classToCompileFor ~~ PrevClass) ifTrue:[
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  8228
        PrevClass notNil ifTrue:[
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  8229
            Parser update:PrevClass
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  8230
        ]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8231
    ]
607
118452a23976 allow dollars in identifiers
Claus Gittinger <cg@exept.de>
parents: 603
diff changeset
  8232
!
118452a23976 allow dollars in identifiers
Claus Gittinger <cg@exept.de>
parents: 603
diff changeset
  8233
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8234
stringsAreImmutable
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8235
    ^ parserFlags stringsAreImmutable.
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8236
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8237
1615
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  8238
stringsAreImmutable:aBoolean
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8239
    parserFlags stringsAreImmutable:aBoolean.
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8240
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8241
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8242
warnUndeclared
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8243
    ^ parserFlags warnUndeclared
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8244
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8245
    "Created: 7.9.1997 / 02:05:00 / cg"
1615
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  8246
!
95cb173a5fcd immutable strings
Claus Gittinger <cg@exept.de>
parents: 1605
diff changeset
  8247
607
118452a23976 allow dollars in identifiers
Claus Gittinger <cg@exept.de>
parents: 603
diff changeset
  8248
warnUndeclared:aBoolean
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8249
    parserFlags warnUndeclared:aBoolean.
607
118452a23976 allow dollars in identifiers
Claus Gittinger <cg@exept.de>
parents: 603
diff changeset
  8250
118452a23976 allow dollars in identifiers
Claus Gittinger <cg@exept.de>
parents: 603
diff changeset
  8251
    "Created: 7.9.1997 / 02:05:00 / cg"
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  8252
!
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  8253
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8254
warnUnusedVars
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8255
    ^ parserFlags warnUnusedVars
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8256
!
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8257
1160
972e7e337891 Warn about unused method vars
Stefan Vogel <sv@exept.de>
parents: 1158
diff changeset
  8258
warnUnusedVars:aBoolean
1636
98afdcdacde8 compilerflags separated into ParserFlags.
Claus Gittinger <cg@exept.de>
parents: 1632
diff changeset
  8259
    parserFlags warnUnusedVars:aBoolean.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  8260
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  8261
84
claus
parents: 83
diff changeset
  8262
!Parser methodsFor:'statistic'!
claus
parents: 83
diff changeset
  8263
1077
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8264
rememberClassVarRead:name 
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8265
    readClassVars isNil ifTrue:[
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8266
        readClassVars := Set new
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8267
    ].
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8268
    readClassVars add:name.
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8269
    self rememberClassVarUsed:name
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8270
!
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8271
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8272
rememberClassVarUsed:name 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8273
    usedClassVars isNil ifTrue:[
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  8274
        usedClassVars := Set new
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8275
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8276
    usedClassVars add:name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8277
    self rememberVariableUsed:name
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8278
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8279
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8280
rememberGlobalUsed:name 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8281
    usedGlobals isNil ifTrue:[
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  8282
        usedGlobals := Set new
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8283
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8284
    usedGlobals add:name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8285
    self rememberVariableUsed:name
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8286
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8287
1077
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8288
rememberInstVarRead:name 
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8289
    readInstVars isNil ifTrue:[
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8290
        readInstVars := Set new
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8291
    ].
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8292
    readInstVars add:name.
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8293
    self rememberVariableUsed:name
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8294
!
e34f711bd1d1 #readInstVars & #readClassVars
Claus Gittinger <cg@exept.de>
parents: 1070
diff changeset
  8295
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8296
rememberInstVarUsed:name 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8297
    usedInstVars isNil ifTrue:[
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  8298
        usedInstVars := Set new
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8299
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8300
    usedInstVars add:name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8301
    self rememberVariableUsed:name
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8302
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8303
977
c1afbaf48a23 remember used & modified local vars;
Claus Gittinger <cg@exept.de>
parents: 971
diff changeset
  8304
rememberLocalUsed:name 
c1afbaf48a23 remember used & modified local vars;
Claus Gittinger <cg@exept.de>
parents: 971
diff changeset
  8305
    usedLocalVars isNil ifTrue:[
c1afbaf48a23 remember used & modified local vars;
Claus Gittinger <cg@exept.de>
parents: 971
diff changeset
  8306
        usedLocalVars := Set new
c1afbaf48a23 remember used & modified local vars;
Claus Gittinger <cg@exept.de>
parents: 971
diff changeset
  8307
    ].
c1afbaf48a23 remember used & modified local vars;
Claus Gittinger <cg@exept.de>
parents: 971
diff changeset
  8308
    usedLocalVars add:name.
c1afbaf48a23 remember used & modified local vars;
Claus Gittinger <cg@exept.de>
parents: 971
diff changeset
  8309
c1afbaf48a23 remember used & modified local vars;
Claus Gittinger <cg@exept.de>
parents: 971
diff changeset
  8310
!
c1afbaf48a23 remember used & modified local vars;
Claus Gittinger <cg@exept.de>
parents: 971
diff changeset
  8311
1231
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8312
rememberReturnedValue:anExpressionNode 
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8313
    |expr|
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8314
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8315
    returnedValues isNil ifTrue:[returnedValues := Set new].
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8316
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8317
    expr := anExpressionNode.
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8318
    expr isAssignment ifTrue:[
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8319
        expr := expr expression.
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8320
    ].
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8321
    (expr isConstant or:[expr isSelf]) ifTrue:[
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8322
        returnedValues add:expr
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8323
    ].
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8324
!
637e0e215633 returnValue check
Claus Gittinger <cg@exept.de>
parents: 1230
diff changeset
  8325
84
claus
parents: 83
diff changeset
  8326
rememberSelectorUsed:sel
1082
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8327
    messagesSent isNil ifTrue:[
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8328
        messagesSent := IdentitySet new.
84
claus
parents: 83
diff changeset
  8329
    ].
1082
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8330
    messagesSent add:sel 
1060
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  8331
!
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  8332
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  8333
rememberSelectorUsed:sel receiver:receiverNode
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  8334
    self rememberSelectorUsed:sel.
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  8335
    receiverNode isSuper ifTrue:[
1082
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8336
        self rememberSelectorUsedInSuperSend:sel
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8337
    ] ifFalse:[
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8338
        receiverNode isSelf ifTrue:[
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8339
            self rememberSelectorUsedInSelfSend:sel
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8340
        ].
1060
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  8341
    ].
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  8342
!
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  8343
1082
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8344
rememberSelectorUsedInSelfSend:sel
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8345
    messagesSentToSelf isNil ifTrue:[
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8346
        messagesSentToSelf := IdentitySet new.
1060
9978f9d22dde more queries (remember super messages)
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
  8347
    ].
1082
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8348
    messagesSentToSelf add:sel
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8349
!
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8350
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8351
rememberSelectorUsedInSuperSend:sel
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8352
    messagesSentToSuper isNil ifTrue:[
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8353
        messagesSentToSuper := IdentitySet new.
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8354
    ].
f795099895c5 keep track of messages sent to self (for checker)
Claus Gittinger <cg@exept.de>
parents: 1078
diff changeset
  8355
    messagesSentToSuper add:sel
84
claus
parents: 83
diff changeset
  8356
!
claus
parents: 83
diff changeset
  8357
1064
ecd50cdfb881 added #usedSymbols statistic
Claus Gittinger <cg@exept.de>
parents: 1063
diff changeset
  8358
rememberSymbolUsed:aSymbol
ecd50cdfb881 added #usedSymbols statistic
Claus Gittinger <cg@exept.de>
parents: 1063
diff changeset
  8359
    usedSymbols isNil ifTrue:[
ecd50cdfb881 added #usedSymbols statistic
Claus Gittinger <cg@exept.de>
parents: 1063
diff changeset
  8360
        usedSymbols := IdentitySet new.
ecd50cdfb881 added #usedSymbols statistic
Claus Gittinger <cg@exept.de>
parents: 1063
diff changeset
  8361
    ].
ecd50cdfb881 added #usedSymbols statistic
Claus Gittinger <cg@exept.de>
parents: 1063
diff changeset
  8362
    usedSymbols add:aSymbol 
ecd50cdfb881 added #usedSymbols statistic
Claus Gittinger <cg@exept.de>
parents: 1063
diff changeset
  8363
!
ecd50cdfb881 added #usedSymbols statistic
Claus Gittinger <cg@exept.de>
parents: 1063
diff changeset
  8364
84
claus
parents: 83
diff changeset
  8365
rememberVariableUsed:name 
claus
parents: 83
diff changeset
  8366
    usedVars isNil ifTrue:[
1576
36b4429bfa58 valid expression check
Claus Gittinger <cg@exept.de>
parents: 1575
diff changeset
  8367
        usedVars := Set new
84
claus
parents: 83
diff changeset
  8368
    ].
claus
parents: 83
diff changeset
  8369
    usedVars add:name
claus
parents: 83
diff changeset
  8370
! !
claus
parents: 83
diff changeset
  8371
1340
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8372
!Parser::ParseError methodsFor:'accessing'!
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8373
1386
10cb83add18b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1380
diff changeset
  8374
description
1434
e7d527d493d3 optional lineNumber info added to parseError
Claus Gittinger <cg@exept.de>
parents: 1432
diff changeset
  8375
    |s|
e7d527d493d3 optional lineNumber info added to parseError
Claus Gittinger <cg@exept.de>
parents: 1432
diff changeset
  8376
1461
43034b07ff08 error string of parseError
Claus Gittinger <cg@exept.de>
parents: 1460
diff changeset
  8377
    s := super description.
43034b07ff08 error string of parseError
Claus Gittinger <cg@exept.de>
parents: 1460
diff changeset
  8378
    s last isSeparator ifFalse:[
43034b07ff08 error string of parseError
Claus Gittinger <cg@exept.de>
parents: 1460
diff changeset
  8379
        errorMessage size > 0 ifTrue:[
43034b07ff08 error string of parseError
Claus Gittinger <cg@exept.de>
parents: 1460
diff changeset
  8380
            s := s , ' '
43034b07ff08 error string of parseError
Claus Gittinger <cg@exept.de>
parents: 1460
diff changeset
  8381
        ]
43034b07ff08 error string of parseError
Claus Gittinger <cg@exept.de>
parents: 1460
diff changeset
  8382
    ].
43034b07ff08 error string of parseError
Claus Gittinger <cg@exept.de>
parents: 1460
diff changeset
  8383
    s := s , (errorMessage ? '').
1434
e7d527d493d3 optional lineNumber info added to parseError
Claus Gittinger <cg@exept.de>
parents: 1432
diff changeset
  8384
    lineNumber notNil ifTrue:[
e7d527d493d3 optional lineNumber info added to parseError
Claus Gittinger <cg@exept.de>
parents: 1432
diff changeset
  8385
        s := s , ' [' , lineNumber asString , ']'
e7d527d493d3 optional lineNumber info added to parseError
Claus Gittinger <cg@exept.de>
parents: 1432
diff changeset
  8386
    ].
e7d527d493d3 optional lineNumber info added to parseError
Claus Gittinger <cg@exept.de>
parents: 1432
diff changeset
  8387
    ^ s
1386
10cb83add18b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1380
diff changeset
  8388
!
10cb83add18b *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1380
diff changeset
  8389
1340
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8390
endPosition
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8391
    ^ endPosition
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8392
!
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8393
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8394
errorMessage
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8395
    ^ errorMessage
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8396
!
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8397
1460
684fec272d87 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1458
diff changeset
  8398
errorMessage:errorMessageArg startPosition:startPositionArg 
684fec272d87 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1458
diff changeset
  8399
    errorMessage := errorMessageArg.
684fec272d87 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1458
diff changeset
  8400
    startPosition := startPositionArg.
684fec272d87 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1458
diff changeset
  8401
!
684fec272d87 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1458
diff changeset
  8402
1340
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8403
errorMessage:errorMessageArg startPosition:startPositionArg endPosition:endPositionArg 
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8404
    errorMessage := errorMessageArg.
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8405
    startPosition := startPositionArg.
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8406
    endPosition := endPositionArg.
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8407
!
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8408
1434
e7d527d493d3 optional lineNumber info added to parseError
Claus Gittinger <cg@exept.de>
parents: 1432
diff changeset
  8409
lineNumber:something
e7d527d493d3 optional lineNumber info added to parseError
Claus Gittinger <cg@exept.de>
parents: 1432
diff changeset
  8410
    lineNumber := something.
e7d527d493d3 optional lineNumber info added to parseError
Claus Gittinger <cg@exept.de>
parents: 1432
diff changeset
  8411
!
e7d527d493d3 optional lineNumber info added to parseError
Claus Gittinger <cg@exept.de>
parents: 1432
diff changeset
  8412
1340
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8413
parser
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8414
    ^ originator
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8415
!
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8416
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8417
startPosition
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8418
    ^ startPosition
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8419
! !
579fe8cd2e52 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1337
diff changeset
  8420
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8421
!Parser::PrimitiveSpecParser methodsFor:'initialization'!
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8422
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8423
initialize
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8424
    super initialize.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8425
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8426
    actionArray := actionArray copy.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8427
    actionArray at:$" codePoint put:(actionArray at:$' codePoint).
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8428
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8429
    "Created: / 01-08-2006 / 14:39:24 / cg"
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8430
! !
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8431
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8432
!Parser::PrimitiveSpecParser methodsFor:'parsing'!
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8433
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8434
parseSTVExternalFunctionDeclarationFrom:aStream definitionType:definitionType lineNr:lineNr for:aParserOrNil
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8435
    "parses ST/V function declarations of the forms 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8436
        '<api: functionName argType1 .. argTypeN returnType>' 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8437
        '<ccall: functionName argType1 .. argTypeN returnType>' 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8438
        '<ole: vFunctionIndex argType1 .. argTypeN returnType>'
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8439
    "
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8440
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8441
    |returnType functionName argTypes type 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8442
     function typeFromSTVTypeSpec virtualFunctionIndex|
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8443
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8444
    self source:aStream.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8445
    self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8446
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8447
    (definitionType = 'ole:') ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8448
        (tokenType == #Integer) ifFalse:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8449
            self parseError:'virtual function number expected (got ' , token printString , ')'.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8450
        ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8451
        virtualFunctionIndex := token.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8452
        self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8453
    ] ifFalse:[ 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8454
        (tokenType == #Identifier) ifFalse:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8455
            self parseError:'function identifier expected (got ' , token printString , ')'.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8456
        ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8457
        functionName := token asSymbol.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8458
        self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8459
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8460
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8461
    argTypes := OrderedCollection new.
1816
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  8462
    [ token notNil and:[ (token ~= '>') and:[ (tokenType ~~ #BinaryOperator) or:[tokenName ~= '>']]]] whileTrue:[
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8463
        argTypes add:(self typeMappingFor:token).
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8464
        self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8465
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8466
    returnType := argTypes last.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8467
    argTypes := argTypes copyWithoutLast:1.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8468
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8469
    function := ExternalLibraryFunction 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8470
            name:(functionName ? virtualFunctionIndex)
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8471
            module:nil 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8472
            returnType:returnType
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8473
            argumentTypes:argTypes asArray.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8474
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8475
    (definitionType = 'api:') ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8476
        function beCallTypeAPI
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8477
    ] ifFalse:[ 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8478
        (definitionType = 'ole:') ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8479
            function beCallTypeOLE
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8480
        ] ifFalse:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8481
            function beCallTypeC
1782
5f85d95bd090 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
  8482
        ].
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8483
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8484
    ^ function
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8485
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8486
    "Created: / 01-08-2006 / 16:11:24 / cg"
1782
5f85d95bd090 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
  8487
    "Modified: / 02-08-2006 / 17:24:37 / cg"
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8488
!
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8489
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8490
parseSqueakOrDolphinExternalFunctionDeclarationFrom:aStream definitionType:definitionType lineNr:lineNrArg for: aParserOrNil
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8491
    "parses squeak/dolphin function declarations of the forms 
1820
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8492
        '<stdcall: [virtual|nonVirtual][const] returnType functionNameOrIndex argType1..argTypeN>'
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8493
        '<cdecl:   [virtual|nonVirtual][const] returnType functionNameOrIndex argType1..argTypeN>' 
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8494
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8495
        '<cdecl:   [async] [virtual|nonVirtual][const] returnType functionNameOrIndex ( argType1..argTypeN ) module: moduleName >' 
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8496
        '<apicall: [async] [virtual|nonVirtual][const] returnType functionNameOrIndex ( argType1..argTypeN ) module: moduleName >'
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8497
    "
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8498
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8499
    |isVirtualCall isNonVirtualCall isAsyncCall isUnlimitedStack isConst scanningCallModifiers
1818
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8500
    returnType functionName virtualFunctionIndex argTypes moduleName argType function 
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8501
    parentized thisType|
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8502
1820
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8503
    isVirtualCall := isNonVirtualCall := isAsyncCall := isUnlimitedStack := isConst := false.
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8504
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8505
    "/ self knownDefinitions:dictionaryOfTypesOrNil.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8506
    self source:aStream.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8507
    lineNr := lineNrArg.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8508
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8509
    self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8510
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8511
    scanningCallModifiers := true.    
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8512
    [scanningCallModifiers] whileTrue:[    
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8513
        scanningCallModifiers := false.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8514
        (tokenType == #Identifier) ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8515
            (token = 'async') ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8516
                self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8517
                isAsyncCall := true.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8518
                scanningCallModifiers := true.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8519
            ] ifFalse:[ (token = 'virtual') ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8520
                self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8521
                isVirtualCall := true.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8522
                scanningCallModifiers := true.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8523
            ] ifFalse:[  (token = 'nonVirtual') ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8524
                self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8525
                isNonVirtualCall := true.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8526
                scanningCallModifiers := true.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8527
            ] ifFalse:[  (token = 'unlimitedStack') ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8528
                self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8529
                isUnlimitedStack := true.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8530
                scanningCallModifiers := true.
1820
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8531
            ] ifFalse:[  (token = 'const') ifTrue:[
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8532
                self nextToken.
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8533
                isConst := true.
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8534
                scanningCallModifiers := true.
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8535
            ]]]]]
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8536
        ]
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8537
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8538
1818
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8539
    returnType := self parseTypeSpec.
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8540
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8541
    isVirtualCall ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8542
        tokenType ~~ #Integer ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8543
            (aParserOrNil ? self) ignorableParseError:'invalid cdecl - virtual function index expected'. 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8544
            ^ nil
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8545
        ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8546
        virtualFunctionIndex := token.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8547
        self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8548
    ] ifFalse:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8549
        tokenType ~~ #String ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8550
            (aParserOrNil ? self) ignorableParseError:'invalid cdecl - functionName expected'. 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8551
            ^ nil
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8552
        ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8553
        functionName := token asSymbol.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8554
        self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8555
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8556
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8557
    tokenType = $( ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8558
        parentized := true.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8559
        self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8560
    ] ifFalse:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8561
        parentized := false.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8562
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8563
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8564
    argTypes := OrderedCollection new.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8565
    [ tokenType == #EOF
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8566
      or:[ parentized and:[tokenType = $) ]] ] whileFalse:[
1818
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8567
        argType := self parseTypeSpec.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8568
        argTypes add:argType.
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8569
        (tokenType = $, 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8570
        or:[ tokenType == #BinaryOperator and:[token = ','] ]) ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8571
            self nextToken
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8572
        ]
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8573
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8574
    tokenType = $) ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8575
        self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8576
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8577
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8578
    ((tokenType == #Identifier and:[token = 'module'])
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8579
    or:[tokenType == #Keyword and:[ token = 'module:']]) ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8580
        self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8581
        tokenType == $: ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8582
            self nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8583
        ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8584
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8585
        tokenType ~~ #String ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8586
            (aParserOrNil ? self) ignorableParseError:'Invalid declaration - moduleName expected'.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8587
            ^ nil
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8588
        ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8589
        moduleName := token asSymbol.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8590
    ].
1816
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  8591
    (argTypes size == 1 and:[argTypes first == #void "isCVoid"]) ifTrue:[
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8592
        argTypes := #()
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8593
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8594
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8595
    isNonVirtualCall ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8596
        (classToCompileFor isSubclassOf:ExternalStructure) ifTrue:[
1816
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  8597
            thisType := classToCompileFor name.    
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  8598
"/            (thisType := classToCompileFor cType) isNil ifTrue:[ 
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  8599
"/                "/ self warning:'missing CType definition in ' , tok printString.
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  8600
"/                thisType := CType newStructType.
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  8601
"/                thisType name:(classToCompileFor nameWithoutPrefix).
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  8602
"/                thisType := CType pointerTypeClass new baseType:thisType.
408690039009 *** empty log message ***
ca
parents: 1812
diff changeset
  8603
"/            ].
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8604
        ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8605
        thisType := thisType ? #pointer.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8606
        argTypes := (Array with:thisType) , argTypes.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8607
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8608
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8609
    function := ExternalLibraryFunction 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8610
            name:(functionName ? virtualFunctionIndex)
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8611
            module:moduleName 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8612
            returnType:returnType
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8613
            argumentTypes:argTypes asArray.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8614
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8615
    (definitionType = 'apicall:') ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8616
        function beCallTypeAPI
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8617
    ] ifFalse:[ 
1782
5f85d95bd090 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
  8618
        (definitionType = 'olecall:') ifTrue:[
5f85d95bd090 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
  8619
            function beCallTypeOLE
5f85d95bd090 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
  8620
        ] ifFalse:[
5f85d95bd090 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
  8621
            function beCallTypeC
5f85d95bd090 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
  8622
        ].
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8623
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8624
    isNonVirtualCall ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8625
        function beNonVirtualCPP
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8626
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8627
    isAsyncCall ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8628
        function beAsync
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8629
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8630
    isUnlimitedStack ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8631
        function beUnlimitedStack
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8632
    ].
1820
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8633
    isConst ifTrue:[
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8634
        function beConstReturnValue
a8e315786148 const specifier (is this a good name ?)
ca
parents: 1819
diff changeset
  8635
    ].
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8636
    ^ function
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8637
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8638
    "Created: / 01-08-2006 / 15:02:45 / cg"
1782
5f85d95bd090 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1780
diff changeset
  8639
    "Modified: / 02-08-2006 / 17:27:22 / cg"
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8640
!
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8641
1818
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8642
parseTypeSpec
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8643
    |type typeName ns cls|
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8644
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8645
    typeName := token.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8646
    self nextToken.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8647
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8648
    ((tokenType == #'::') or:[(tokenType == #'.')]) ifTrue:[
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8649
        "/ namespace...
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8650
        [(tokenType == #'::')  or:[(tokenType == #'.')]] whileTrue:[
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8651
            typeName := typeName , '::'.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8652
            self nextToken.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8653
            tokenType ~~ #Identifier ifTrue:[
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8654
                self parseError:'invalid type identifier'.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8655
            ].
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8656
            typeName := typeName , token.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8657
            self nextToken.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8658
         ]
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8659
    ].
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8660
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8661
    type := self typeMappingFor:typeName.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8662
    ((tokenType = $*) or:[(tokenType == #BinaryOperator) and:[tokenName = '*']]) ifTrue:[
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8663
        type := self pointerTypeMappingFor:type.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8664
        self nextToken.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8665
    ].
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8666
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8667
    type first isUppercase ifTrue:[
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8668
        (ns := classToCompileFor nameSpace) notNil ifTrue:[
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8669
            cls := ns at:type.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8670
        ].
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8671
        cls isNil ifTrue:[
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8672
            cls := Smalltalk at:type.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8673
        ].
1819
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
  8674
        cls isNil ifTrue:[
1818
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8675
            self warning:'possibly unknown type: ', type allBold
1819
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
  8676
        ] ifFalse:[
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
  8677
            cls autoload.    
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
  8678
            (cls isSubclassOf:ExternalBytes) ifFalse:[
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
  8679
                self warning:'possibly wrong type: ', type allBold
77cd2c32df81 autoload prim-types if required
ca
parents: 1818
diff changeset
  8680
            ].
1818
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8681
            type := cls name.
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8682
        ].
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8683
    ].
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8684
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8685
    ^ type
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8686
!
918baf269481 *** empty log message ***
ca
parents: 1817
diff changeset
  8687
1780
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8688
parseVWTypeOrExternalFunctionDeclarationFrom:aStream definitionType:definitionType knownDefinitions:dictionaryOfTypesOrNil lineNr:lineNr for:aParser
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8689
    "parses visualWorks type/function declarations of the form: 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8690
        '<c: ...>'"
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8691
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8692
    |cParser returnType functionName argTypes moduleName type 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8693
     nameAndFunctionOrType functionOrType function |
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8694
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8695
    CParser isNil ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8696
        self generateTrapCodeForUnavailableCParser.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8697
        ^ self.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8698
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8699
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8700
    cParser := CParser new.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8701
    cParser knownDefinitions:dictionaryOfTypesOrNil.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8702
    cParser allowRedefinitions:true.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8703
    cParser source:aStream scannerClass:CDeclScanner.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8704
    cParser nextToken.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8705
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8706
    cParser tokenType == #struct ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8707
        type := cParser type.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8708
    ] ifFalse:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8709
        cParser tokenType == #typedef ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8710
            type := cParser typedef.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8711
        ] ifFalse:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8712
            nameAndFunctionOrType := cParser typeOrFunctionDeclaration.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8713
            functionOrType := nameAndFunctionOrType second.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8714
            functionOrType isCFunction ifFalse:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8715
                type := functionOrType.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8716
                function := nil.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8717
            ] ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8718
                function := functionOrType.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8719
                type := nil.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8720
            ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8721
        ]
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8722
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8723
    cParser token notNil ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8724
        (aParser ? self) ignorableParseError:'invalid cdecl - nothing more expected'.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8725
        ^ nil.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8726
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8727
    type notNil ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8728
        ^ type.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8729
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8730
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8731
    moduleName isNil ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8732
        moduleName := classToCompileFor theNonMetaclass libraryName asSymbol.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8733
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8734
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8735
    function := ExternalLibraryFunction 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8736
            name:function name 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8737
            module:moduleName 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8738
            returnType:function returnType
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8739
            argumentTypes:function argumentTypes asArray.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8740
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8741
    function beCallTypeC.    
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8742
    ^ function
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8743
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8744
    "Created: / 01-08-2006 / 16:18:05 / cg"
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8745
! !
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8746
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8747
!Parser::PrimitiveSpecParser methodsFor:'parsing-primitives & pragmas'!
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8748
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8749
pointerTypeMappingFor: aTypeSymbol
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8750
    |e|
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8751
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8752
    e := #(
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8753
        (char            charPointer    )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8754
        (void            voidPointer    )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8755
    ) detect:[:p | p first = aTypeSymbol] ifNone:nil.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8756
    e notNil ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8757
        ^ e second
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8758
    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8759
    ^ aTypeSymbol asSymbol
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8760
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8761
    "Created: / 01-08-2006 / 15:33:53 / cg"
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8762
!
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8763
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8764
typeMappingFor:aTypeSymbol
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8765
    |e|
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8766
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8767
    e := #(
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8768
        (short           int16          )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8769
        (long            int32          )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8770
        (int             int32          )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8771
        (ushort          uint16         )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8772
        (unsignedShort   uint16         )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8773
        (ulong           uint32         )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8774
        (unsignedLong    uint32         )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8775
        (double          double         )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8776
        (float           float          )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8777
        (char            char           )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8778
        (uchar           uint8          )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8779
        (unsignedChar    uint8          )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8780
        (void            void           )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8781
        (bool            bool           )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8782
        (byte            uint8          )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8783
        (dword           uint32         )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8784
        (sdword          int32          )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8785
        (word            uint16         )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8786
        (sword           int16          )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8787
        (handle          voidPointer    )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8788
        (lpstr           charPointer    )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8789
        (hresult         uint32         )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8790
        (boolean         bool           )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8791
        (ulongReturn     uint32         )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8792
        (none            void           )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8793
        (struct          voidPointer    )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8794
        (structIn        voidPointer    )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8795
        (structOut       voidPointer    )
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8796
    ) detect:[:p | p first = aTypeSymbol] ifNone:nil.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8797
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8798
    e notNil ifTrue:[ ^ e second ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8799
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8800
"/ the following is now done in ExternalFunction (if at all), as the ctype is not required to
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8801
"/ be present right now, and also to allow for stc-compilation, where no
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8802
"/ ctypes are avaliable at all.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8803
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8804
"/            e isNil ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8805
"/                cls := classToCompileFor nameSpace classNamed:tok.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8806
"/                cls isNil ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8807
"/                    cls := Smalltalk classNamed:tok.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8808
"/                ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8809
"/                cls notNil ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8810
"/                    (cls isSubclassOf:ExternalStructure) ifTrue:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8811
"/                        (cType := cls cType) isNil ifTrue:[ 
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8812
"/                            "/ self warning:'missing CType definition in ' , tok printString.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8813
"/                            cType := CType newStructType.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8814
"/                            cType name:cls name.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8815
"/                        ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8816
"/                        cType
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8817
"/                    ] ifFalse:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8818
"/                        cls
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8819
"/                    ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8820
"/                ] ifFalse:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8821
"/                    self parseError:'ulong, ushort, or another valid Squeak type identifier expected (got ' , tok printString , ')'.
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8822
"/                    nil
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8823
"/                ]
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8824
"/            ] ifFalse:[
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8825
"/                e second
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8826
"/            ].
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8827
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8828
    ^ aTypeSymbol asSymbol
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8829
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8830
    "Created: / 01-08-2006 / 15:35:52 / cg"
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8831
! !
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8832
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8833
!Parser::PrimitiveSpecParser methodsFor:'reading next token'!
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8834
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8835
isCommentCharacter:ch
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8836
    "no comments"
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8837
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8838
    ^ false
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8839
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8840
    "Created: / 01-08-2006 / 14:54:48 / cg"
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8841
! !
572da5701f89 rewrite & cleanup of primitive parsing code
Claus Gittinger <cg@exept.de>
parents: 1779
diff changeset
  8842
1399
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8843
!Parser::UndefinedVariableNotification methodsFor:'accessing'!
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8844
1514
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  8845
description
1516
9e981654a0f5 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 1515
diff changeset
  8846
    ^ 'undefined variable: ' , self variableName
1514
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  8847
!
cf0c183c5ad9 description
Claus Gittinger <cg@exept.de>
parents: 1512
diff changeset
  8848
1399
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8849
parser
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8850
    "return the value of the instance variable 'parser' (automatically generated)"
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8851
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8852
    ^ parser
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8853
!
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8854
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8855
parser:something
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8856
    "set the value of the instance variable 'parser' (automatically generated)"
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8857
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8858
    parser := something.
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8859
!
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8860
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8861
variableName
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8862
    ^ parameter
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8863
! !
95b2eaa4e457 undefinedVariableNotification fix
Claus Gittinger <cg@exept.de>
parents: 1398
diff changeset
  8864
358
78b0d8954c49 removed possible conflict between #classVarNames here and in Class.
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
  8865
!Parser class methodsFor:'documentation'!
148
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 145
diff changeset
  8866
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 145
diff changeset
  8867
version
1855
61936f01108e error messages shortened and cleanup
Claus Gittinger <cg@exept.de>
parents: 1842
diff changeset
  8868
    ^ '$Header: /cvs/stx/stx/libcomp/Parser.st,v 1.520 2006-08-22 12:42:34 cg Exp $'
148
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 145
diff changeset
  8869
! !
1322
da25e31f423c autodefine workspace variables
Claus Gittinger <cg@exept.de>
parents: 1315
diff changeset
  8870
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  8871
Parser initialize!