Parser.st
author Claus Gittinger <cg@exept.de>
Thu, 08 Feb 1996 22:04:55 +0100
changeset 207 6ab9eb3c1cf0
parent 202 77ac1f0c15df
child 210 b22f4472833b
permissions -rw-r--r--
by default, dont warn about ST80 directives
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
     1
"
4
f6fd83437415 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
     3
	      All Rights Reserved
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
     4
7ad01559b262 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
7ad01559b262 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
7ad01559b262 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
7ad01559b262 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
7ad01559b262 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
7ad01559b262 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    11
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
    12
7ad01559b262 Initial revision
claus
parents:
diff changeset
    13
Scanner subclass:#Parser
165
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    14
	instanceVariableNames:'classToCompileFor selfValue contextToEvaluateIn selector
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    15
		methodArgs methodArgNames methodVars methodVarNames tree
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    16
		currentBlock parseForCode usedInstVars usedClassVars usedVars
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    17
		modifiedInstVars modifiedClassVars modifiedGlobals usesSuper
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    18
		usedGlobals usedSymbols usedMessages localVarDefPosition
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    19
		evalExitBlock selfNode superNode hasPrimitiveCode
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    20
		hasNonOptionalPrimitiveCode primitiveNr primitiveResource logged
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    21
		warnedUndefVars warnSTXHereExtensionUsed correctedSource'
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    22
	classVariableNames:'PrevClass PrevInstVarNames PrevClassVarNames
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    23
		PrevClassInstVarNames LazyCompilation ArraysAreImmutable
207
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
    24
		ImplicitSelfSends WarnST80Directives'
165
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    25
	poolDictionaries:''
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
    26
	category:'System-Compiler'
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    27
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    28
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    29
!Parser class methodsFor:'documentation'!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    30
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    31
copyright
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    32
"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    33
 COPYRIGHT (c) 1989 by Claus Gittinger
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    34
	      All Rights Reserved
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    35
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    36
 This software is furnished under a license and may be used
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    37
 only in accordance with the terms of that license and with the
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    38
 inclusion of the above copyright notice.   This software may not
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    39
 be provided or otherwise made available to, or used by, any
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    40
 other person.  No title to or ownership of the software is
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    41
 hereby transferred.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    42
"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    43
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    44
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    45
documentation
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    46
"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    47
    Parser is used for both parsing and evaluating smalltalk expressions;
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    48
    it first builds a parseTree which is then interpreted (evaluate) or
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    49
    compiled. Compilation is done in the subclass ByteCodeCompiler and/or
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    50
    the (planned) MachineCodeCompiler.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    51
173
247ae4b8af76 interest is written with one 'r' (shame on me)
Claus Gittinger <cg@exept.de>
parents: 171
diff changeset
    52
    methods of main interest are:
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    53
	Parser evaluateExpression:...
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    54
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    55
    and:
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    56
	Parser parseExpression:...
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    57
	Parser parseMethod:...
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    58
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    59
    there is protocol to parse complete methods, selector specs, body only etc.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    60
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    61
    Parser is also used to find the referenced/modified inst/classvars of
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    62
    a method - this is done by sending parseXXX message to a parser and asking
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    63
    the parser for referencedXVars or modifiedXVars (see SystemBrowser).
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    64
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    65
    You can also use parsers for all kinds of other things (ChangesBrowser for
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    66
    example analyzes the expressions in the changelist ...) by looking at the
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    67
    parsers tree. (Although this is somewhat dangerous, since it exports the
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    68
    compilers internals ... better style is to add specialized query methods here,
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
    69
    which will be done incrementally.)
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    70
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    71
    One instance of Parser is created to parse one method or expression - i.e.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    72
    its not suggested to reuse parsers.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    73
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    74
    Instance variables:
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    75
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    76
	classToCompileFor   <Class>             the class (or nil) we are compiling for
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    77
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    78
	selfValue           <any>               value to use as self when interpreting
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    79
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    80
	contextToEvaluateIn <Context>           the context (or nil) when interpreting
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    81
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    82
	selector            <Symbol>            the selector of the parsed method
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    83
						(valid after parseMethodSpecification)
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    84
	methodArgs                              internal
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    85
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    86
	methodArgNames      <Collection>        the names of the arguments
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    87
						(valid after parseMethodSpecification)
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    88
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    89
	methodVars                              internal
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    90
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    91
	methodVarNames      <Collection>        the names of the method locals
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    92
						(valid after parseMethodBodyVarSpec)
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    93
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    94
	tree                <ParseTree>         the parse tree - valid after parsing
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    95
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    96
	currentBlock                            if currently parsing for a block
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
    97
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    98
	usedInstVars                            set of all accessed instances variables
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
    99
						(valid after parsing)
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   100
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   101
	usedClassVars                           same for classVars
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   102
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   103
	usedVars                                all used variables (inst, class & globals)
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   104
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   105
	modifiedInstVars                        set of all modified instance variables
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   106
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   107
	modifiedClassVars                       same for clasVars
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   108
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   109
	localVarDefPosition <Integer>           the character offset of the local variable
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   110
						def. (i.e. the first '|' if any)
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   111
						Not yet used - prepared for automatic add of
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   112
						undefined variables
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   113
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   114
	evalExitBlock                           internal for interpretation
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   115
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   116
	selfNode            <Node>              cached one-and-only 'self' node
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   117
	superNode           <Node>              cached one-and-only 'super' node
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   118
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   119
	hasPrimitiveCode    <Boolean>           true, if it contains ST/X style primitive code
126
Claus Gittinger <cg@exept.de>
parents: 120
diff changeset
   120
	hasNonOptionalPrimitiveCode    
Claus Gittinger <cg@exept.de>
parents: 120
diff changeset
   121
			    <Boolean>           true, if it contains ST/X style primitive code
Claus Gittinger <cg@exept.de>
parents: 120
diff changeset
   122
						which is NOT flagged by the OPTIONAL directive.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   123
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   124
	primitiveNr         <Integer>           the parsed ST-80 type primitive number (or nil)
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   125
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   126
	logged
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   127
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   128
	warnedUndefVars     <Set>               set of all variables which the parser has
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   129
						already output a warning (to avoid multiple
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   130
						warnings about the same variable)
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   131
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   132
    Class variables:
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   133
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   134
	PrevClass           <Class>             class, of which properties are
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   135
						cached in:
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   136
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   137
	PrevInstVarNames      <Collection>      instance variablenames of cached class
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   138
	PrevClassVarNames     <Collection>      class variablenames of cached class
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   139
	PrevClassInstVarNames <Collection>      class instance variablenames of cached class
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   140
66
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   141
	LazyCompilation       <Boolean>         EXPERIMENTAL: lazy compilation
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   142
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   143
	ArraysAreImmutable    <Boolean>         if true, create array literals
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   144
						as instances of ImmutableArray,
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   145
						which cannot be stored into.
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   146
						Default is false, for compatibility.
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   147
						Can be turned on while developping
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   148
						new code to make certain that side
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   149
						effects are avoided.
207
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
   150
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
   151
	WarnST80Directives    <Boolean>         if true, give warnings about
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
   152
						ST-80 directives (resource defs)
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
   153
						which are ignored in st/x.
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
   154
						defaults to false.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   155
"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   156
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   157
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   158
!Parser class methodsFor:'instance creation'!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   159
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   160
for:aStringOrStream in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   161
    "return a new parser, reading code for aClass from aStringOrStream"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   162
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   163
    |parser|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   164
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   165
    parser := self for:aStringOrStream.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   166
    parser setClassToCompileFor:aClass.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   167
    ^ parser
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   168
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   169
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   170
!Parser class methodsFor:'changes'!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   171
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   172
flushNameCache
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   173
    "unconditional flush name caches"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   174
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   175
    PrevClass notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   176
	PrevClass removeDependent:Parser
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   177
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   178
    PrevClass := nil.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   179
    PrevInstVarNames := nil.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   180
    PrevClassVarNames := nil.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   181
    PrevClassInstVarNames := nil.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   182
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   183
    "Parser flushNameCache"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   184
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   185
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   186
update:something with:someArgument from:changedObject
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   187
    "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
   188
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   189
    (changedObject == PrevClass) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   190
	something == #definition ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   191
	    self flushNameCache
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   192
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   193
    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   194
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   195
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   196
!Parser class methodsFor:'controlling compilation'!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   197
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   198
arraysAreImmutable
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   199
    "return true if arrays are immutable literals"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   200
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   201
    ^ ArraysAreImmutable
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   202
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   203
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   204
arraysAreImmutable:aBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   205
    "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
   206
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   207
    ArraysAreImmutable := aBoolean.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   208
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   209
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   210
     can be added to your private.rc file:
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   211
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   212
     Compiler arraysAreImmutable:true     
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   213
     Compiler arraysAreImmutable:false      
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   214
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   215
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   216
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   217
compileLazy
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   218
    "return true if compiling lazy"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   219
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   220
    ^ LazyCompilation.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   221
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   222
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   223
compileLazy:aBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   224
    "turn on/off lazy compilation - return previous setting.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   225
     Actually this flag belongs into the ByteCodeCompiler subclass,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   226
     but it also controls the reporting of some errors here; therefore
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   227
     its located here"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   228
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   229
    |oldLazy|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   230
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   231
    oldLazy := LazyCompilation.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   232
    LazyCompilation := aBoolean.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   233
    ^ oldLazy
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   234
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   235
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   236
     usually set in your .rc file
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   237
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   238
     Compiler compileLazy:false         
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   239
     Compiler compileLazy:true          
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   240
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   241
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   242
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   243
implicitSelfSends
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   244
    "return true if undefined variables with
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   245
     lowercase first character are to be turned
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   246
     into implicit self sends"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   247
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   248
    ^ ImplicitSelfSends
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   249
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   250
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   251
implicitSelfSends:aBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   252
    "turn on/off implicit self sends"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   253
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   254
    ImplicitSelfSends := aBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   255
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   256
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   257
     Compiler implicitSelfSends:true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   258
     Compiler implicitSelfSends:false 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   259
    "
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   260
! !
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   261
7ad01559b262 Initial revision
claus
parents:
diff changeset
   262
!Parser class methodsFor:'evaluating expressions'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   263
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   264
evaluate:aStringOrStream
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   265
    "return the result of evaluating an expression in aStringOrStream.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   266
     No doit-entry is added to the changeLog."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   267
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   268
    ^ self 
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   269
	evaluate:aStringOrStream 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   270
	in:nil 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   271
	receiver:nil 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   272
	notifying:nil 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   273
	logged:false
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   274
	ifFail:nil 
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   275
	compile:true
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   276
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   277
    "
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   278
     Compiler evaluate:'1 + 2'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   279
     Compiler evaluate:'''hello world'' asSortedCollection displayString printNL'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   280
     Compiler evaluate:'''hello world'' asSortedCollection printNL'
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   281
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   282
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   283
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   284
evaluate:aStringOrStream compile:compile
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   285
    "return the result of evaluating aString, 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   286
     The compile argument specifies if the string should be compiled down to 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   287
     bytecode or instead be interpreted from the parseTree.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   288
     The first should be done for doIts etc, where a readable walkback is
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   289
     required.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   290
     The latter is better done for constants, styleSheet and resource
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   291
     reading and simple sends, where the overhead of compilation is bigger
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   292
     than the interpretation overhead."
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   293
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   294
    ^ self 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   295
	evaluate:aStringOrStream
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   296
	in:nil
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   297
	receiver:nil 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   298
	notifying:nil 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   299
	logged:false
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   300
	ifFail:nil
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   301
	compile:compile 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   302
!
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   303
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   304
evaluate:aStringOrStream ifFail:failBlock
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   305
    "return the result of evaluating an expression in aStringOrStream.
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   306
     In case of any syntax errors, return the value of failBlock.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   307
     No doit-entry is added to the changeLog."
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   308
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   309
    ^ self 
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   310
	evaluate:aStringOrStream 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   311
	in:nil 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   312
	receiver:nil 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   313
	notifying:nil 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   314
	logged:false
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   315
	ifFail:failBlock 
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   316
	compile:true
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   317
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   318
     Compiler evaluate:'1 +' ifFail:['oops']   
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   319
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   320
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   321
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   322
evaluate:aStringOrStream in:aContext receiver:anObject notifying:requestor ifFail:failBlock
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   323
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   324
     Allow access to anObject as self and to its instVars (used in the inspector).
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   325
     No doIt entry is added to the change-file. 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   326
     If the failBlock argument is non-nil, it is evaluated if an error occurs."
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   327
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   328
    ^ self 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   329
	evaluate:aStringOrStream
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   330
	in:nil
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   331
	receiver:anObject
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   332
	notifying:requestor
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   333
	logged:false
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   334
	ifFail:nil
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   335
	compile:true
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   336
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   337
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   338
evaluate:aStringOrStream in:aContext receiver:anObject notifying:requestor logged:logged ifFail:failBlock
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   339
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   340
     Allow access to anObject as self and to its instVars (used in the inspector).
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   341
     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
   342
     is non-nil, it is evaluated if an error occurs."
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   343
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   344
    ^ self 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   345
	evaluate:aStringOrStream
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   346
	in:aContext
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   347
	receiver:anObject
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   348
	notifying:requestor
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   349
	logged:logged 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   350
	ifFail:failBlock 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   351
	compile:true
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   352
!
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   353
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   354
evaluate:aStringOrStream in:aContext receiver:anObject notifying:requestor logged:logged ifFail:failBlock compile:compile
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   355
    "return the result of evaluating aStringOrStream, errors are reported to requestor. 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   356
     Allow access to anObject as self and to its instVars (used in the inspector).
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   357
     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
   358
     is non-nil, it is evaluated if an error occurs.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   359
     Finally, compile specifies if the string should be compiled down to 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   360
     bytecode or instead be interpreted from the parseTree.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   361
     The first should be done for doIts etc, where a readable walkback is
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   362
     required.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   363
     The latter is better done for constants, styleSheet and resource
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   364
     reading and simple sends, where the overhead of compilation is bigger
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   365
     than the interpretation overhead."
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   366
52
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   367
    |parser tree mustBackup loggedString chgStream value s sReal m|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   368
7ad01559b262 Initial revision
claus
parents:
diff changeset
   369
    aStringOrStream isNil ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   370
    aStringOrStream isStream ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   371
	parser := self for:aStringOrStream.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   372
	mustBackup := true
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   373
    ] ifFalse:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   374
	loggedString := aStringOrStream.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   375
	parser := self for:(ReadStream on:aStringOrStream).
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   376
	mustBackup := false
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   377
    ].
84
claus
parents: 83
diff changeset
   378
    parser parseForCode. 
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   379
    parser setSelf:anObject.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   380
    parser setContext:aContext.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   381
    parser notifying:requestor.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   382
    parser nextToken.
79
26f81a94a6ea *** empty log message ***
claus
parents: 78
diff changeset
   383
    tree := parser parseMethodBodyOrEmpty.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   384
7ad01559b262 Initial revision
claus
parents:
diff changeset
   385
    "if reading from a stream, backup for next expression"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   386
    mustBackup ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   387
	parser backupPosition
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   388
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   389
7ad01559b262 Initial revision
claus
parents:
diff changeset
   390
    (parser errorFlag or:[tree == #Error]) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   391
	failBlock notNil ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   392
	    ^ failBlock value
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   393
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   394
	^ #Error
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   395
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   396
    tree notNil ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   397
	(logged
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   398
	and:[loggedString notNil
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   399
	and:[Smalltalk logDoits]]) ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   400
	    chgStream := Class changesStream.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   401
	    chgStream notNil ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   402
		chgStream nextChunkPut:loggedString.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   403
		chgStream cr.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   404
		chgStream close
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   405
	    ].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   406
	].
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
   407
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
   408
	"
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   409
	 if compile is false, or the parse tree is that of a constant, 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   410
	 quickly return its value.
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   411
	 This is used for example, when reading simple objects
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   412
	 via #readFrom:. 
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
   413
	 The overhead of compiling a method is avoided in this case.
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
   414
	"
76
55d64cb1ffea *** empty log message ***
claus
parents: 71
diff changeset
   415
	(compile not 
55d64cb1ffea *** empty log message ***
claus
parents: 71
diff changeset
   416
	 or:[tree isConstant
55d64cb1ffea *** empty log message ***
claus
parents: 71
diff changeset
   417
	 or:[aStringOrStream isStream]]) ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
   418
	    ^ tree evaluate
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
   419
	] ifFalse:[
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
   420
	    "
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
   421
	     if I am the ByteCodeCompiler,
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
   422
	     generate a dummy method, execute it and return the value.
52
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   423
	     otherwise, just evaluate the tree; slower, but not too bad ...
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   424
	     This allows systems to be delivered without the ByteCodeCompiler,
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   425
	     and still evaluate expressions (neede for example, to read resource
53
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   426
	     files or to process .rc files).
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
   427
	    "
52
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   428
	    self == Parser ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
   429
		parser evalExitBlock:[:value | parser release. ^ value].
51
124369e443f8 *** empty log message ***
claus
parents: 50
diff changeset
   430
		value := tree evaluate.
124369e443f8 *** empty log message ***
claus
parents: 50
diff changeset
   431
		parser evalExitBlock:nil.
52
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   432
	    ] ifFalse:[
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   433
		aStringOrStream isStream ifTrue:[
76
55d64cb1ffea *** empty log message ***
claus
parents: 71
diff changeset
   434
		    s := parser collectedSource.  "/ does not work yet ...
52
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   435
		] ifFalse:[
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   436
		    s := aStringOrStream
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   437
		].
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   438
		sReal := 'doIt ^[\' withCRs , s , '\] value' withCRs.
87
claus
parents: 86
diff changeset
   439
		m := self 
claus
parents: 86
diff changeset
   440
			compile:sReal 
claus
parents: 86
diff changeset
   441
			forClass:anObject class
claus
parents: 86
diff changeset
   442
			inCategory:'_temporary_' 
claus
parents: 86
diff changeset
   443
			notifying:requestor 
claus
parents: 86
diff changeset
   444
			install:false 
claus
parents: 86
diff changeset
   445
			skipIfSame:false 
claus
parents: 86
diff changeset
   446
			silent:true.
52
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   447
		m notNil ifTrue:[
53
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   448
		    m ~~ #Error ifTrue:[
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   449
			"
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   450
			 fake: patch the source string, to what the user expects
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   451
			 in the browser
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   452
			"
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   453
			m source:'       \' withCRs , s .
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   454
			value := m valueWithReceiver:anObject 
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   455
					   arguments:#() 
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   456
					    selector:#doIt 
61
eef9f154de6d *** empty log message ***
claus
parents: 60
diff changeset
   457
					      search:nil
eef9f154de6d *** empty log message ***
claus
parents: 60
diff changeset
   458
					      sender:nil.
53
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   459
		    ] ifFalse:[
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   460
			parser evalExitBlock:[:value | parser release. ^ value].
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   461
			value := tree evaluate.
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   462
			parser evalExitBlock:nil.
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
   463
		    ]
52
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   464
		].
d80ec10c3321 *** empty log message ***
claus
parents: 51
diff changeset
   465
	    ]
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
   466
	]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   467
    ].
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
   468
    parser release.
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
   469
    ^ value
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   470
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   471
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   472
evaluate:aStringOrStream logged:logged
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   473
    "return the result of evaluating an expression in aStringOrStream.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   474
     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
   475
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   476
    ^ self 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   477
	evaluate:aStringOrStream 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   478
	in:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   479
	receiver:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   480
	notifying:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   481
	logged:logged
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   482
	ifFail:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   483
	compile:true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   484
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   485
     Compiler evaluate:'''some string''' logged:false   
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   486
     Compiler evaluate:'''some string''' logged:true   
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   487
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   488
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   489
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   490
evaluate:aStringOrStream notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   491
    "return the result of evaluating aString, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   492
     errors are reported to requestor"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   493
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   494
    ^ self 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   495
	evaluate:aStringOrStream 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   496
	in:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   497
	receiver:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   498
	notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   499
	logged:false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   500
	ifFail:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   501
	compile: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
evaluate:aStringOrStream notifying:requestor compile:compile
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   505
    "return the result of evaluating aString, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   506
     errors are reported to requestor.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   507
     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
   508
     bytecode or instead be interpreted from the parseTree.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   509
     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
   510
     required.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   511
     The latter is better done for constants, styleSheet and resource
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   512
     reading and simple sends, where the overhead of compilation is bigger
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   513
     than the interpretation overhead."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   514
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   515
    ^ self 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   516
	evaluate:aStringOrStream 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   517
	in:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   518
	receiver:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   519
	notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   520
	logged:false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   521
	ifFail:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   522
	compile:compile
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   523
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   524
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   525
evaluate:aStringOrStream receiver:anObject notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   526
    "return the result of evaluating aString, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   527
     errors are reported to requestor. Allow access to
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   528
     anObject as self and to its instVars (used in the inspector)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   529
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   530
    ^ self 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   531
	evaluate:aStringOrStream
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   532
	in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   533
	receiver:anObject
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   534
	notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   535
	logged:false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   536
	ifFail:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   537
	compile:true
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
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   540
     Compiler evaluate:'self x' receiver:(1 @ 2) notifying:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   541
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   542
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   543
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   544
evaluate:aStringOrStream receiver:anObject notifying:requestor compile:compile
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   545
    "return the result of evaluating aString, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   546
     errors are reported to requestor. Allow access to
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   547
     anObject as self and to its instVars (used in the inspector).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   548
     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
   549
     bytecode or instead be interpreted from the parseTree.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   550
     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
   551
     required.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   552
     The latter is better done for constants, styleSheet and resource
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   553
     reading and simple sends, where the overhead of compilation is bigger
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   554
     than the interpretation overhead."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   555
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   556
    ^ self 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   557
	evaluate:aStringOrStream
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   558
	in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   559
	receiver:anObject
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   560
	notifying:requestor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   561
	logged:false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   562
	ifFail:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   563
	compile:compile 
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   564
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   565
66
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   566
!Parser class methodsFor:'initialization '!
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   567
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   568
initialize
98
claus
parents: 97
diff changeset
   569
    LazyCompilation := false.      "/ usually set to true in your .rc file
claus
parents: 97
diff changeset
   570
    ArraysAreImmutable := false.   "/ usually left true for ST-80 compatibility
207
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
   571
    ImplicitSelfSends := false.
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
   572
    WarnST80Directives := false.
66
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   573
! !
366136954049 *** empty log message ***
claus
parents: 64
diff changeset
   574
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   575
!Parser class methodsFor:'parsing'!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   576
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   577
parseExpression:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   578
    "parse aString as an expression; 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   579
     Return the parseTree (if ok), nil (for an empty string 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   580
     or comment only) or #Error (syntactic error)."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   581
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   582
    ^ self withSelf:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   583
	   parseExpression:aString 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   584
	   notifying:nil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   585
	   ignoreErrors:true       "silence on Transcript"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   586
	   ignoreWarnings:true 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   587
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   588
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   589
parseMethod:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   590
    "parse a method.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   591
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   592
     The parser can be queried for selector, receiver, args, locals,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   593
     used selectors etc."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   594
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   595
    ^ self parseMethod:aString in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   596
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   597
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   598
     |p|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   599
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   600
     p := Parser 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   601
	     parseMethod:'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   602
		 foo:arg1 bar:arg2 baz:arg3 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   603
		     |l1 l2| 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   604
		     l1 := 0. 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   605
		     l2 := arg1. 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   606
		     ^ self'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   607
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   608
     'nArgs:  ' print. p numberOfMethodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   609
     'args:   ' print. p methodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   610
     'sel:    ' print. p selector printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   611
     'nLocal: ' print. p numberOfMethodVars printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   612
     'locals: ' print. p methodVars printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   613
     'tree:   ' printNL. p tree printAllOn:Stdout. Stdout cr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   614
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   615
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   616
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   617
parseMethod:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   618
    "parse a method in a given class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   619
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   620
     The parser can be queried for selector, receiver, args, locals,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   621
     used selectors, modified instvars, referenced classvars etc."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   622
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   623
    ^ self parseMethod:aString in:aClass 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   624
	ignoreErrors:false 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   625
	ignoreWarnings:false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   626
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   627
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   628
parseMethod:aString in:aClass ignoreErrors:noErrors ignoreWarnings:noWarnings
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   629
    "parse a method in a given class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   630
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   631
     The parser can be queried for selector, receiver, args, locals,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   632
     used selectors, modified instvars, referenced classvars etc."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   633
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   634
    |parser tree|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   635
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   636
    aString isNil ifTrue:[^ nil].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   637
    parser := self for:(ReadStream on:aString) in:aClass.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   638
    noErrors ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   639
	parser ignoreErrors
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   640
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   641
    noWarnings ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   642
	parser ignoreWarnings
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   643
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   644
    tree := parser parseMethod.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   645
    (parser errorFlag or:[tree == #Error]) ifTrue:[^ nil].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   646
    ^ parser
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   647
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   648
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   649
parseMethod:aString in:aClass warnings:warnBoolean
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   650
    "parse a method in a given class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   651
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   652
     The parser can be queried for selector, receiver, args, locals,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   653
     used selectors, modified instvars, referenced classvars etc.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   654
     This method is obsolete, and left in for backward compatibility."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   655
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   656
    ^ self
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   657
	parseMethod:aString in:aClass 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   658
	ignoreErrors:false 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   659
	ignoreWarnings:warnBoolean not
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   660
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   661
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   662
parseMethodArgAndVarSpecification:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   663
    "parse a methods selector, arg and var spec (i.e. locals);
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   664
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   665
     The parser can be queried for selector, receiver etc."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   666
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   667
    ^ self parseMethodArgAndVarSpecification:aString in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   668
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   669
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   670
     |p|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   671
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   672
     p := Parser 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   673
	     parseMethodArgAndVarSpecification:'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   674
		      foo:arg1 bar:arg2 baz:arg3 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   675
		      |l1 l2|'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   676
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   677
     'nArgs:  ' print. p numberOfMethodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   678
     'args:   ' print. p methodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   679
     'sel:    ' print. p selector printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   680
     'nLocal: ' print. p numberOfMethodVars printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   681
     'locals: ' print. p methodVars printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   682
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   683
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   684
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   685
parseMethodArgAndVarSpecification:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   686
    "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
   687
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   688
     The parser can be queried for selector, receiver, args and locals"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   689
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   690
    ^ self parseMethodArgAndVarSpecification:aString 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   691
	   in:aClass 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   692
	   ignoreErrors:false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   693
	   ignoreWarnings:false 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   694
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   695
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   696
parseMethodArgAndVarSpecification:aString in:aClass ignoreErrors:noErrors ignoreWarnings:noWarnings
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   697
    "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
   698
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   699
     The parser can be queried for selector, receiver, args and locals"
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   700
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   701
    |parser|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   702
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   703
    aString isNil ifTrue:[^ nil].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   704
    parser := self for:(ReadStream on:aString) in:aClass.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   705
    noErrors ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   706
	parser ignoreErrors
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   707
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   708
    noWarnings ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   709
	parser ignoreWarnings
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   710
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   711
    parser nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   712
    (parser parseMethodSpec == #Error) ifTrue:[^ nil].
202
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
   713
    (parser parseMethodBodyOrEmpty "parseMethodBodyVarSpec" == #Error) ifTrue:[^ nil].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   714
    parser errorFlag ifTrue:[^ nil].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   715
    ^ parser
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   716
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   717
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   718
parseMethodArgAndVarSpecificationSilent:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   719
    "parse a methods selector, arg and var spec (i.e. locals);
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   720
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   721
     The parser can be queried for selector, receiver etc.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   722
     Like #parseMethodArgAndVarSpecification:, but does not
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   723
     display error/warning messages on the transcript."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   724
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   725
    ^ self parseMethodArgAndVarSpecificationSilent:aString in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   726
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   727
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   728
parseMethodArgAndVarSpecificationSilent:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   729
    "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
   730
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   731
     The parser can be queried for selector, receiver, args and locals.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   732
     Like #parseMethodArgAndVarSpecification:in:, but does not
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   733
     display error/warning messages on the transcript."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   734
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   735
    ^ self parseMethodArgAndVarSpecification:aString 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   736
	   in:aClass 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   737
	   ignoreErrors:true 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   738
	   ignoreWarnings:true 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   739
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   740
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   741
parseMethodSilent:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   742
    "parse a method.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   743
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   744
     The parser can be queried for selector, receiver, args, locals,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   745
     used selectors etc.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   746
     Like #parseMethod:, but does not display warning/error messages on the
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   747
     transcript."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   748
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   749
    ^ self parseMethodSilent:aString in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   750
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   751
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   752
parseMethodSilent:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   753
    "parse a method in a given class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   754
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   755
     The parser can be queried for selector, receiver, args, locals,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   756
     used selectors, modified instvars, referenced classvars etc.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   757
     Like #parseMethod:in:, but does not display any error/warning
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   758
     messages on the transcript."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   759
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   760
    ^ self parseMethod:aString in:aClass 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   761
	ignoreErrors:true 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   762
	ignoreWarnings:true 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   763
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   764
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   765
parseMethodSpecification:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   766
    "parse a methods selector & arg specification; 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   767
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   768
     The parser can be queried for selector, receiver etc."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   769
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   770
    ^ self parseMethodSpecification:aString in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   771
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   772
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   773
     |p|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   774
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   775
     p := Parser parseMethodSpecification:'foo:arg1 bar:arg2 baz:arg3'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   776
     'nArgs: ' print. p numberOfMethodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   777
     'args:  ' print. p methodArgs printNL.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   778
     'sel:   ' print. p selector printNL
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   779
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   780
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   781
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   782
parseMethodSpecification:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   783
    "parse a methods selector & arg spec for a given class;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   784
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   785
     The parser can be queried for selector, receiver etc."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   786
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   787
    ^ self parseMethodSpecification:aString 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   788
	   in:aClass 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   789
	   ignoreErrors:false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   790
	   ignoreWarnings:false 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   791
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   792
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   793
parseMethodSpecification:aString in:aClass ignoreErrors:noErrors ignoreWarnings:noWarnings 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   794
    "parse a methods selector & arg spec for a given class;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   795
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   796
     The parser can be queried for selector, receiver etc.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   797
     noErrors and noWarnings specify if error- and warningMessages are
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   798
     to be output onto the Transcript."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   799
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   800
    |parser tree|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   801
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   802
    aString isNil ifTrue:[^ nil].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   803
    parser := self for:(ReadStream on:aString) in:aClass.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   804
    noErrors ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   805
	parser ignoreErrors
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   806
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   807
    noWarnings ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   808
	parser ignoreWarnings
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   809
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   810
    parser nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   811
    tree := parser parseMethodSpec.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   812
    (parser errorFlag or:[tree == #Error]) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   813
    ^ parser
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   814
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   815
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   816
parseMethodSpecificationSilent:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   817
    "parse a methods selector & arg specification; 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   818
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   819
     The parser can be queried for selector, receiver etc.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   820
     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
   821
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   822
    ^ self parseMethodSpecificationSilent:aString in:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   823
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   824
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   825
parseMethodSpecificationSilent:aString in:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   826
    "parse a methods selector & arg spec for a given class;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   827
     Return a parser (if ok), nil (empty) or #Error (syntax).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   828
     The parser can be queried for selector, receiver etc.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   829
     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
   830
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   831
    ^ self parseMethodSpecification:aString 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   832
	   in:aClass 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   833
	   ignoreErrors:true 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   834
	   ignoreWarnings:true
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
    "Created: 31.10.1995 / 14:37:49 / cg"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
   837
!
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   838
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   839
selectorInExpression:aString
47
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
   840
    "parse an expression - return the selector. Even malformed expressions
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
   841
     (such as missing receiver or missing arg are parsed.
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
   842
     Used for the SystemBrowsers implementors/senders query-box initial text.
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   843
     Returns nil if unparsable."
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   844
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   845
    |tree parser|
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   846
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   847
    (aString isNil or:[aString isEmpty]) ifTrue:[^ nil].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   848
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   849
    tree := self withSelf:nil 
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   850
		 parseExpression:aString 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   851
		 notifying:nil 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   852
		 ignoreErrors:true 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   853
		 ignoreWarnings:true. 
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   854
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   855
    "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   856
     special: take the expression of the right side, if its an
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   857
     assignment or return
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   858
    "
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   859
    (tree notNil and:[tree ~~ #Error]) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   860
	tree isAssignment ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   861
	    tree expression isMessage ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   862
		tree := tree expression
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   863
	    ]
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   864
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   865
	tree isReturnNode ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   866
	    tree expression isMessage ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   867
		tree := tree expression
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   868
	    ]
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   869
	].
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
   870
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   871
	tree isMessage ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   872
	    ^ tree selector
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   873
	].
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   874
    ].
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   875
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   876
    "
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   877
     mhmh, try expression without receiver
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   878
    "
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   879
    parser := self for:(ReadStream on:aString).
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   880
    parser ignoreErrors.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   881
    parser nextToken.
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   882
    ^ parser degeneratedKeywordExpressionForSelector
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   883
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   884
"
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   885
    Parser selectorInExpression:'foo at:1 put:(5 * bar)'     
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   886
    Parser selectorInExpression:'(foo at:1) at:1'           
47
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
   887
    Parser selectorInExpression:'a + 4'                     
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
   888
    Parser selectorInExpression:'a negated'                 
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   889
    Parser selectorInExpression:'at:1 put:5'            
47
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
   890
    Parser selectorInExpression:'at:1 put:'            
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
   891
    Parser selectorInExpression:'a at:1 put:5'            
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
   892
    Parser selectorInExpression:'a at:1 put:'            
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   893
    Parser selectorInExpression:'a := foo at:1 put:5'    
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   894
"
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   895
!
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   896
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   897
withSelf:anObject parseExpression:aString notifying:someOne 
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   898
    "parse aString as an expression with self set to anObject;
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   899
     Return the parseTree (if ok), nil (for an empty string 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   900
     or comment only ) or #Error (syntactic error).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   901
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   902
     Errors and warnings are forwarded to someOne (usually some
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   903
     codeView) which can highlight it and show a popup box."
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   904
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   905
    ^ self withSelf:anObject 
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   906
	   parseExpression:aString 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   907
	   notifying:someOne 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   908
	   ignoreErrors:false 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   909
	   ignoreWarnings:false 
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   910
!
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   911
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   912
withSelf:anObject parseExpression:aString notifying:someOne ignoreErrors:ignore
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   913
    "parse aString as an expression with self set to anObject;
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   914
     Return the parseTree (if ok), nil (for an empty string 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   915
     or comment only ) or #Error (syntactic error).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   916
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   917
     Errors and warnings are forwarded to someOne (usually some
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   918
     codeView) which can highlight it and show a popup box."
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   919
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   920
    ^ self withSelf:anObject
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   921
	   parseExpression:aString 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   922
	   notifying:someOne 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   923
	   ignoreErrors:ignore 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   924
	   ignoreWarnings:ignore 
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   925
!
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   926
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   927
withSelf:anObject parseExpression:aString notifying:someOne ignoreErrors:ignoreErrors ignoreWarnings:ignoreWarnings
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   928
    "parse aString as an expression with self set to anObject;
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   929
     Return the parseTree (if ok), nil (for an empty string 
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   930
     or comment only ) or #Error (syntactic error).
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   931
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   932
     Errors and warnings are forwarded to someOne (usually some
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   933
     codeView) which can highlight it and show a popup box,
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   934
     iff ignoreErrors/ignoreWarnings is true respectively."
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   935
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
   936
    |parser tree token|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   937
7ad01559b262 Initial revision
claus
parents:
diff changeset
   938
    aString isNil ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   939
    parser := self for:(ReadStream on:aString).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   940
    parser setSelf:anObject.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   941
    parser notifying:someOne.
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   942
    ignoreErrors ifTrue:[parser ignoreErrors].
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   943
    ignoreWarnings ifTrue:[parser ignoreWarnings].
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
   944
    token := parser nextToken.
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
   945
    (token == $^) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   946
	parser nextToken.
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
   947
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   948
    tree := parser expression.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   949
    (parser errorFlag or:[tree == #Error]) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   950
    ^ tree
7ad01559b262 Initial revision
claus
parents:
diff changeset
   951
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   952
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   953
!Parser class methodsFor:'unparsing'!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   954
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   955
methodSpecificationForSelector:aSelector
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   956
    "given a selector such as #foo:bar:, return a string that could
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   957
     serve as a methods specification source code.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   958
     To be used for code generators"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   959
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   960
    ^ self methodSpecificationForSelector:aSelector 
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   961
				 argNames:#('arg1' 'arg2' 'arg3' 'arg4' 'arg5' 'arg6'
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   962
					    'arg7' 'arg8' 'arg9' 'arg10' 'arg11' 'arg12'
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   963
					    'arg13' 'arg14' 'arg15')
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   964
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   965
     Parser methodSpecificationForSelector:#foo:bar:   
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
   966
     Parser methodSpecificationForSelector:#+       
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   967
     Parser methodSpecificationForSelector:#negated   
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   968
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   969
!
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   970
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   971
methodSpecificationForSelector:aSelector argNames:argNames
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   972
    "given a selector such as #foo:bar:, return a string that could
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   973
     serve as a methods specification source code.
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   974
     To be used for code generators"
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   975
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   976
    |s nargs parts|
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   977
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   978
    s := WriteStream on:String new.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   979
    nargs := aSelector numArgs.
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   980
    nargs == 0 ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   981
	s nextPutAll:aSelector
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   982
    ] ifFalse:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   983
	parts := aSelector partsIfSelector.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   984
	1 to:nargs do:[:i |
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   985
	    s nextPutAll:(parts at:i); space;
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   986
	      nextPutAll:(argNames at:i); space.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
   987
	]
20
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   988
    ].
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   989
    ^ s contents
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   990
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   991
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   992
     Parser methodSpecificationForSelector:#foo:bar: argNames:#('one' 'two' 'three')  
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   993
     Parser methodSpecificationForSelector:#+ argNames:#('one')  
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   994
     Parser methodSpecificationForSelector:#negated   
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   995
    "
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   996
! !
f8dd8ba75205 *** empty log message ***
claus
parents: 19
diff changeset
   997
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   998
!Parser methodsFor:'ST-80 compatibility'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   999
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1000
evaluate:aString in:aClass to:to notifying:aRequestor ifFail:failBlock
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1001
    |parseTree value|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1002
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1003
    aString isNil ifTrue:[^ nil].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1004
    self initializeFor:(ReadStream on:aString).
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1005
    self setClassToCompileFor:aClass.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1006
    selfValue := nil.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1007
    requestor := aRequestor.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1008
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1009
    self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1010
    parseTree := self parseMethodBody.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1011
    (errorFlag or:[tree == #Error]) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1012
    parseTree notNil ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1013
	self evalExitBlock:[:value | ^ failBlock value].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1014
	value := parseTree evaluate
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1015
    ].
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1016
    self release.
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1017
    ^ value
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1018
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1019
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1020
!Parser methodsFor:'accessing'!
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1021
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1022
correctedSource
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1023
    ^ correctedSource
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1024
!
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1025
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1026
errorFlag
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1027
    "return true if there where any errors (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1028
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1029
    ^ errorFlag
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1030
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1031
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1032
evalExitBlock:aBlock
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1033
    "when evaluating a return expression, this block is evaluated"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1034
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1035
    evalExitBlock := aBlock
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1036
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1037
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1038
primitiveNumber
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1039
    "return the ST-80 style primitiveNumber or nil (valid after parsing)"
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1040
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1041
    ^ primitiveNr
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1042
!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1043
97
claus
parents: 96
diff changeset
  1044
primitiveResource
claus
parents: 96
diff changeset
  1045
    "return the ST-80 style resource info or nil (valid after parsing)."
claus
parents: 96
diff changeset
  1046
claus
parents: 96
diff changeset
  1047
    ^ primitiveResource
claus
parents: 96
diff changeset
  1048
!
claus
parents: 96
diff changeset
  1049
35
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1050
release
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1051
    methodArgs := methodVars := tree := selfNode := superNode := nil.
2884eed75e2a logging doits.
claus
parents: 23
diff changeset
  1052
    super release.
90
claus
parents: 87
diff changeset
  1053
!
claus
parents: 87
diff changeset
  1054
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1055
targetClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1056
    ^ classToCompileFor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1057
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1058
90
claus
parents: 87
diff changeset
  1059
targetClass:aClass
117
claus
parents: 103
diff changeset
  1060
    classToCompileFor := aClass
claus
parents: 103
diff changeset
  1061
!
claus
parents: 103
diff changeset
  1062
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1063
tree
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1064
    "return the parsetree"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1065
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1066
    ^tree
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1067
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1068
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1069
tree:aTree
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1070
    "private: set the tree - for internal use only"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1071
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1072
    tree := aTree
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1073
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1074
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1075
!Parser methodsFor:'error correction'!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1076
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1077
askForCorrection:aString fromList:aList
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1078
    "launch a selection box, which allows user to enter correction.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1079
     return newString or nil (for abort)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1080
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1081
    |box|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1082
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1083
    "in systems without widgets ..."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1084
    ListSelectionBox isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1085
	^ self confirm:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1086
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1087
    box := ListSelectionBox title:aString.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1088
    box initialText:(aList at:1).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1089
    box list:aList.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1090
    box okText:'correct'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1091
    box action:[:aString | ^ aString].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1092
    box showAtPointer.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1093
    ^ nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1094
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1095
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1096
correctByDeleting
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1097
    "correct (by deleting token) if user wants to;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1098
     return #Error if there was no correction;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1099
     nil if there was one." 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1100
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1101
    (self confirm:'confirm deleting') ifFalse:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1102
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1103
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1104
     tell requestor (i.e. CodeView) about the change
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1105
     this will update what the requestor shows.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1106
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1107
    requestor deleteSelection.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1108
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1109
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1110
     get the updated source-string 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1111
     which is needed, when we eventually install the new method
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1112
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1113
    correctedSource := requestor currentSourceCode.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1114
    ^ nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1115
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1116
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1117
correctSelector:aSelectorString message:msg position:pos1 to:pos2
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1118
    "notify error and correct if user wants to;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1119
     return #Error if there was no correction 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1120
     or a ParseNode as returned by variable"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1121
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1122
    |correctIt suggestedNames newSelector|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1123
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1124
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1125
     sorry, but I cannot handle keywords with more than one-part
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1126
     currently (too much work - maybe Ill do it later when everything else works :-)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1127
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1128
    (aSelectorString occurrencesOf:$:) > 1 ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1129
	self warning:msg position:pos1 to:pos2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1130
	^ aSelectorString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1131
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1132
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1133
    correctIt := self correctableError:msg position:pos1 to:pos2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1134
    correctIt ifFalse:[^ aSelectorString].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1135
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1136
    suggestedNames := self findBestSelectorsFor:aSelectorString.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1137
    suggestedNames notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1138
	newSelector := self askForCorrection:'correct selector to: ' fromList:suggestedNames.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1139
	newSelector isNil ifTrue:[^ aSelectorString].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1140
    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1141
	self information:'no good correction found'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1142
	^ aSelectorString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1143
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1144
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1145
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1146
     tell requestor (i.e. CodeView) about the change
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1147
     this will update what the requestor shows.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1148
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1149
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1150
    requestor replaceSelectionBy:newSelector keepCursor:false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1151
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1152
     get the updated source-string 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1153
     which is needed, when we eventually install the new method
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1154
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1155
    correctedSource := requestor currentSourceCode.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1156
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1157
    ^ newSelector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1158
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1159
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1160
correctVariable
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1161
    "notify error and correct if user wants to;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1162
     return #Error if there was no correction 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1163
     or a ParseNode as returned by variable"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1164
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1165
    |correctIt varName suggestedNames newName pos1 pos2|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1166
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1167
    pos1 := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1168
    varName := tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1169
    pos2 := pos1 + varName size - 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1170
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1171
"OLD:
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1172
    (varName at:1) isLowercase ifTrue:[
202
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1173
	correctIt := self undefError:varName position:pos1 to:pos2.
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1174
	correctIt ifFalse:[^ #Error]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1175
    ] ifFalse:[
202
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1176
	correctIt := self warning:(varName , ' is undefined') position:pos1 to:pos2.
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1177
	correctIt ifFalse:[
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1178
	    ^ VariableNode type:#GlobalVariable name:(varName asSymbol)
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1179
	]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1180
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1181
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1182
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1183
    correctIt := self undefError:varName position:pos1 to:pos2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1184
    correctIt ifFalse:[
202
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1185
	(varName at:1) isLowercase ifTrue:[
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1186
	    self warning:'no automatic global declaration of lowercase variables' position:pos1 to:pos2.
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1187
	    ^ #Error
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1188
	] ifFalse:[
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1189
	    ^ VariableNode type:#GlobalVariable name:(varName asSymbol)
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1190
	]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1191
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1192
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1193
    suggestedNames := self findBestVariablesFor:varName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1194
    suggestedNames notNil ifTrue:[
202
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1195
	newName := self askForCorrection:'correct variable to: ' fromList:suggestedNames.
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1196
	newName isNil ifTrue:[^ #Error].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1197
"
202
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1198
	newName := suggestedNames at:1.
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1199
	(self confirm:('confirm correction to: ' , newName)) ifFalse:[^ #Error]
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1200
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1201
    ] ifFalse:[
202
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1202
	self information:'no good correction found'.
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1203
	^ #Error
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1204
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1205
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1206
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1207
     tell requestor (i.e. CodeView) about the change
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1208
     this will update what the requestor shows.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1209
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1210
    requestor replaceSelectionBy:newName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1211
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1212
     get the updated source-string 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1213
     which is needed, when we eventually install the new method
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1214
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1215
    correctedSource := requestor currentSourceCode.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1216
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1217
    "redo parse with new value"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1218
    tokenName := newName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1219
    ^ self variableOrError
176
dae7e295a689 give a warning after correct of undeclared lower-case variable
Claus Gittinger <cg@exept.de>
parents: 173
diff changeset
  1220
dae7e295a689 give a warning after correct of undeclared lower-case variable
Claus Gittinger <cg@exept.de>
parents: 173
diff changeset
  1221
    "Modified: 22.12.1995 / 19:02:01 / cg"
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1222
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1223
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1224
findBestSelectorsFor:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1225
    "collect known selectors with their spelling distances to aString;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1226
     return the 10 best suggestions"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1227
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1228
    |info n|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1229
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1230
    info := SortedCollection new.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1231
    info sortBlock:[:a :b | a value > b value].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1232
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1233
    n := 0.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1234
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1235
    Symbol allInstancesDo:[:sym |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1236
	|dist|
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
	dist := aString spellAgainst:sym.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1239
	dist > 20 ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1240
	    info add:(sym -> dist).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1241
	    n := n + 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1242
	    n > 10 ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1243
		info removeLast.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1244
	    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1245
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1246
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1247
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1248
    ^ info asOrderedCollection collect:[:a | a key]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1249
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1250
    "Time millisecondsToRun:[Parser new findBestSelectorsFor:'foo']"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1251
    "Parser new findBestSelectorsFor:'findBestSel'"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1252
    "Parser new findBestSelectorsFor:'fildBestSelectrFr'"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1253
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1254
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1255
findBestVariablesFor:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1256
    "collect known variables with their spelling distances to aString;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1257
     return the 10 best suggestions"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1258
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1259
    |names dists searchBlock args vars globalVarName aClass className baseClass n|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1260
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1261
    names := OrderedCollection new.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1262
    dists := OrderedCollection new.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1263
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1264
    "block arguments"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1265
    searchBlock := currentBlock.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1266
    [searchBlock notNil] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1267
	args := searchBlock arguments.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1268
	args notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1269
	    args do:[:aBlockArg |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1270
		names add:(aBlockArg name).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1271
		dists add:(aString spellAgainst: "levenshteinTo:"(aBlockArg name))
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1272
	    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1273
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1274
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1275
	vars := searchBlock variables.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1276
	vars notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1277
	    vars do:[:aBlockVar |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1278
		names add:(aBlockVar name).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1279
		dists add:(aString spellAgainst: "levenshteinTo:"(aBlockVar name))
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1280
	    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1281
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1282
	searchBlock := searchBlock home
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1283
    ].
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
    "method-variables"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1286
    methodVars notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1287
	methodVarNames do:[:methodVarName |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1288
	    names add:methodVarName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1289
	    dists add:(aString spellAgainst: "levenshteinTo:"methodVarName)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1290
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1291
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1292
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1293
    "method-arguments"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1294
    methodArgs notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1295
	methodArgNames do:[:methodArgName |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1296
	    names add:methodArgName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1297
	    dists add:(aString spellAgainst: "levenshteinTo:"methodArgName)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1298
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1299
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1300
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1301
    "instance-variables"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1302
    classToCompileFor notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1303
	PrevInstVarNames do:[:instVarName |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1304
	    names add:instVarName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1305
	    dists add:(aString spellAgainst: "levenshteinTo:"instVarName)
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
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1308
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1309
    "class-variables"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1310
    classToCompileFor notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1311
	PrevClassVarNames do:[:classVarName |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1312
	    names add:classVarName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1313
	    dists add:(aString spellAgainst: "levenshteinTo:"classVarName)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1314
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1315
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1316
"/        aClass := classToCompileFor.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1317
"/        aClass isMeta ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1318
"/            className := aClass name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1319
"/            className := className copyWithoutLast:5.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1320
"/            baseClass := Smalltalk at:(className asSymbol).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1321
"/            baseClass notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1322
"/                aClass := baseClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1323
"/            ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1324
"/        ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1325
"/        [aClass notNil] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1326
"/            (aClass classVarNames) do:[:classVarName |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1327
"/                names add:classVarName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1328
"/                dists add:(aString spellAgainst: "levenshteinTo:"classVarName)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1329
"/            ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1330
"/            aClass := aClass superclass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1331
"/        ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1332
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1333
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1334
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1335
    "globals"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1336
    Smalltalk keysDo:[:aKey |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1337
	globalVarName := aKey asString.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1338
	"only compare strings where length is about right"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1339
	((globalVarName size - aString size) abs < 3) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1340
	    names add:globalVarName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1341
	    dists add:(aString spellAgainst: "levenshteinTo:"globalVarName)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1342
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1343
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1344
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1345
    "misc"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1346
    #('self' 'super' 'nil' 'thisContext') do:[:name |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1347
	names add:name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1348
	dists add:(aString spellAgainst: "levenshteinTo:"name)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1349
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1350
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1351
    (dists size ~~ 0) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1352
	dists sortWith:names.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1353
	dists := dists reverse.             
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1354
	names := names reverse.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1355
	n := names size min:10.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1356
	names := names copyTo:n.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1357
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1358
	"if it starts with a lower case character, add all local & instvar names"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1359
	(aString at:1) isLowercase ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1360
	    methodVarNames size > 0 ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1361
		names add:'---- method locals ----'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1362
		methodVarNames asSortedCollection do:[:methodVarName |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1363
		    names add:methodVarName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1364
		].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1365
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1366
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1367
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1368
	    methodArgs notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1369
		names add:'---- method arguments ----'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1370
		methodArgNames asSortedCollection do:[:methodArgName |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1371
		    names add:methodArgName.
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
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1374
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1375
	    names add:'---- instance variables ----'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1376
	    PrevInstVarNames asSortedCollection do:[:instVarName |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1377
		(names includes:instVarName) ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1378
		    names add:instVarName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1379
		]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1380
	    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1381
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1382
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1383
	^ names
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1384
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1385
    ^ nil
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
selectorCheck:aSelectorString for:receiver position:pos1 to:pos2
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1389
    "just a quick check: if a selector is totally unknown as a symbol, 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1390
     or has the same name as a variable or cannot be understood.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1391
     Simple, but catches many typos"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1392
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1393
    |ok err sym rec superCls|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1394
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1395
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1396
     if compiling lazy, or errors are to be ignored, or there
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1397
     is no requestor, do not check
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1398
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1399
    (LazyCompilation == true) ifTrue:[^ aSelectorString].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1400
    (ignoreErrors or:[ignoreWarnings]) ifTrue:[^ aSelectorString].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1401
    (requestor isNil or:[requestor isStream]) ifTrue:[^ aSelectorString].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1402
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1403
    err := ' is currently nowhere implemented'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1404
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1405
     if the selector has the name of a variable, use another message
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1406
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1407
    ((methodVarNames notNil and:[methodVarNames includes:aSelectorString])
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1408
    or:[(methodArgNames notNil and:[methodArgNames includes:aSelectorString])
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1409
    or:[(self instVarNames notNil and:[self instVarNames includes:aSelectorString])
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1410
    or:[(self classInstVarNames notNil and:[self classInstVarNames includes:aSelectorString])
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1411
    or:[(self classVarNames notNil and:[self classVarNames includes:aSelectorString])]]]]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1412
	err := ' is currently nowhere implemented ..
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1413
.. but a variable with that name is defined. 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1414
143
1008a91b7bc1 better warning message
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  1415
Missing ''.'' after the previous expression 
1008a91b7bc1 better warning message
Claus Gittinger <cg@exept.de>
parents: 141
diff changeset
  1416
or missing keyword/receiver before that word ?'.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1417
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1418
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1419
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1420
     check if the selector is known at all
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1421
     - if not, it cannot be understood
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1422
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1423
    ok := false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1424
    sym := aSelectorString asSymbolIfInterned.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1425
    sym notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1426
	ok := true.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1427
	receiver notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1428
	    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1429
	     if the receiver is a constant, we can check if it responds
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1430
	     to this selector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1431
	    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1432
	    receiver isConstant ifTrue:[
145
bbc655bd97a9 better warning in selectorCheck
Claus Gittinger <cg@exept.de>
parents: 144
diff changeset
  1433
		rec := receiver evaluate.
bbc655bd97a9 better warning in selectorCheck
Claus Gittinger <cg@exept.de>
parents: 144
diff changeset
  1434
		ok := rec respondsTo:sym.
bbc655bd97a9 better warning in selectorCheck
Claus Gittinger <cg@exept.de>
parents: 144
diff changeset
  1435
		err := ' will not be understood here (message to ' , rec classNameWithArticle , ')'.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1436
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1437
		receiver isBlock ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1438
		    "/ this should help with typos, sending #ifTrue to blocks ...
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1439
		    ok := [] respondsTo:sym.
145
bbc655bd97a9 better warning in selectorCheck
Claus Gittinger <cg@exept.de>
parents: 144
diff changeset
  1440
		    err := ' will not be understood here (message to a Block)'.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1441
		] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1442
		    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1443
		     if the receiver is a global, we check it too ...
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1444
		    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1445
		    receiver type == #GlobalVariable ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1446
			"dont check autoloaded classes - it may work after
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1447
			 loading"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1448
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1449
			rec := receiver evaluate. 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1450
			(rec notNil 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1451
			 and:[rec isBehavior
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1452
			 and:[rec isLoaded not]]) ifTrue:[^ aSelectorString].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1453
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1454
			ok := rec respondsTo:sym.
145
bbc655bd97a9 better warning in selectorCheck
Claus Gittinger <cg@exept.de>
parents: 144
diff changeset
  1455
			err := ' may not be understood here (is currently ' , rec classNameWithArticle , ')'.
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1456
		    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1457
			"if its a super send, we can do more checking"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1458
			receiver isSuper ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1459
			    receiver isHere ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1460
				((superCls := classToCompileFor superclass) notNil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1461
				and:[(superCls whichClassIncludesSelector:sym) isNil]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1462
				    err := ' is currently not implemented in any superclass'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1463
				    ok := false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1464
				]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1465
			    ] ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1466
				(classToCompileFor whichClassIncludesSelector:sym) isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1467
				    err := ' is currently not implemented in this class'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1468
				    ok := false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1469
				]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1470
			    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1471
			].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1472
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1473
			(receiver isUnaryMessage
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1474
			and:[receiver selector == #class
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1475
			and:[receiver receiver type == #Self]]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1476
			    "its a message to self class - can check this too ..."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1477
			    (classToCompileFor class whichClassIncludesSelector:sym) isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1478
				ok := false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1479
				classToCompileFor allSubclasses do:[:subclass |
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1480
				    (subclass class implements:sym) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1481
					ok := true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1482
				    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1483
				].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1484
				err := ' is currently not implemented in the class'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1485
			    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1486
			]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1487
		    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1488
		]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1489
	    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1490
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1491
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1492
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1493
    ok ifFalse:[
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
"OLD: "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1496
	self warning:('#' , aSelectorString , err) position:pos1 to:pos2
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1497
" "   
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1498
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1499
"NEW:    - not finished - need more interfaces
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1500
   (currently produces warning output on Transcript while filing in
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
	^ self correctSelector:aSelectorString message:('#' , aSelectorString , err) position:pos1 to:pos2
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
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1506
    ^ aSelectorString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1507
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1508
    "Modified: 5.9.1995 / 17:02:11 / claus"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1509
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1510
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1511
!Parser methodsFor:'error handling'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1512
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1513
correctableError:message position:pos1 to:pos2
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1514
    "report an error which can be corrected by compiler -
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1515
     return true if correction is wanted"
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
    |correctIt|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1518
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1519
    requestor isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1520
	self showErrorMessage:message position:pos1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1521
	correctIt := false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1522
    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1523
	correctIt := requestor correctableError:message position:pos1 to:pos2 from:self
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1524
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1525
    correctIt ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1526
	exitBlock notNil ifTrue:[exitBlock value]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1527
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1528
    ^ correctIt
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
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1531
exitWith:something
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1532
    "this is the longjump out of evaluation via a return expression"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1533
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1534
    evalExitBlock value:something
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1535
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1536
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1537
identifierExpectedIn:what
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1538
    |msg|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1539
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1540
    (#(True False Self Nil Super ThisContext) includes:tokenType) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1541
	msg := 'Reserved keyword in ' 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1542
    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1543
	msg := 'Identifier expected in ' 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1544
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1545
    self syntaxError:msg , what position:tokenPosition to:source position - 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1546
    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1547
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1548
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1549
parseError:aMessage
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1550
    "report an error"
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
    ^ self parseError:aMessage position:tokenPosition to:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1553
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1554
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1555
parseError:aMessage position:position
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1556
    "report an error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1557
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1558
    ^ self parseError:aMessage position:position to:nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1559
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1560
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1561
parseError:aMessage position:position to:endPos
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1562
    "report an error"
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
    |m|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1565
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1566
    errorFlag := true.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1567
    m := 'Error: ' , aMessage.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1568
    self notifyError:m position:position to:endPos.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1569
    exitBlock notNil ifTrue:[exitBlock value].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1570
    ^ false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1571
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1572
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1573
showErrorMessage:aMessage position:pos
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1574
    "redefined since parser can give more detailed info about
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1575
     the class & selector where the error occured."
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1576
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  1577
    |text|
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  1578
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  1579
    ignoreErrors ifFalse:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1580
	Smalltalk silentLoading == true ifFalse:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1581
	    Transcript show:(pos printString).
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1582
	    Transcript show:' '.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1583
	    selector notNil ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1584
		Transcript show:aMessage.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1585
		classToCompileFor notNil ifTrue:[
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  1586
		    text := ' in ' , classToCompileFor name , '>>' , selector
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1587
		] ifFalse:[
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  1588
		    text := ' in ' , selector
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1589
		]
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1590
	    ] ifFalse:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1591
		classToCompileFor notNil ifTrue:[
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  1592
		    text := aMessage , ' (' , classToCompileFor name , ')'
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1593
		] ifFalse:[
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  1594
		    text := aMessage
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1595
		]
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  1596
	    ].
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  1597
	    Transcript showCr:text.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1598
	]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1599
    ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1600
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1601
171
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1602
showErrorMessageForClass:aClass
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1603
"/        compiler parseError:'syntax error'.
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1604
    Transcript show:'    '.
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1605
    aClass notNil ifTrue:[
202
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1606
	Transcript show:aClass name , '>>'
171
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1607
    ].
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1608
    selector notNil ifTrue:[
202
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  1609
	Transcript show:(selector)
171
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1610
    ].
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1611
    Transcript showCr:' -> Error'.
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1612
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1613
    "Created: 13.12.1995 / 20:24:34 / cg"
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1614
!
fc14729145ff checkin from browser
Claus Gittinger <cg@exept.de>
parents: 165
diff changeset
  1615
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1616
undefError:aName position:pos1 to:pos2
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1617
    "report an undefined variable error - return true, if it should be
86
claus
parents: 85
diff changeset
  1618
     corrected. If not corrected, only one warning is made per undefined
claus
parents: 85
diff changeset
  1619
     variable."
claus
parents: 85
diff changeset
  1620
131
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  1621
    |doCorrect msg idx hasSourceInfoStripped|
86
claus
parents: 85
diff changeset
  1622
claus
parents: 85
diff changeset
  1623
    "
claus
parents: 85
diff changeset
  1624
     alredy warned about this one ?
claus
parents: 85
diff changeset
  1625
    "
claus
parents: 85
diff changeset
  1626
    warnedUndefVars notNil ifTrue:[
claus
parents: 85
diff changeset
  1627
	(warnedUndefVars includes:aName) ifTrue:[
claus
parents: 85
diff changeset
  1628
	    "already warned about this one"
claus
parents: 85
diff changeset
  1629
	    ^ false
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1630
	].
86
claus
parents: 85
diff changeset
  1631
    ].
claus
parents: 85
diff changeset
  1632
131
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  1633
"/    (classToCompileFor notNil 
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  1634
"/    and:[classToCompileFor superclass notNil
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  1635
"/    and:[classToCompileFor superclass instanceVariableString isNil]]) ifTrue:[
132
5be56a5e90b7 added methods for silent parsing (parseMethod / parseMethodSpec)
Claus Gittinger <cg@exept.de>
parents: 131
diff changeset
  1636
"/      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
  1637
"/      ^ false
131
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  1638
"/    ].
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  1639
5fcdc8c7770d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 126
diff changeset
  1640
    (requestor isNil or:[requestor isStream]) ifTrue:[
56
867ccf456147 only output undef non-uppercase vars when filing in
claus
parents: 53
diff changeset
  1641
	aName first isUppercase ifFalse:[
867ccf456147 only output undef non-uppercase vars when filing in
claus
parents: 53
diff changeset
  1642
	    self showErrorMessage:('Error: ' , aName , ' is undefined') position:pos1.
867ccf456147 only output undef non-uppercase vars when filing in
claus
parents: 53
diff changeset
  1643
	].
86
claus
parents: 85
diff changeset
  1644
	doCorrect := false.
claus
parents: 85
diff changeset
  1645
    ] ifFalse:[
claus
parents: 85
diff changeset
  1646
	"
claus
parents: 85
diff changeset
  1647
	 ask requestor for correct/continue/abort ...
claus
parents: 85
diff changeset
  1648
	 it is supposed to raise abort or return true/false.
claus
parents: 85
diff changeset
  1649
	 True return means that correction is wanted.
claus
parents: 85
diff changeset
  1650
	"
95
claus
parents: 91
diff changeset
  1651
	msg := 'Warning: ' , aName , ' is undefined'.
claus
parents: 91
diff changeset
  1652
	classToCompileFor notNil ifTrue:[
claus
parents: 91
diff changeset
  1653
	    "is it an instance-variable marked inaccessable ?"
claus
parents: 91
diff changeset
  1654
claus
parents: 91
diff changeset
  1655
	    idx := (self instVarNames) indexOf:(aName , '*') startingAt:1.
claus
parents: 91
diff changeset
  1656
	    idx ~~ 0 ifTrue:[
claus
parents: 91
diff changeset
  1657
		msg := 'Warning: ' , aName , ' is a hidden instvar (not accessable from ST-code)'.
claus
parents: 91
diff changeset
  1658
	    ]
claus
parents: 91
diff changeset
  1659
	].
claus
parents: 91
diff changeset
  1660
claus
parents: 91
diff changeset
  1661
	doCorrect := self correctableError:msg position:pos1 to:pos2
86
claus
parents: 85
diff changeset
  1662
    ].
claus
parents: 85
diff changeset
  1663
claus
parents: 85
diff changeset
  1664
    doCorrect ifFalse:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1665
	warnedUndefVars isNil ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1666
	    warnedUndefVars := Set new.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1667
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  1668
	warnedUndefVars add:aName.
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
  1669
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1670
86
claus
parents: 85
diff changeset
  1671
    ^ doCorrect
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1672
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1673
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1674
!Parser methodsFor:'parsing'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  1675
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1676
array
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1677
    |arr elements elem pos1|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1678
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1679
    pos1 := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1680
    elements := OrderedCollection new:20.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1681
    [tokenType ~~ $) ] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1682
	elem := self arrayConstant.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1683
	(elem == #Error) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1684
	    (tokenType == #EOF) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1685
		self syntaxError:'unterminated array-constant; '')'' expected' 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1686
			position:pos1 to:tokenPosition
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1687
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1688
	    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1689
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1690
	elements add:elem.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1691
	self nextToken
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1692
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1693
    arr := Array withAll:elements.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1694
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1695
    (ArraysAreImmutable and:[ImmutableArray notNil]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1696
	arr changeClassTo:ImmutableArray.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1697
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1698
    ^ arr
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1699
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1700
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1701
arrayConstant
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1702
    (tokenType == #String) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1703
	^ tokenValue
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1704
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1705
    (tokenType == #Nil) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1706
	^ nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1707
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1708
    (tokenType == #Integer) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1709
	^ tokenValue
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1710
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1711
    (tokenType == #Character) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1712
	^ tokenValue
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1713
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1714
    (tokenType == #Float) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1715
	^ tokenValue
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1716
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1717
    (tokenType == #True) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1718
	^ true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1719
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1720
    (tokenType == #False) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1721
	^ false
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1722
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1723
    (tokenType == #Error) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1724
	^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1725
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1726
    (tokenType == #BinaryOperator) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1727
	^ tokenName asSymbol
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1728
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1729
    (tokenType == #Keyword) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1730
	^ tokenName asSymbol
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1731
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1732
    (tokenType == #Identifier) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1733
	^ tokenName asSymbol
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1734
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1735
    (tokenType == $() ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1736
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1737
	^ self array
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1738
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1739
    (tokenType == $[) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1740
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1741
	^ self byteArray
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1742
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1743
    (tokenType == #Symbol) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1744
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1745
	self warning:'no # for symbols within array-constants'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1746
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1747
	^ tokenValue
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1748
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1749
    (tokenType == #HashLeftParen) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1750
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1751
	self warning:'no # for arrays within array-constants'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1752
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1753
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1754
	^ self array
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1755
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1756
    (tokenType == #HashLeftBrack) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1757
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1758
	self warning:'no # for arrays within array-constants'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1759
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1760
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1761
	^ self byteArray
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1762
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1763
    (tokenType == #EOF) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1764
	"just for the better error-hilight; let caller handle error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1765
	^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1766
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1767
    self syntaxError:('error in array-constant; ' 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1768
		      , tokenType printString 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1769
		      , ' unexpected').
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1770
    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1771
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1772
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1773
binaryExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1774
    "parse a binary-expression; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1775
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1776
    |receiver arg sel pos try lno note|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1777
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1778
    receiver := self unaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1779
    (receiver == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1780
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1781
    "special kludge: since Scanner cannot know if -digit is a binary
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1782
     expression or a negative constant, handle cases here"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1783
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1784
    [(tokenType == #BinaryOperator) or:[(tokenType == $|)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1785
     or:[(tokenType == #Integer) and:[tokenValue < 0]]]] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1786
	pos := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1787
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1788
	lno := tokenLineNr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1789
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1790
	"kludge here: bar and minus are not scanned as binop "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1791
	(tokenType == $|) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1792
	    sel := '|'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1793
	    self nextToken
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1794
	] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1795
	    (tokenType == #BinaryOperator) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1796
		sel := self selectorCheck:tokenName for:receiver position:tokenPosition to:(tokenPosition + tokenName size - 1).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1797
		self nextToken
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1798
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1799
		sel := '-'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1800
		tokenValue := tokenValue negated
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1801
	    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1802
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1803
	arg := self unaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1804
	(arg == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1805
	try := BinaryNode receiver:receiver selector:sel arg:arg.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1806
	(try isMemberOf:String) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1807
	    self parseError:try position:pos to:tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1808
	    errorFlag := false. "ok, user wants it - so he'll get it"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1809
	    receiver := BinaryNode receiver:receiver selector:sel arg:arg fold:false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1810
	    note := receiver plausibilityCheck.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1811
	    note notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1812
		self warning:note position:pos to:tokenPosition
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1813
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1814
	] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1815
	    receiver := try
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1816
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1817
	receiver lineNumber:lno.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1818
	parseForCode ifFalse:[self rememberSelectorUsed:sel].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1819
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1820
    ^ receiver
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1821
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1822
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1823
block
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1824
    "parse a block; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1825
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1826
    |node args argNames arg pos lno|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1827
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1828
    lno := tokenLineNr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1829
    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1830
    (tokenType == $: ) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1831
	[tokenType == $:] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1832
	    pos := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1833
	    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1834
	    (tokenType == #Identifier) ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1835
		^ self identifierExpectedIn:'block-arg declaration'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1836
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1837
	    arg := Variable name:tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1838
	    args isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1839
		args := Array with:arg.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1840
		argNames := Array with:tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1841
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1842
		(argNames includes:tokenName) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1843
		    self syntaxError:'redefinition of ''' , tokenName , ''' in argument list.'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1844
			    position:tokenPosition 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1845
				   to:(tokenPosition + tokenName size - 1)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1846
		].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1847
		args := args copyWith:arg.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1848
		argNames := argNames copyWith:tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1849
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1850
	    self nextToken
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1851
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1852
	(tokenType ~~ $| ) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1853
	    "ST-80 allows [:arg ]"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1854
	    (tokenType == $] ) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1855
		node := BlockNode arguments:args home:currentBlock variables:nil.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1856
		node lineNumber:lno.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1857
		^ node
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1858
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1859
	    self syntaxError:'| expected after block-arg declaration'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1860
	    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1861
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1862
	self nextToken
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1863
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1864
    node := self blockBody:args.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1865
    (node notNil and:[node ~~ #Error]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1866
	node lineNumber:lno.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1867
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1868
    ^ node
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1869
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1870
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1871
blockBody:args
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1872
    "parse a blocks body; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1873
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1874
    |stats node var vars lno names|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1875
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1876
    lno := tokenLineNr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1877
    (tokenType == $| ) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1878
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1879
	[tokenType == $|] whileFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1880
	    (tokenType == #Identifier) ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1881
		^ self identifierExpectedIn:'block-var declaration'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1882
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1883
	    var := Variable name:tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1884
	    vars isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1885
		vars := Array with:var.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1886
		names := Array with:tokenName
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1887
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1888
		(names includes:tokenName) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1889
		    self parseError:'redefinition of ''' , tokenName , ''' in local variables'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1890
			   position:tokenPosition to:tokenPosition + tokenName size -1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1891
		] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1892
		    vars := vars copyWith:var.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1893
		    names := names copyWith:tokenName
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1894
		]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1895
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1896
	    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1897
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1898
	self nextToken
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1899
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1900
    node := BlockNode arguments:args home:currentBlock variables:vars.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1901
    node lineNumber:lno.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1902
    currentBlock := node.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1903
    stats := self blockStatementList.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1904
    node statements:stats.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1905
    currentBlock := node home.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1906
    (stats == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1907
    ^ node
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1908
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1909
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1910
blockExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1911
    "parse a blockExpression; return a node-tree, nil or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1912
     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
  1913
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1914
    tokenType ~~ $[ ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1915
	self syntaxError:'[ expected'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1916
	^ #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1917
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1918
    ^ self block
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1919
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1920
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1921
blockStatementList
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1922
    "parse a blocks statementlist; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1923
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1924
    |thisStatement prevStatement firstStatement|
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
    (tokenType == $] ) ifTrue:[^ nil].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1927
    thisStatement := self statement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1928
    (thisStatement == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1929
    firstStatement := thisStatement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1930
    [tokenType == $] ] whileFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1931
	(tokenType == $.) ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1932
	    ((tokenType == #EOF) or:[tokenType == $)]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1933
		self syntaxError:'missing '']'' in block'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1934
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1935
		self syntaxError:'missing ''.'' in block'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1936
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1937
	    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1938
	] ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1939
	    prevStatement := thisStatement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1940
	    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1941
	    tokenType == $] ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1942
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1943
		*** I had a warning here (since it was not defined
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1944
		*** in the blue-book; but PD-code contains a lot of
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1945
		*** code with periods at the end so that the warnings
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1946
		*** became annoying
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1947
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1948
		self warning:'period after last statement in block'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1949
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1950
		^ firstStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1951
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1952
	    thisStatement := self statement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1953
	    (thisStatement == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1954
	    prevStatement nextStatement:thisStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1955
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1956
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1957
    ^ firstStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1958
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1959
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1960
byteArray
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1961
    "started with ST-80 R4 - allow byteArray constants as #[ ... ]"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1962
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1963
    |bytes index limit newArray elem pos1 pos2|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1964
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1965
    pos1 := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1966
    bytes := ByteArray uninitializedNew:5000.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1967
    index := 0. limit := 5000.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1968
    [tokenType ~~ $] ] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1969
	pos2 := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1970
	"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1971
	 this is not good programming style, but speeds up
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1972
	 reading of huge byte arrays (i.e. stored Images ...)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1973
	"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1974
	(tokenType == #Integer) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1975
	    elem := tokenValue
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1976
	] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1977
	    elem := self arrayConstant.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1978
	    (elem == #Error) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1979
		(tokenType == #EOF) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1980
		    self syntaxError:'unterminated bytearray-constant; '']'' expected' 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1981
			    position:pos1 to:tokenPosition
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1982
		].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1983
		^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1984
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1985
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1986
	((elem isMemberOf:SmallInteger) and:[elem between:0 and:255]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1987
	    index := index + 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1988
	    bytes at:index put:elem.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1989
	    index == limit ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1990
		newArray := ByteArray uninitializedNew:(limit * 2).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1991
		newArray replaceFrom:1 to:limit with:bytes startingAt:1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1992
		limit := limit * 2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1993
		bytes := newArray
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
	] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1996
	    self parseError:'invalid ByteArray element' position:pos2 to:tokenPosition - 1
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
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  1999
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2000
    newArray := ByteArray uninitializedNew:index.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2001
    newArray replaceFrom:1 to:index with:bytes startingAt:1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2002
    ^ newArray
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2003
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2004
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2005
degeneratedKeywordExpressionForSelector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2006
    "parse a keyword-expression without receiver - for the selector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2007
     only. return the selector or nil. This is not used in normal parsing,
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2008
     but instead to extract the selector from a code fragment.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2009
     (for example, the system browsers implementors-function uses this)"
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
    |sel arg rec|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2012
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2013
    (tokenType == #Keyword) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2014
	sel := tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2015
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2016
	arg := self binaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2017
	(arg == #Error) ifTrue:[^ sel].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2018
	[tokenType == #Keyword] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2019
	    sel := sel , tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2020
	    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2021
	    arg := self binaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2022
	    (arg == #Error) ifTrue:[^ sel].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2023
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2024
	^ sel
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2025
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2026
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2027
    (rec := self primary) ~~ #Error ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2028
	sel := self degeneratedKeywordExpressionForSelector.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2029
	sel isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2030
	    rec isMessage ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2031
		sel := rec selector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2032
	    ] ifFalse:[        
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2033
		rec isAssignment ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2034
		    rec expression isMessage ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2035
			sel := rec expression selector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2036
		    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2037
		]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2038
	    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2039
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2040
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2041
    ^ sel
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2042
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2043
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2044
expression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2045
    "parse a cascade-expression; return a node-tree, nil or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2046
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2047
     expression ::= keywordExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2048
		    | keywordExpression cascade
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2049
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2050
     cascade ::= ';' expressionSendPart
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2051
		 | cascade ';' expressionSendPart
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2052
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2053
     expressionSendPart ::= { KEYWORD binaryExpression }
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2054
			    | BINARYOPERATOR unaryExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2055
			    | IDENTIFIER
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2056
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2057
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2058
    |receiver arg sel args pos pos2 lno|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2059
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2060
    pos := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2061
    receiver := self keywordExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2062
    (receiver == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2063
    (tokenType == $;) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2064
	[tokenType == $;] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2065
	    receiver isMessage ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2066
		self syntaxError:'left side of cascade must be a message expression'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2067
			position:pos to:tokenPosition
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2068
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2069
	    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2070
	    (tokenType == #Identifier) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2071
		sel := self selectorCheck:tokenName for:receiver position:tokenPosition to:(tokenPosition + tokenName size - 1).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2072
		receiver := CascadeNode receiver:receiver selector:sel.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2073
		receiver lineNumber:tokenLineNr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2074
		parseForCode ifFalse:[self rememberSelectorUsed:sel].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2075
		self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2076
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2077
		(tokenType == #BinaryOperator) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2078
		    sel := self selectorCheck:tokenName for:receiver position:tokenPosition to:(tokenPosition + tokenName size - 1).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2079
		    lno := tokenLineNr. 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2080
		    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2081
		    arg := self unaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2082
		    (arg == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2083
		    receiver := CascadeNode receiver:receiver selector:sel arg:arg.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2084
		    receiver lineNumber:lno.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2085
		    parseForCode ifFalse:[self rememberSelectorUsed:sel].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2086
		] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2087
		    (tokenType == #Keyword) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2088
			pos := tokenPosition. 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2089
			lno := tokenLineNr. 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2090
			sel := tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2091
			self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2092
			arg := self binaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2093
			(arg == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2094
			args := Array with:arg.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2095
			[tokenType == #Keyword] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2096
			    sel := sel , tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2097
			    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2098
			    arg := self binaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2099
			    (arg == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2100
			    args := args copyWith:arg.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2101
			    pos2 := tokenPosition
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2102
			].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2103
			sel := self selectorCheck:sel for:receiver position:pos to:pos2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2104
			receiver := CascadeNode receiver:receiver selector:sel args:args.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2105
			receiver lineNumber:lno.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2106
			parseForCode ifFalse:[self rememberSelectorUsed:sel].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2107
		    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2108
			(tokenType == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2109
			self syntaxError:('invalid cascade; ' , tokenType printString , ' unexpected')
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2110
				position:tokenPosition to:source position - 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2111
			^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2112
		    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2113
		]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2114
	    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2115
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2116
144
f28ab79db022 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 143
diff changeset
  2117
	"obscure (unspecified ?) if selector follows; Question:
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2118
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2119
	is
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2120
		'expr sel1; sel2 sel3'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2121
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2122
	to be parsed as: 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2123
		(t := expr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2124
		 t sel1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2125
		 t sel2) sel3
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2126
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2127
	 or:
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2128
		(t := expr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2129
		 t sel1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2130
		 t sel2 sel3)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2131
	"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2132
	((tokenType == #Identifier) 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2133
	 or:[(tokenType == #BinaryOperator)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2134
	     or:[tokenType == #Keyword]]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2135
	    self syntaxError:'ambigous cascade - please group using ( ...)'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2136
		    position:tokenPosition to:source position - 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2137
	    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2138
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2139
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2140
    ^ receiver
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2141
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2142
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2143
inWhichClassIsClassInstVar:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2144
    "search class-chain for the class-instance variable named aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2145
     - return the class or nil if not found"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2146
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2147
    |aClass|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2148
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2149
    aClass := classToCompileFor.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2150
    [aClass notNil] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2151
	(aClass class instVarNames includes:aString) ifTrue:[ ^ aClass].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2152
	aClass := aClass superclass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2153
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2154
    ^ nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2155
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2156
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2157
inWhichClassIsClassVar:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2158
    "search class-chain for the classvariable named aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2159
     - return the class or nil if not found"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2160
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2161
    |aClass className baseClass|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2162
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2163
    aClass := classToCompileFor.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2164
    aClass isMeta ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2165
	className := aClass name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2166
	className := className copyWithoutLast:5.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2167
	baseClass := Smalltalk at:(className asSymbol).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2168
	baseClass notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2169
	    aClass := baseClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2170
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2171
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2172
    ^ aClass whichClassDefinesClassVar:aString
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2173
"/    [aClass notNil] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2174
"/        (aClass classVarNames includes:aString) ifTrue:[ ^ aClass].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2175
"/        aClass := aClass superclass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2176
"/    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2177
"/    ^ nil
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2178
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2179
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2180
keywordExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2181
    "parse a keyword-expression; return a node-tree, nil or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2182
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2183
     keywordExpression ::= binaryexpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2184
			   | { KEYWORD-PART binaryExpression }
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2185
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2186
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2187
    |receiver sel arg args pos1 pos2 try lno note|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2188
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2189
    receiver := self binaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2190
    (receiver == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2191
    (tokenType == #Keyword) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2192
	pos1 := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2193
	pos2 := tokenPosition + tokenName size - 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2194
	sel := tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2195
	lno := tokenLineNr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2196
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2197
	arg := self binaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2198
	(arg == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2199
	args := Array with:arg.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2200
	[tokenType == #Keyword] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2201
	    sel := sel , tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2202
	    pos2 := tokenPosition + tokenName size - 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2203
	    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2204
	    arg := self binaryExpression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2205
	    (arg == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2206
	    args := args copyWith:arg.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2207
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2208
	sel := self selectorCheck:sel for:receiver position:pos1 to:pos2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2209
	try := MessageNode receiver:receiver selector:sel args:args.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2210
	(try isMemberOf:String) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2211
	    self parseError:try position:pos1 to:pos2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2212
	    errorFlag := false. "ok, user wants it - so he'll get it"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2213
	    receiver := MessageNode receiver:receiver selector:sel args:args fold:false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2214
	    note := receiver plausibilityCheck.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2215
	    note notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2216
		self warning:note position:pos1 to:pos2
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2217
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2218
	] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2219
	    receiver := try
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2220
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2221
	receiver lineNumber:lno.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2222
	parseForCode ifFalse:[self rememberSelectorUsed:sel].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2223
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2224
    ^ receiver
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2225
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2226
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2227
parseMethod
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2228
    "parse a method.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2229
     Return the parseTree or #Error.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2230
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2231
     method ::= methodSpec methodBody
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2232
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2233
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2234
    |parseTree|
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2235
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2236
    self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2237
    (self parseMethodSpec == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2238
    parseTree := self parseMethodBody.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2239
    (parseTree == #Error) ifFalse:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2240
	self tree:parseTree
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2241
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2242
    ^ parseTree
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2243
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2244
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2245
parseMethodBody
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2246
    "parse a methods body (locals & statements). 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2247
     No more tokens may follow.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2248
     Return a node-tree, or #Error
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2249
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2250
     methodBody ::= '<' st80Primitive '>' #EOF
202
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2251
		    | '<' st80Primitive '>' methodBodyVarSpec statementList #EOF
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2252
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2253
    "
165
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
  2254
    |stats badToken firstPos|
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2255
79
26f81a94a6ea *** empty log message ***
claus
parents: 78
diff changeset
  2256
    stats := self parseMethodBodyOrEmpty.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2257
    (stats == #Error) ifFalse:[
202
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2258
	(tokenType ~~ #EOF) ifTrue:[
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2259
	    "/ just for the nicer error message
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2260
	    (#(Self Nil True False Super Here) includes:tokenType) ifTrue:[
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2261
		self parseError:tokenName , ' unexpected (missing ''.'' before ' , tokenName , ' ?)' 
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2262
		       position:tokenPosition to:(tokenPosition + tokenName size - 1)
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2263
	    ] ifFalse:[
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2264
		self parseError:(tokenType printString , ' unexpected (missing ''.'' or selector before it ?)') 
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2265
		     position:tokenPosition to:source position-1.
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2266
	    ].
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2267
	    ^#Error
77ac1f0c15df fix parsing for args/vars if method has an ST-80 resource spec
Claus Gittinger <cg@exept.de>
parents: 176
diff changeset
  2268
	]
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2269
    ].
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2270
    ^ stats
165
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
  2271
213e3f12fc56 better error message when selector is missing
Claus Gittinger <cg@exept.de>
parents: 148
diff changeset
  2272
    "Modified: 12.12.1995 / 19:40:58 / cg"
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2273
!
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2274
79
26f81a94a6ea *** empty log message ***
claus
parents: 78
diff changeset
  2275
parseMethodBodyOrEmpty
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2276
    "parse a methods body (locals & statements);
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2277
     return  a node-tree, nil or #Error. 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2278
     empty (or comment only) input is accepted and returns nil.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2279
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2280
     methodBodyOrNil ::= '<' st80Primitive '>'
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2281
			 | '<' st80Primitive '>' methodBodyVarSpec statementList
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2282
			 | <empty>
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2283
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2284
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  2285
    |stats pos wmsg|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2286
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2287
    ((tokenType == #BinaryOperator) and:[tokenName = '<']) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2288
	"an ST-80 primitive - parsed but ignored"
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  2289
	pos := tokenPosition.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2290
	self nextToken.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2291
	primitiveNr := self parseST80Primitive.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2292
	(primitiveNr == #Error) ifTrue:[^ #Error].
60
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2293
	primitiveNr < 0 ifTrue:[
207
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
  2294
	    WarnST80Directives == true ifTrue:[
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
  2295
		wmsg := 'ST-80 directive ignored'.
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
  2296
	    ].
79
26f81a94a6ea *** empty log message ***
claus
parents: 78
diff changeset
  2297
	    primitiveNr := nil.
60
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2298
	] ifFalse:[
78
e320344c19b7 *** empty log message ***
claus
parents: 77
diff changeset
  2299
	    wmsg := 'ST-80 primitive may not work'
71
2aac7fbb5be0 *** empty log message ***
claus
parents: 66
diff changeset
  2300
	].
207
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
  2301
	wmsg notNil ifTrue:[self warning:wmsg position:pos]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2302
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2303
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2304
    (self parseMethodBodyVarSpec == #Error) ifTrue:[^ #Error].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2305
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2306
    (tokenType ~~ #EOF) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2307
	stats := self statementList
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2308
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2309
    ^ stats
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2310
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2311
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2312
parseMethodBodyVarSpec
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2313
    "parse a methods local variable specification. 
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2314
     Leave spec of locals in methodLocals as a side effect.
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2315
     Return #Error or nil.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2316
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2317
     methodBodyVarSpec ::= '|' { IDENTIFIER } '|'
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2318
			    | <empty>
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2319
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2320
53
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2321
    |var pos msg|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2322
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2323
    (tokenType == $|) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2324
	"memorize position for declaration in correction"
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2325
	localVarDefPosition := tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2326
	self nextToken.
53
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2327
	pos := tokenPosition.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2328
	[tokenType == #Identifier] whileTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2329
	    var := Variable name:tokenName.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2330
	    methodVars isNil ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2331
		methodVars := Array with:var.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2332
		methodVarNames := Array with:tokenName
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2333
	    ] ifFalse:[
53
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2334
		(methodVarNames includes:tokenName) ifTrue:[
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2335
		    self parseError:'redefinition of ''' , tokenName , ''' in local variables'
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2336
			   position:tokenPosition to:tokenPosition + tokenName size -1.
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2337
		] ifFalse:[
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2338
		    methodVars := methodVars copyWith:var.
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2339
		    methodVarNames := methodVarNames copyWith:tokenName
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2340
		]
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2341
	    ].
139
65eaf1a009f5 warn if method local hides method arg
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  2342
	    methodArgNames notNil ifTrue:[
65eaf1a009f5 warn if method local hides method arg
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  2343
		(methodArgNames includes:tokenName) ifTrue:[
65eaf1a009f5 warn if method local hides method arg
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  2344
		    self warning:'local variable ''' , tokenName , ''' hides argument.'
65eaf1a009f5 warn if method local hides method arg
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  2345
			position:tokenPosition 
65eaf1a009f5 warn if method local hides method arg
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  2346
			      to:(tokenPosition + tokenName size - 1)
65eaf1a009f5 warn if method local hides method arg
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  2347
		]
65eaf1a009f5 warn if method local hides method arg
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  2348
	    ].
53
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2349
	    self nextToken.
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2350
	    pos := tokenPosition
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2351
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2352
	(tokenType ~~ $|) ifTrue:[
53
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2353
	    (#(True False Self Nil Super ThisContext) includes:tokenType) ifTrue:[
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2354
		msg := 'Reserved keyword in local var declaration' 
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2355
	    ] ifFalse:[
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2356
		msg := 'Identifier or | expected in local var declaration' 
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2357
	    ].
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2358
	    self syntaxError:msg position:tokenPosition to:source position-1.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2359
	    ^ #Error
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2360
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2361
	self nextToken
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2362
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2363
    ^ nil
139
65eaf1a009f5 warn if method local hides method arg
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  2364
65eaf1a009f5 warn if method local hides method arg
Claus Gittinger <cg@exept.de>
parents: 135
diff changeset
  2365
    "Modified: 18.11.1995 / 16:32:51 / cg"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2366
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2367
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2368
parseMethodSpec
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2369
    "parse a methods selector & arg specification;
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2370
     Set selector and methodArgs in the receiver as a side effect.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2371
     Return the receiver or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2372
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2373
     methodSpec ::= { KEYWORD IDENTIFIER }
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2374
		    | binaryOperator IDENTIFIER
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2375
		    | IDENTIFIER
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2376
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2377
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2378
    |var|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2379
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2380
    (tokenType == #Keyword) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2381
	selector := ''.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2382
	[tokenType == #Keyword] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2383
	    selector := selector , tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2384
	    self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2385
	    (tokenType ~~ #Identifier) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2386
	    var := Variable name:tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2387
	    methodArgs isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2388
		methodArgs := Array with:var.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2389
		methodArgNames := Array with:tokenName
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2390
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2391
		(methodArgNames includes:tokenName) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2392
		    self syntaxError:'redefinition of ''' , tokenName , ''' in argument list.'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2393
			    position:tokenPosition 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2394
				  to:(tokenPosition + tokenName size - 1)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2395
		].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2396
		methodArgs := methodArgs copyWith:var.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2397
		methodArgNames := methodArgNames copyWith:tokenName
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2398
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2399
	    self nextToken
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2400
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2401
	selector := selector asSymbol.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2402
	^ self
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2403
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2404
    (tokenType == #Identifier) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2405
	selector := tokenName asSymbol.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2406
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2407
	^ self
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2408
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2409
    (tokenType == #BinaryOperator) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2410
	selector := tokenName asSymbol.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2411
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2412
	(tokenType ~~ #Identifier) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2413
	var := Variable name:tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2414
"/      methodArgs isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2415
	    methodArgs := Array with:var.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2416
	    methodArgNames := Array with:tokenName.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2417
"/      ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2418
"/          methodArgs := methodArgs copyWith:var.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2419
"/          methodArgNames := methodArgNames copyWith:tokenName
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2420
"/      ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2421
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2422
	^ self
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2423
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2424
    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2425
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2426
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2427
parseST80Primitive
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
  2428
    "parse an ST-80 type primitive as '< primitive: nr >';
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2429
     return primitive number or #Error.
97
claus
parents: 96
diff changeset
  2430
     Also, ST-80 style resource specs are parsed; the result is
claus
parents: 96
diff changeset
  2431
     left (as side effect) in primitiveResource. 
claus
parents: 96
diff changeset
  2432
     (maybe someone else knows what to do with it ...)
claus
parents: 96
diff changeset
  2433
claus
parents: 96
diff changeset
  2434
     Well, as we now have this mechanism, I'll use it to mark methods which
claus
parents: 96
diff changeset
  2435
     do keyboard processing ... <resource: keyboard ( keys )>
claus
parents: 96
diff changeset
  2436
     For faster finding of used keyboard accelerators.
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2437
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2438
     st80Primitive ::= 'primitive:' INTEGER
97
claus
parents: 96
diff changeset
  2439
     st80Primitive ::= 'resource:' SYMBOL       - ignored; leave SYMBOL in primitiveResource
claus
parents: 96
diff changeset
  2440
     st80Primitive ::= 'resource:' SYMBOL (...) - ignored; leave (SYMBOL (...)) in primitiveResource
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2441
    "
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2442
97
claus
parents: 96
diff changeset
  2443
    |primNumber keys|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2444
60
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2445
    (tokenType ~~ #Keyword) ifTrue:[
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2446
	self parseError:'bad primitive definition (keyword expected)'.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2447
	^ #Error
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2448
    ].
60
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2449
    (tokenName = 'primitive:') ifTrue:[
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2450
	self nextToken.
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2451
	(tokenType == #Integer) ifFalse:[
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2452
	    self parseError:'primitive number expected'.
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2453
	    ^ #Error
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2454
	].
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2455
	primNumber := tokenValue.
97
claus
parents: 96
diff changeset
  2456
	self nextToken.
60
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2457
    ] ifFalse:[
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2458
	(tokenName = 'resource:') ifTrue:[
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2459
	    self nextToken.
97
claus
parents: 96
diff changeset
  2460
	    (tokenType ~~ #Symbol) ifTrue:[
60
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2461
		self parseError:'symbol expected'.
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2462
		^ #Error
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2463
	    ].
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2464
	    primNumber := -1.
97
claus
parents: 96
diff changeset
  2465
	    primitiveResource := tokenValue.
claus
parents: 96
diff changeset
  2466
claus
parents: 96
diff changeset
  2467
	    primitiveResource == #keyboard ifTrue:[
claus
parents: 96
diff changeset
  2468
		self nextToken.
claus
parents: 96
diff changeset
  2469
		tokenType == $( ifTrue:[
claus
parents: 96
diff changeset
  2470
		    self nextToken.
claus
parents: 96
diff changeset
  2471
		    keys := OrderedCollection new.
claus
parents: 96
diff changeset
  2472
		    [tokenType == $) ] whileFalse:[
claus
parents: 96
diff changeset
  2473
			keys add:tokenValue.
claus
parents: 96
diff changeset
  2474
			self nextToken.
claus
parents: 96
diff changeset
  2475
		    ].
claus
parents: 96
diff changeset
  2476
		    primitiveResource := Array with:primitiveResource
claus
parents: 96
diff changeset
  2477
					       with:keys.
claus
parents: 96
diff changeset
  2478
		    self nextToken.
claus
parents: 96
diff changeset
  2479
		]
claus
parents: 96
diff changeset
  2480
	    ] ifFalse:[
claus
parents: 96
diff changeset
  2481
		self nextToken.
claus
parents: 96
diff changeset
  2482
	    ].
60
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2483
	] ifFalse:[
97
claus
parents: 96
diff changeset
  2484
	    self parseError:'unrecognized primitive'.
60
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2485
	    ^ #Error
0db697f03def *** empty log message ***
claus
parents: 56
diff changeset
  2486
	].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2487
    ].
97
claus
parents: 96
diff changeset
  2488
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2489
    ((tokenType == #BinaryOperator) and:[tokenName = '>']) ifFalse:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2490
	self parseError:'bad primitive definition (> expected)'.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2491
	^ #Error
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2492
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2493
    self nextToken.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2494
    ^ primNumber
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2495
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2496
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2497
primary
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2498
    "parse a primary-expression; return a node-tree, nil or #Error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2499
84
claus
parents: 83
diff changeset
  2500
    |val var expr pos name t cls|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2501
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2502
    pos := tokenPosition.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2503
    (tokenType == #Self) ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2504
	self nextToken.
120
claus
parents: 117
diff changeset
  2505
	((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2506
	    self parseError:'assignment to self' position:pos to:tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2507
	    ^ #Error
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2508
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2509
	selfNode isNil ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2510
	    selfNode := SelfNode value:selfValue
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2511
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2512
	^ selfNode
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2513
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2514
    (tokenType == #Identifier) ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2515
	"
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2516
	 must check for variable first, to be backward compatible
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2517
	 with other smalltalks. 
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2518
	"
101
claus
parents: 98
diff changeset
  2519
	tokenName = 'here' ifTrue:[
claus
parents: 98
diff changeset
  2520
	    self variableOrError == #Error ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2521
		tokenType := #Here.
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2522
		warnSTXHereExtensionUsed ifTrue:[
50
ab38fba1331e *** empty log message ***
claus
parents: 49
diff changeset
  2523
		    self warning:'here-sends are a nonstandard feature of ST/X' 
ab38fba1331e *** empty log message ***
claus
parents: 49
diff changeset
  2524
			 position:pos to:pos+3.
ab38fba1331e *** empty log message ***
claus
parents: 49
diff changeset
  2525
		    "
ab38fba1331e *** empty log message ***
claus
parents: 49
diff changeset
  2526
		     only warn once
ab38fba1331e *** empty log message ***
claus
parents: 49
diff changeset
  2527
		    "
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2528
		    warnSTXHereExtensionUsed := false
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2529
		]
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2530
	    ]
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2531
	]
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2532
    ].
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2533
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2534
    (tokenType == #Identifier) ifTrue:[
101
claus
parents: 98
diff changeset
  2535
	name := tokenName.
claus
parents: 98
diff changeset
  2536
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2537
	var := self variable.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2538
	(var == #Error) ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2539
	    errorFlag := true
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2540
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2541
	self nextToken.
120
claus
parents: 117
diff changeset
  2542
	((tokenType == $_) or:[tokenType == #':=']) ifFalse:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2543
	    ^ var
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2544
	].
101
claus
parents: 98
diff changeset
  2545
	"/ careful: it could already be an implicit self send
claus
parents: 98
diff changeset
  2546
	ImplicitSelfSends ifTrue:[
claus
parents: 98
diff changeset
  2547
	    var isMessage ifTrue:[
claus
parents: 98
diff changeset
  2548
		self nextToken.
claus
parents: 98
diff changeset
  2549
		expr := self expression.
claus
parents: 98
diff changeset
  2550
		(errorFlag or:[expr == #Error]) ifTrue:[^ #Error].
claus
parents: 98
diff changeset
  2551
		selfNode isNil ifTrue:[
claus
parents: 98
diff changeset
  2552
		    selfNode := SelfNode value:selfValue
claus
parents: 98
diff changeset
  2553
		].
claus
parents: 98
diff changeset
  2554
		^ MessageNode receiver:selfNode selector:('implicit_' , name , ':') asSymbol arg:expr.
claus
parents: 98
diff changeset
  2555
	    ].
claus
parents: 98
diff changeset
  2556
	].
claus
parents: 98
diff changeset
  2557
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2558
	(var ~~ #Error) ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2559
	    t := var type.
120
claus
parents: 117
diff changeset
  2560
	    (t ~~ #MethodVar) ifTrue:[
claus
parents: 117
diff changeset
  2561
		(t == #MethodArg) ifTrue:[
claus
parents: 117
diff changeset
  2562
		    self parseError:'assignment to method argument' position:pos to:tokenPosition.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2563
		    errorFlag := true
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2564
		] ifFalse:[
120
claus
parents: 117
diff changeset
  2565
		    (t == #BlockArg) ifTrue:[
claus
parents: 117
diff changeset
  2566
			self parseError:'assignment to block argument' position:pos to:tokenPosition.
claus
parents: 117
diff changeset
  2567
			errorFlag := true
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2568
		    ] ifFalse:[
120
claus
parents: 117
diff changeset
  2569
			(t == #InstanceVariable) ifTrue:[
claus
parents: 117
diff changeset
  2570
			    name := PrevInstVarNames at:(var index).
84
claus
parents: 83
diff changeset
  2571
			    parseForCode ifFalse:[
120
claus
parents: 117
diff changeset
  2572
				modifiedInstVars isNil ifTrue:[
claus
parents: 117
diff changeset
  2573
				    modifiedInstVars := Set new
84
claus
parents: 83
diff changeset
  2574
				].
120
claus
parents: 117
diff changeset
  2575
				modifiedInstVars add:name
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2576
			    ]
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2577
			] ifFalse:[
120
claus
parents: 117
diff changeset
  2578
			    (t == #ClassVariable) ifTrue:[
claus
parents: 117
diff changeset
  2579
				name := var name.
claus
parents: 117
diff changeset
  2580
				name := name copyFrom:((name indexOf:$:) + 1).
claus
parents: 117
diff changeset
  2581
				parseForCode ifFalse:[
claus
parents: 117
diff changeset
  2582
				    modifiedClassVars isNil ifTrue:[
claus
parents: 117
diff changeset
  2583
					modifiedClassVars := Set new
claus
parents: 117
diff changeset
  2584
				    ].
claus
parents: 117
diff changeset
  2585
				    modifiedClassVars add:name
claus
parents: 117
diff changeset
  2586
				]
claus
parents: 117
diff changeset
  2587
			    ] ifFalse:[
claus
parents: 117
diff changeset
  2588
				(t == #GlobalVariable) ifTrue:[
claus
parents: 117
diff changeset
  2589
				    (cls := Smalltalk classNamed:var name) notNil ifTrue:[
claus
parents: 117
diff changeset
  2590
					cls name = var name ifTrue:[
claus
parents: 117
diff changeset
  2591
					    self warning:'assignment to global which contains class' position:pos to:tokenPosition.
claus
parents: 117
diff changeset
  2592
					]
claus
parents: 117
diff changeset
  2593
				    ].
claus
parents: 117
diff changeset
  2594
				    parseForCode ifFalse:[
claus
parents: 117
diff changeset
  2595
					modifiedGlobals isNil ifTrue:[
claus
parents: 117
diff changeset
  2596
					    modifiedGlobals := Set new
claus
parents: 117
diff changeset
  2597
					].
claus
parents: 117
diff changeset
  2598
					modifiedGlobals add:var name
84
claus
parents: 83
diff changeset
  2599
				    ]
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2600
				]
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2601
			    ]
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2602
			]
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2603
		    ]
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2604
		]
120
claus
parents: 117
diff changeset
  2605
	    ].
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2606
	].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2607
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2608
	self nextToken.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2609
	expr := self expression.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2610
	(errorFlag or:[expr == #Error]) ifTrue:[^ #Error].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2611
	^ AssignmentNode variable:var expression:expr
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2612
    ].
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2613
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2614
    ((tokenType == #Integer) 
120
claus
parents: 117
diff changeset
  2615
     or:[(tokenType == #String)
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2616
     or:[(tokenType == #Character) 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2617
     or:[(tokenType == #Float)
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2618
     or:[(tokenType == #Symbol)]]]]) ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2619
	val := ConstantNode type:tokenType value:tokenValue.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2620
	self nextToken.
120
claus
parents: 117
diff changeset
  2621
	((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2622
	    self parseError:'assignment to a constant' position:pos to:tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2623
	    ^ #Error
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2624
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2625
	^ val
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2626
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2627
    (tokenType == #Nil) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2628
	self nextToken.
120
claus
parents: 117
diff changeset
  2629
	((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2630
	    self parseError:'assignment to nil' position:pos to:tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2631
	    ^ #Error
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2632
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2633
	^ ConstantNode type:#Nil value:nil
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2634
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2635
    (tokenType == #True) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2636
	self nextToken.
120
claus
parents: 117
diff changeset
  2637
	((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2638
	    self parseError:'assignment to true' position:pos to:tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2639
	    ^ #Error
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2640
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2641
	^ ConstantNode type:#True value:true
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2642
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2643
    (tokenType == #False) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2644
	self nextToken.
120
claus
parents: 117
diff changeset
  2645
	((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2646
	    self parseError:'assignment to false' position:pos to:tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2647
	    ^ #Error
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2648
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2649
	^ ConstantNode type:#False value:false
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2650
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2651
    (tokenType  == #Super) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2652
	usesSuper := true.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2653
	self nextToken.
120
claus
parents: 117
diff changeset
  2654
	((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2655
	    self parseError:'assignment to super' position:pos to:tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2656
	    ^ #Error
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2657
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2658
	(classToCompileFor isNil or:[classToCompileFor superclass isNil]) ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2659
	    self warning:'superclass is (currently ?) nil' position:pos to:(pos + 4).
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2660
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2661
	superNode isNil ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2662
	    superNode := SuperNode value:selfValue inClass:classToCompileFor
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2663
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2664
	^ superNode
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2665
    ].
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2666
    (tokenType  == #Here) ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2667
	self nextToken.
120
claus
parents: 117
diff changeset
  2668
	((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
49
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2669
	    self parseError:'assignment to here' position:pos to:tokenPosition.
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2670
	    ^ #Error
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2671
	].
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2672
	classToCompileFor isNil ifTrue:[
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2673
	    self warning:'in which class are you ?' position:pos to:(pos + 3).
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2674
	].
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2675
	^ SuperNode value:selfValue inClass:classToCompileFor here:true
02660b790c3e *** empty log message ***
claus
parents: 47
diff changeset
  2676
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2677
    (tokenType == #ThisContext) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2678
	self nextToken.
120
claus
parents: 117
diff changeset
  2679
	((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2680
	    self parseError:'assignment to thisContext' position:pos to:tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2681
	    ^ #Error
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2682
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2683
	^ VariableNode type:#ThisContext
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2684
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2685
    (tokenType == #HashLeftParen) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2686
	self nextToken.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2687
	val := self array.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2688
	self nextToken.
120
claus
parents: 117
diff changeset
  2689
	((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2690
	    self parseError:'assignment to a constant' position:pos to:tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2691
	    ^ #Error
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2692
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2693
	^ ConstantNode type:#Array value:val
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2694
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2695
    (tokenType == #HashLeftBrack) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2696
	self nextToken.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2697
	val := self byteArray.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2698
	self nextToken.
120
claus
parents: 117
diff changeset
  2699
	((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2700
	    self parseError:'assignment to a constant' position:pos to:tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2701
	    ^ #Error
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2702
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2703
	^ ConstantNode type:#Array value:val
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2704
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2705
    (tokenType == $() ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2706
	self nextToken.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2707
	val := self expression.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2708
	(val == #Error) ifTrue:[^ #Error].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2709
	(tokenType ~~ $) ) ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2710
	    tokenType isCharacter ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2711
		self syntaxError:'missing '')'' (i.e. ''' , tokenType asString , ''' unexpected)' withCRs position:pos to:tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2712
	    ] ifFalse:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2713
		self syntaxError:'missing '')''' position:pos to:tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2714
	    ].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2715
	    ^ #Error
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2716
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2717
	self nextToken.
120
claus
parents: 117
diff changeset
  2718
	((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2719
	    self parseError:'invalid assignment' position:pos to:tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2720
	    ^ #Error
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2721
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2722
	val parenthized:true.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2723
	^ val
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2724
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2725
    (tokenType == $[ ) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2726
	val := self block.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2727
	self nextToken.
120
claus
parents: 117
diff changeset
  2728
	((tokenType == $_) or:[tokenType == #':=']) ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2729
	    self parseError:'invalid assignment' position:pos to:tokenPosition.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2730
	    ^ #Error
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2731
	].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2732
	^ val
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2733
    ].
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2734
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2735
    (tokenType == #Error) ifTrue:[^ #Error].
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2736
    tokenType isCharacter ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2737
	self syntaxError:('error in primary; ' 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2738
			   , tokenType printString , 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2739
			   ' unexpected') position:tokenPosition to:tokenPosition
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2740
    ] ifFalse:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2741
	(#(BinaryOperator Keyword) includes:tokenType) ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2742
	    self syntaxError:('error in primary; ' 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2743
			       , tokenType printString , '(' , tokenName , ') ' ,
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2744
			       ' unexpected')
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2745
	] ifFalse:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2746
	    self syntaxError:('error in primary; ' 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2747
			       , tokenType printString ,
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2748
			       ' unexpected') 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2749
	]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2750
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2751
    ^ #Error
120
claus
parents: 117
diff changeset
  2752
claus
parents: 117
diff changeset
  2753
    "Created: 13.9.1995 / 12:50:50 / claus"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2754
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2755
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2756
statement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2757
    "parse a statement; return a node-tree or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2758
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2759
     statement ::= '^' expression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2760
		   | PRIMITIVECODE
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2761
		   | expression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2762
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2763
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2764
    |expr node|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2765
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2766
    (tokenType == $^) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2767
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2768
	expr := self expression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2769
	(expr == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2770
	node := ReturnNode expression:expr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2771
	node home:self blockHome:currentBlock.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2772
	^ node
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2773
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2774
    (tokenType == #Primitive) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2775
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2776
	node := PrimitiveNode code:tokenValue.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2777
	node isOptional ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2778
	    hasNonOptionalPrimitiveCode := true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2779
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2780
	hasPrimitiveCode := true.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2781
	^ node
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2782
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2783
    (tokenType == #EOF) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2784
	self syntaxError:'period after last statement'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2785
	^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2786
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2787
    expr := self expression.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2788
    (expr == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2789
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2790
    classToCompileFor notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2791
	currentBlock isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2792
	    expr isPrimary ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2793
		self warning:'useless computation - missing ^ ?'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2794
	    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2795
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2796
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2797
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2798
    ^ StatementNode expression:expr
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2799
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2800
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2801
statementList
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2802
    "parse a statementlist; return a node-tree, nil or #Error.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2803
     Statements must be separated by periods.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2804
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2805
     statementList ::= <statement>
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2806
		       | <statementList> . <statement>
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2807
    "
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2808
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2809
    |thisStatement prevStatement firstStatement correctIt periodPos|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2810
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2811
    thisStatement := self statement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2812
    (thisStatement == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2813
    firstStatement := thisStatement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2814
    [tokenType == $.] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2815
	periodPos := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2816
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2817
	(tokenType == $]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2818
	    currentBlock isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2819
		self parseError:'block nesting error'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2820
		errorFlag := true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2821
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2822
	    *** I had a warning here (since it was not defined
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2823
	    *** in the blue-book; but PD-code contains a lot of
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2824
	    *** code with periods at the end so that the warnings
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2825
	    *** became annoying
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2826
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2827
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2828
		self warning:'period after last statement' position:periodPos
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2829
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2830
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2831
	    ^ firstStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2832
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2833
	(tokenType == #EOF) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2834
	    currentBlock notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2835
		self parseError:'block nesting error (expected '']'')'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2836
		errorFlag := true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2837
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2838
	    *** I had a warning here (since it was not defined
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2839
	    *** in the blue-book; but PD-code contains a lot of
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2840
	    *** code with periods at the end so that the warnings
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2841
	    *** became annoying
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2842
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2843
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2844
		self warning:'period after last statement' position:periodPos
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2845
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2846
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2847
	    ^ firstStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2848
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2849
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2850
	prevStatement := thisStatement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2851
	prevStatement isReturnNode ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2852
	    self warning:'statements after return' position:tokenPosition
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2853
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2854
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2855
	periodPos := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2856
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2857
"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2858
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2859
	((tokenType == $]) or:[tokenType == #EOF]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2860
	    (currentBlock isNil and:[tokenType == $]]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2861
		self parseError:'block nesting error'.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2862
		errorFlag := true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2863
	    ] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2864
		correctIt := self correctableError:'period after last statement in block'
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2865
					  position:periodPos to:(periodPos + 1).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2866
		correctIt ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2867
		    (self correctByDeleting == #Error) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2868
			errorFlag := true
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2869
		    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2870
		]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2871
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2872
	    ^ firstStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2873
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2874
	thisStatement := self statement.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2875
	(thisStatement == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2876
	prevStatement nextStatement:thisStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2877
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2878
    ^ firstStatement
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2879
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2880
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2881
unaryExpression
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2882
    "parse a unary-expression; return a node-tree, nil or #Error"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2883
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2884
    |receiver sel pos pos2 try|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2885
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2886
    receiver := self primary.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2887
    (receiver == #Error) ifTrue:[^ #Error].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2888
    [tokenType == #Identifier] whileTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2889
	pos := tokenPosition.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2890
	pos2 := pos + tokenName size - 1.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2891
	sel := self selectorCheck:tokenName for:receiver position:pos to:pos2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2892
	try := UnaryNode receiver:receiver selector:sel.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2893
	(try isMemberOf:String) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2894
	    self parseError:try position:pos to:pos2.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2895
	    errorFlag := false. "ok, user wants it - so he'll get it"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2896
	    receiver := UnaryNode receiver:receiver selector:sel fold:false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2897
	] ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2898
	    receiver := try
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2899
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2900
	receiver lineNumber:tokenLineNr.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2901
	parseForCode ifFalse:[self rememberSelectorUsed:sel].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2902
	self nextToken.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2903
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2904
    ^ receiver
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
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2907
variable
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2908
    "parse a variable; if undefined, notify error and correct if user wants to"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2909
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2910
    |v|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2911
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2912
    v := self variableOrError.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2913
    (v == #Error) ifFalse:[^ v].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2914
    v := self correctVariable.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2915
    (v == #Error) ifFalse:[^ v].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2916
    parseForCode ifFalse:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2917
	self rememberGlobalUsed:tokenName
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2918
    ] ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2919
	tokenName first isLowercase ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2920
	    ImplicitSelfSends ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2921
		selfNode isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2922
		    selfNode := SelfNode value:selfValue
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2923
		].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2924
		^ UnaryNode receiver:selfNode selector:('implicit_' , tokenName) asSymbol.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2925
	    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2926
	    ^ #Error
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2927
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2928
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2929
    ^ VariableNode type:#GlobalVariable name:tokenName asSymbol
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2930
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  2931
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2932
variableOrError
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2933
    "parse a variable; return a node-tree, nil or #Error"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2934
21
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2935
    ^ self variableOrError:tokenName
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2936
!
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2937
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2938
variableOrError:varName
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2939
    "parse a variable; return a node-tree, nil or #Error"
338c3cfeffbf *** empty log message ***
claus
parents: 20
diff changeset
  2940
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2941
    |var instIndex aClass searchBlock args vars
53
c5dd7abf8431 *** empty log message ***
claus
parents: 52
diff changeset
  2942
     tokenSymbol|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2943
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2944
    "is it a block-arg or block-var ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2945
    searchBlock := currentBlock.
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2946
    [searchBlock notNil] whileTrue:[
47
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  2947
	vars := searchBlock variables.
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  2948
	vars notNil ifTrue:[
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  2949
	    instIndex := vars findFirst:[:aBlockVar | aBlockVar name = varName].
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  2950
	    instIndex ~~ 0 ifTrue:[
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  2951
		^ VariableNode type:#BlockVariable
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  2952
			       name:varName
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  2953
			      token:(vars at:instIndex)
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  2954
			      index:instIndex
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  2955
			      block:searchBlock
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  2956
	    ].
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  2957
	].
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  2958
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2959
	args := searchBlock arguments.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2960
	args notNil ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2961
	    instIndex := args findFirst:[:aBlockArg | aBlockArg name = varName].
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2962
	    instIndex ~~ 0 ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2963
		^ VariableNode type:#BlockArg
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2964
			       name:varName
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2965
			      token:(args at:instIndex)
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2966
			      index:instIndex
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2967
			      block:searchBlock
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2968
	    ].
19
84a1ddf215a5 *** empty log message ***
claus
parents: 15
diff changeset
  2969
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2970
	].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2971
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2972
	searchBlock := searchBlock home
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2973
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2974
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2975
    "is it a method-variable ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2976
    methodVars notNil ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2977
	instIndex := methodVarNames indexOf:varName.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2978
	instIndex ~~ 0 ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2979
	    var := methodVars at:instIndex.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2980
	    var used:true.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2981
	    ^ VariableNode type:#MethodVariable
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2982
			   name:varName
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2983
			  token:var
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2984
			  index:instIndex
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2985
	]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2986
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2987
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2988
    "is it a method-argument ?"
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2989
    methodArgs notNil ifTrue:[
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2990
	instIndex := methodArgNames indexOf:varName.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2991
	instIndex ~~ 0 ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2992
	    ^ VariableNode type:#MethodArg
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2993
			   name:varName
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2994
			  token:(methodArgs at:instIndex)
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2995
			  index:instIndex
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  2996
	]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2997
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2998
7ad01559b262 Initial revision
claus
parents:
diff changeset
  2999
    classToCompileFor notNil ifTrue:[
80
101b42803846 *** empty log message ***
claus
parents: 79
diff changeset
  3000
	"is it an instance-variable ?"
101b42803846 *** empty log message ***
claus
parents: 79
diff changeset
  3001
98
claus
parents: 97
diff changeset
  3002
	instIndex := (self instVarNames) lastIndexOf:varName.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3003
	instIndex ~~ 0 ifTrue:[
84
claus
parents: 83
diff changeset
  3004
	    parseForCode ifFalse:[self rememberInstVarUsed:varName].
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3005
	    ^ VariableNode type:#InstanceVariable 
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3006
			   name:varName
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3007
			  index:instIndex
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3008
		      selfValue:selfValue
80
101b42803846 *** empty log message ***
claus
parents: 79
diff changeset
  3009
	].
101b42803846 *** empty log message ***
claus
parents: 79
diff changeset
  3010
101b42803846 *** empty log message ***
claus
parents: 79
diff changeset
  3011
	"is it a class-instance-variable ?"
101b42803846 *** empty log message ***
claus
parents: 79
diff changeset
  3012
98
claus
parents: 97
diff changeset
  3013
	instIndex := (self classInstVarNames) lastIndexOf:varName.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3014
	instIndex ~~ 0 ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3015
	    aClass := self inWhichClassIsClassInstVar:varName.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3016
	    aClass notNil ifTrue:[
84
claus
parents: 83
diff changeset
  3017
		parseForCode ifFalse:[self rememberClassVarUsed:varName].
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3018
		^ VariableNode type:#ClassInstanceVariable
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3019
			       name:varName
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3020
			      index:instIndex
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3021
			  selfClass:aClass
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3022
	    ]
80
101b42803846 *** empty log message ***
claus
parents: 79
diff changeset
  3023
	].
101b42803846 *** empty log message ***
claus
parents: 79
diff changeset
  3024
101b42803846 *** empty log message ***
claus
parents: 79
diff changeset
  3025
	"is it a class-variable ?"
101b42803846 *** empty log message ***
claus
parents: 79
diff changeset
  3026
98
claus
parents: 97
diff changeset
  3027
	instIndex := (self classVarNames) lastIndexOf:varName.
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3028
	instIndex ~~ 0 ifTrue:[
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3029
	    aClass := self inWhichClassIsClassVar:varName.
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3030
	    aClass notNil ifTrue:[
84
claus
parents: 83
diff changeset
  3031
		parseForCode ifFalse:[self rememberClassVarUsed:varName].
98
claus
parents: 97
diff changeset
  3032
		^ VariableNode type:#ClassVariable class:aClass name:varName
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3033
	    ]
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3034
	]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3035
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3036
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3037
    "is it a global-variable ?"
63
c30ce56de7a8 *** empty log message ***
claus
parents: 62
diff changeset
  3038
    tokenSymbol := varName asSymbolIfInterned.
c30ce56de7a8 *** empty log message ***
claus
parents: 62
diff changeset
  3039
    tokenSymbol notNil ifTrue:[
47
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  3040
	(Smalltalk includesKey:tokenSymbol) ifTrue:[
84
claus
parents: 83
diff changeset
  3041
	    parseForCode ifFalse:[self rememberGlobalUsed:varName].
47
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  3042
	    ^ VariableNode type:#GlobalVariable name:tokenSymbol
f861ad42703e *** empty log message ***
claus
parents: 45
diff changeset
  3043
	]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3044
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3045
    ^ #Error
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3046
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3047
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3048
!Parser methodsFor:'queries'!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3049
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3050
classInstVarNames
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3051
    "caching allInstVarNames for next compilation saves time ..."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3052
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3053
    PrevClassInstVarNames isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3054
	PrevClassInstVarNames := classToCompileFor class allInstVarNames
98
claus
parents: 97
diff changeset
  3055
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3056
    ^ PrevClassInstVarNames
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3057
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3058
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3059
classVarNames
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3060
    "caching allClassVarNames for next compilation saves time ..."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3061
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3062
    |aClass className|
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3063
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3064
    PrevClassVarNames isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3065
	aClass := classToCompileFor.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3066
	classToCompileFor isMeta ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3067
	    className := aClass name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3068
	    className := className copyWithoutLast:5.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3069
	    aClass := Smalltalk at:(className asSymbol).
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3070
	    aClass isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3071
		aClass := classToCompileFor
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3072
	    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3073
	].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3074
	PrevClassVarNames := aClass allClassVarNames
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3075
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3076
    ^ PrevClassVarNames
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3077
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3078
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3079
hasNonOptionalPrimitiveCode
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3080
    "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
  3081
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3082
    ^ hasNonOptionalPrimitiveCode
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3083
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3084
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3085
hasPrimitiveCode
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3086
    "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
  3087
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3088
    ^ hasPrimitiveCode
98
claus
parents: 97
diff changeset
  3089
!
claus
parents: 97
diff changeset
  3090
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3091
instVarNames
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3092
    "caching allInstVarNames for next compilation saves time ..."
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3093
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3094
    (PrevInstVarNames isNil or:[PrevClass ~~ classToCompileFor]) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3095
	PrevClass notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3096
	    PrevClass removeDependent:Parser
44
74ddc944c27f *** empty log message ***
claus
parents: 35
diff changeset
  3097
	].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3098
	PrevClass := classToCompileFor.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3099
	PrevInstVarNames := classToCompileFor allInstVarNames.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3100
	PrevClassInstVarNames := nil.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3101
	PrevClassVarNames := nil.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3102
	PrevClass addDependent:Parser
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3103
    ].
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3104
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3105
    ^ PrevInstVarNames
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3106
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3107
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3108
methodArgs
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3109
    "return an array with methodarg names (valid after parsing spec)"
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
    ^ methodArgNames
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3112
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3113
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3114
methodVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3115
    "return a collection with method variablenames (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3116
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3117
    ^ methodVarNames
23
1f7bcfff8d39 *** empty log message ***
claus
parents: 21
diff changeset
  3118
!
1f7bcfff8d39 *** empty log message ***
claus
parents: 21
diff changeset
  3119
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3120
modifiedClassVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3121
    "return a collection with classvariablenames modified by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3122
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3123
    ^ modifiedClassVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3124
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3125
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3126
modifiedGlobals
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3127
    "return a collection with globalnames modified by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3128
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3129
    ^ modifiedGlobals
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
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3132
modifiedInstVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3133
    "return a collection with instvariablenames modified by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3134
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3135
    ^ modifiedInstVars
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3136
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3137
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3138
numberOfMethodArgs
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3139
    "return the number of methodargs (valid after parsing spec)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3140
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3141
    ^ methodArgs size
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3142
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3143
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3144
numberOfMethodVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3145
    "return the number of method variables (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3146
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3147
    ^ methodVars size
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3148
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3149
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3150
selector
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3151
    "return the selector (valid after parsing spec)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3152
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3153
    ^ selector
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3154
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3155
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3156
usedClassVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3157
    "return a collection with classvariablenames refd by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3158
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3159
    ^ usedClassVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3160
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3161
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3162
usedGlobals
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3163
    "return a collection with globalnames refd by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3164
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3165
    ^ usedGlobals
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3166
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3167
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3168
usedInstVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3169
    "return a collection with instvariablenames refd by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3170
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3171
    ^ usedInstVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3172
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3173
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3174
usedVars
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3175
    "return a collection with variablenames refd by method (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3176
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3177
    ^ usedVars
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3178
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3179
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3180
usesSuper
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3181
    "return true if the parsed method uses super (valid after parsing)"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3182
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3183
    ^ usesSuper
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3184
! !
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3185
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3186
!Parser methodsFor:'setup'!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3187
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3188
initialize
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3189
    super initialize.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3190
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3191
    hasPrimitiveCode := hasNonOptionalPrimitiveCode := false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3192
    warnSTXHereExtensionUsed := WarnSTXSpecials.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3193
    usesSuper := false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3194
    parseForCode := false.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3195
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3196
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3197
parseForCode
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3198
    "turns off certain statistics (keeping referenced variables, modified vars etc.)
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3199
     Use this when parsing for compilation or evaluation"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3200
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3201
    parseForCode := true
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3202
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3203
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3204
setClassToCompileFor:aClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3205
    "set the class to be used for parsing/evaluating"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3206
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3207
    classToCompileFor := aClass.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3208
    (classToCompileFor ~~ PrevClass) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3209
	PrevClass notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3210
	    Parser update:PrevClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3211
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3212
    ]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3213
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3214
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3215
setContext:aContext
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3216
    "set the context used while evaluating"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3217
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3218
    contextToEvaluateIn := aContext
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3219
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3220
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3221
setSelf:anObject
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3222
    "set the value to be used for self while evaluating"
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3223
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3224
    selfValue := anObject.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3225
    classToCompileFor := anObject class.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3226
    (classToCompileFor ~~ PrevClass) ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3227
	PrevClass notNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3228
	    Parser update:PrevClass
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3229
	]
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3230
    ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3231
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
  3232
84
claus
parents: 83
diff changeset
  3233
!Parser methodsFor:'statistic'!
claus
parents: 83
diff changeset
  3234
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3235
rememberClassVarUsed:name 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3236
    usedClassVars isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3237
	usedClassVars := Set new
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3238
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3239
    usedClassVars add:name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3240
    self rememberVariableUsed:name
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3241
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3242
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3243
rememberGlobalUsed:name 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3244
    usedGlobals isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3245
	usedGlobals := Set new
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3246
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3247
    usedGlobals add:name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3248
    self rememberVariableUsed:name
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3249
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3250
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3251
rememberInstVarUsed:name 
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3252
    usedInstVars isNil ifTrue:[
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3253
	usedInstVars := Set new
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3254
    ].
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3255
    usedInstVars add:name.
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3256
    self rememberVariableUsed:name
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3257
!
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3258
84
claus
parents: 83
diff changeset
  3259
rememberSelectorUsed:sel
claus
parents: 83
diff changeset
  3260
    usedMessages isNil ifTrue:[
claus
parents: 83
diff changeset
  3261
	usedMessages := IdentitySet new.
claus
parents: 83
diff changeset
  3262
    ].
claus
parents: 83
diff changeset
  3263
    usedMessages add:sel
claus
parents: 83
diff changeset
  3264
!
claus
parents: 83
diff changeset
  3265
claus
parents: 83
diff changeset
  3266
rememberVariableUsed:name 
claus
parents: 83
diff changeset
  3267
    usedVars isNil ifTrue:[
claus
parents: 83
diff changeset
  3268
	usedVars := Set new
claus
parents: 83
diff changeset
  3269
    ].
claus
parents: 83
diff changeset
  3270
    usedVars add:name
claus
parents: 83
diff changeset
  3271
! !
claus
parents: 83
diff changeset
  3272
148
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 145
diff changeset
  3273
!Parser class methodsFor:'documentation'!
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 145
diff changeset
  3274
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 145
diff changeset
  3275
version
207
6ab9eb3c1cf0 by default, dont warn about ST80 directives
Claus Gittinger <cg@exept.de>
parents: 202
diff changeset
  3276
    ^ '$Header: /cvs/stx/stx/libcomp/Parser.st,v 1.67 1996-02-08 21:04:55 cg Exp $'
148
ef0e604209ec version method at the end
Claus Gittinger <cg@exept.de>
parents: 145
diff changeset
  3277
! !
141
d378d997aab0 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 139
diff changeset
  3278
Parser initialize!