Scanner.st
author claus
Mon, 10 Oct 1994 01:58:23 +0100
changeset 45 e8331ba8ad5d
parent 41 62214c6ca833
child 49 02660b790c3e
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
     1
"
4
f6fd83437415 *** empty log message ***
claus
parents: 3
diff changeset
     2
 COPYRIGHT (c) 1989 by Claus Gittinger
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
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
Object subclass:#Scanner
7ad01559b262 Initial revision
claus
parents:
diff changeset
    14
       instanceVariableNames:'source 
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    15
			      token tokenType tokenPosition tokenValue
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    16
			      tokenName tokenLineNr tokenRadix
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    17
			      thisChar peekChar
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    18
			      requestor exitBlock
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    19
			      errorFlag 
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    20
			      ignoreErrors ignoreWarnings
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    21
			      saveComments currentComments
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    22
			      warnSTXSpecialComment
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    23
			      outStream outCol'
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    24
	  classVariableNames:'TypeArray ActionArray Warnings WarnSTXSpecials'
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    25
	    poolDictionaries:''
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    26
		    category:'System-Compiler'
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    27
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    28
7ad01559b262 Initial revision
claus
parents:
diff changeset
    29
Scanner comment:'
4
f6fd83437415 *** empty log message ***
claus
parents: 3
diff changeset
    30
COPYRIGHT (c) 1989 by Claus Gittinger
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    31
	     All Rights Reserved
30
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
    32
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    33
$Header: /cvs/stx/stx/libcomp/Scanner.st,v 1.13 1994-10-10 00:57:45 claus Exp $
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    34
'!
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    35
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    36
!Scanner class methodsFor:'documentation'!
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    37
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    38
copyright
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    39
"
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    40
 COPYRIGHT (c) 1989 by Claus Gittinger
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    41
	      All Rights Reserved
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    42
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    43
 This software is furnished under a license and may be used
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    44
 only in accordance with the terms of that license and with the
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    45
 inclusion of the above copyright notice.   This software may not
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    46
 be provided or otherwise made available to, or used by, any
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    47
 other person.  No title to or ownership of the software is
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    48
 hereby transferred.
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    49
"
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    50
!
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    51
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    52
version
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    53
"
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    54
$Header: /cvs/stx/stx/libcomp/Scanner.st,v 1.13 1994-10-10 00:57:45 claus Exp $
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    55
"
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    56
!
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    57
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    58
documentation
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    59
"
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    60
    Scanner reads from a stream and returns individual smalltalk tokens
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    61
"
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
    62
! !
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    63
7ad01559b262 Initial revision
claus
parents:
diff changeset
    64
!Scanner class methodsFor:'instance creation'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    65
30
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
    66
for:aStringOrStream
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
    67
    "return a new scanner reading from aStringOrStream"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    68
30
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
    69
    ^ (super new) initializeFor:aStringOrStream
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    70
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
    71
41
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    72
!Scanner class methodsFor:'defaults'!
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    73
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    74
warnings:aBoolean
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    75
    "this allows turning on/off warnings; the default is on.
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    76
     You can turn off warnings in your 'private.rc' file with
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    77
	 Compiler warnings:false
41
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    78
    "
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    79
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    80
    Warnings := aBoolean
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    81
!
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    82
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    83
warnSTXSpecials:aBoolean
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    84
    "this allows turning on/off warnings about stx specials.
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    85
     If you get bored by those warnings, turn them off by adding
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    86
     a line as:
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
    87
	Compiler warnSTXSpecials:false
41
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    88
     in your 'private.rc' file"
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    89
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    90
    WarnSTXSpecials := aBoolean
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    91
! !
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
    92
33
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
    93
!Scanner class methodsFor:'initialization'!
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
    94
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
    95
setupActions
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
    96
    |block|
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
    97
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
    98
    ActionArray := Array new:256.
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
    99
    TypeArray := Array new:256.
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   100
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   101
    block := [:s :char | s nextNumber].
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   102
    ($0 asciiValue) to:($9 asciiValue) do:[:index |
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   103
	ActionArray at:index put:block
33
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   104
    ].
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   105
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   106
    block := [:s :char | s nextIdentifier].
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   107
    ($a asciiValue) to:($z asciiValue) do:[:index |
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   108
	ActionArray at:index put:block
33
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   109
    ].
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   110
    ($A asciiValue) to:($Z asciiValue) do:[:index |
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   111
	ActionArray at:index put:block
33
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   112
    ].
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   113
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   114
    block := [:s :char | s nextSpecial].
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   115
    #( $& $- $+ $= $* $/ $\ $< $> $~ $@ $, $? ) do:[:binop |
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   116
	TypeArray at:(binop asciiValue) put:#special.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   117
	ActionArray at:(binop asciiValue) put:block
33
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   118
    ].
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   119
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   120
    block := [:s :char | s nextToken:char].
38
7bd25d09a330 *** empty log message ***
claus
parents: 33
diff changeset
   121
    #( $; $. $( $) $[ $] $!! $^ $| $_ ) do:[:ch |
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   122
	ActionArray at:(ch asciiValue) put:block
33
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   123
    ].
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   124
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   125
    "kludge: action is characterToken, but type is special"
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   126
    TypeArray at:($| asciiValue) put:#special.
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   127
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   128
    ActionArray at:($' asciiValue) put:[:s :char | s nextString].
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   129
    ActionArray at:($$ asciiValue) put:[:s :char | s nextCharacter].
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   130
    ActionArray at:($# asciiValue) put:[:s :char | s nextHash].
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   131
    ActionArray at:($% asciiValue) put:[:s :char | s nextPrimitive].
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   132
    ActionArray at:($: asciiValue) put:[:s :char | s nextColonOrAssign]
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   133
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   134
    "
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   135
     Scanner setupActions
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   136
    "
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   137
! !
8985ec2f9e82 *** empty log message ***
claus
parents: 30
diff changeset
   138
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   139
!Scanner methodsFor:'private'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   140
30
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
   141
initializeFor:aStringOrStream
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   142
    "initialize -
7ad01559b262 Initial revision
claus
parents:
diff changeset
   143
     if this is the first time, setup character- and action tables"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   144
7ad01559b262 Initial revision
claus
parents:
diff changeset
   145
    errorFlag := false.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   146
    tokenLineNr := 1.
30
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
   147
    aStringOrStream isStream ifFalse:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   148
	source := ReadStream on:aStringOrStream
30
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
   149
    ] ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   150
	source := aStringOrStream.
30
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
   151
    ].
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   152
    currentComments := nil.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   153
    saveComments := false.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   154
    ignoreErrors := false.
41
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
   155
    ignoreWarnings := Warnings not.
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
   156
    warnSTXSpecialComment := WarnSTXSpecials.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   157
10
73e97b6175c4 *** empty log message ***
claus
parents: 7
diff changeset
   158
    ActionArray isNil ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   159
	self class setupActions
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   160
    ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   161
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   162
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   163
initialize
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   164
    "prepare a scan"
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   165
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   166
    errorFlag := false.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   167
    tokenLineNr := 1.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   168
    currentComments := nil.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   169
    saveComments := false.
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   170
    ignoreErrors := false.
41
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
   171
    ignoreWarnings := Warnings not.
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
   172
    warnSTXSpecialComment := WarnSTXSpecials
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   173
!
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   174
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   175
notifying:anObject
7ad01559b262 Initial revision
claus
parents:
diff changeset
   176
    "set the requestor to be notified"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   177
7ad01559b262 Initial revision
claus
parents:
diff changeset
   178
    requestor := anObject
7ad01559b262 Initial revision
claus
parents:
diff changeset
   179
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   180
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   181
ignoreErrors
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   182
    "turn off notification of errors"
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   183
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   184
    ignoreErrors := true
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   185
!
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   186
17
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   187
ignoreWarnings
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   188
    "turn off notification of warnings"
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   189
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   190
    ignoreWarnings := true
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   191
!
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   192
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   193
backupPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
   194
    "if reading from a stream, at the end we might have read
7ad01559b262 Initial revision
claus
parents:
diff changeset
   195
     one token too many"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   196
7ad01559b262 Initial revision
claus
parents:
diff changeset
   197
    (tokenType == #EOF) ifFalse:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   198
	source position:tokenPosition
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   199
    ]
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   200
!
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   201
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   202
beginComment
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   203
    ^ self
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   204
!
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   205
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   206
endComment:comment
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   207
    saveComments ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   208
	currentComments isNil ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   209
	    currentComments := OrderedCollection with:comment
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   210
	] ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   211
	    currentComments add:comment
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   212
	]
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   213
    ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   214
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   215
7ad01559b262 Initial revision
claus
parents:
diff changeset
   216
!Scanner methodsFor:'error handling'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   217
7ad01559b262 Initial revision
claus
parents:
diff changeset
   218
showErrorMessage:aMessage position:pos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   219
    "show an errormessage on the Transcript"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   220
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   221
    ignoreErrors ifFalse:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   222
	Smalltalk silentLoading == true ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   223
	    Transcript showCr:(pos printString , ' ' , aMessage)
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   224
	]
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   225
    ]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   226
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   227
7ad01559b262 Initial revision
claus
parents:
diff changeset
   228
notifyError:aMessage position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   229
    "notify requestor of an error - if there is no requestor
7ad01559b262 Initial revision
claus
parents:
diff changeset
   230
     put it on the transcript.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   231
     Return the result passed back by the requestor."
7ad01559b262 Initial revision
claus
parents:
diff changeset
   232
7ad01559b262 Initial revision
claus
parents:
diff changeset
   233
    requestor isNil ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   234
	self showErrorMessage:aMessage position:position.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   235
	^ false
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   236
    ].
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   237
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   238
    ^ requestor error:aMessage position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   239
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   240
7ad01559b262 Initial revision
claus
parents:
diff changeset
   241
notifyWarning:aMessage position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   242
    "notify requestor of an warning - if there is no requestor
7ad01559b262 Initial revision
claus
parents:
diff changeset
   243
     put it on the transcript.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   244
     Return the result passed back by the requestor."
7ad01559b262 Initial revision
claus
parents:
diff changeset
   245
7ad01559b262 Initial revision
claus
parents:
diff changeset
   246
    requestor isNil ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   247
	ignoreWarnings ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   248
	    self showErrorMessage:aMessage position:position.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   249
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   250
	^ false
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   251
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   252
    ^ requestor warning:aMessage position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   253
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   254
7ad01559b262 Initial revision
claus
parents:
diff changeset
   255
syntaxError:aMessage position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   256
    "a syntax error happened"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   257
7ad01559b262 Initial revision
claus
parents:
diff changeset
   258
    self notifyError:(' Error:' , aMessage) position:position to:endPos.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   259
    exitBlock notNil ifTrue:[exitBlock value].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   260
    ^ false
7ad01559b262 Initial revision
claus
parents:
diff changeset
   261
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   262
7ad01559b262 Initial revision
claus
parents:
diff changeset
   263
syntaxError:aMessage position:position
7ad01559b262 Initial revision
claus
parents:
diff changeset
   264
    "a syntax error happened - only start position is known"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   265
7ad01559b262 Initial revision
claus
parents:
diff changeset
   266
    ^ self syntaxError:aMessage position:position to:nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
   267
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   268
7ad01559b262 Initial revision
claus
parents:
diff changeset
   269
syntaxError:aMessage
7ad01559b262 Initial revision
claus
parents:
diff changeset
   270
    "a syntax error happened - position is not known"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   271
7ad01559b262 Initial revision
claus
parents:
diff changeset
   272
    ^ self syntaxError:aMessage position:tokenPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
   273
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   274
7ad01559b262 Initial revision
claus
parents:
diff changeset
   275
warning:aMessage position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   276
    "a warning"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   277
30
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
   278
    ^ self notifyWarning:('Warning: ' , aMessage) position:position to:endPos
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   279
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   280
7ad01559b262 Initial revision
claus
parents:
diff changeset
   281
warning:aMessage position:position
7ad01559b262 Initial revision
claus
parents:
diff changeset
   282
    "a warning - only start position is known"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   283
7ad01559b262 Initial revision
claus
parents:
diff changeset
   284
    ^ self warning:aMessage position:position to:nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
   285
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   286
7ad01559b262 Initial revision
claus
parents:
diff changeset
   287
warning:aMessage
7ad01559b262 Initial revision
claus
parents:
diff changeset
   288
    "a warning - position is not known"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   289
7ad01559b262 Initial revision
claus
parents:
diff changeset
   290
    ^ self warning:aMessage position:tokenPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
   291
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   292
17
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   293
!Scanner methodsFor:'general scanning'!
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   294
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   295
scanPositionsFor:aTokenString inString:aSourceString
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   296
    "scan aSourceString for occurrances of aTokenString.
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   297
     Return a collection of start positions.
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   298
     Added for VW compatibility (to support syntax-highlight)."
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   299
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   300
    |searchType searchName searchValue positions t|
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   301
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   302
    "
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   303
     first, look what kind of token we have to search for
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   304
    "
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   305
    self initializeFor:(ReadStream on:aTokenString).
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   306
    self nextToken.
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   307
    searchType := tokenType.
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   308
    searchName := tokenName.
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   309
    searchValue := tokenValue.
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   310
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   311
    "
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   312
     start the real work ...
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   313
    "
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   314
    self initializeFor:(ReadStream on:aSourceString).
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   315
    positions := OrderedCollection new.
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   316
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   317
    [(t := self nextToken) ~~ #EOF] whileTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   318
	searchType == t ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   319
	    (searchName isNil or:[tokenName = searchName]) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   320
		(searchValue isNil or:[tokenValue = searchValue]) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   321
		    positions add:tokenPosition.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   322
		]
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   323
	    ]
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   324
	]
17
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   325
    ].
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   326
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   327
    ^ positions
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   328
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   329
    "
30
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
   330
     Scanner new scanPositionsFor:'hello' inString:'foo bar hello baz hello' 
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
   331
     Scanner new scanPositionsFor:'3.14' inString:'foo 3.145 bar hello 3.14 baz hello 3.14' 
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
   332
     Scanner new scanPositionsFor:'16' inString:'foo 16 bar hello 16r10 baz hello 2r10000' 
17
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   333
    "
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   334
! !
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   335
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   336
!Scanner methodsFor:'reading next token'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   337
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   338
skipComment
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   339
    |comment startPos|
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   340
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   341
    comment := ''.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   342
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   343
    self beginComment.
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   344
    outStream notNil ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   345
	outStream nextPut:Character doubleQuote.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   346
	outCol := outCol + 1
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   347
    ].
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   348
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   349
    startPos := source position.
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   350
    source next.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   351
    thisChar := source peek.
15
992c3d87edbf *** empty log message ***
claus
parents: 10
diff changeset
   352
992c3d87edbf *** empty log message ***
claus
parents: 10
diff changeset
   353
    "special ST/X addition:
17
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   354
     a $/ right after the initial double quote makes it an up-to-end-of-line comment,
15
992c3d87edbf *** empty log message ***
claus
parents: 10
diff changeset
   355
     which is very useful to comment out parts of filed-in source code.
17
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   356
     Since this is non-standard, use it in very rare cases only. 
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   357
     (maybe the upcoming ansi-standard adds something similar - in this case, I will
f06d70d785dc *** empty log message ***
claus
parents: 15
diff changeset
   358
      change it without notice)"
15
992c3d87edbf *** empty log message ***
claus
parents: 10
diff changeset
   359
992c3d87edbf *** empty log message ***
claus
parents: 10
diff changeset
   360
    thisChar == $/ ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   361
	[thisChar notNil and:[thisChar ~~ Character cr]] whileTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   362
	    saveComments ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   363
		comment := comment copyWith:thisChar
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   364
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   365
	    outStream notNil ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   366
		outStream nextPut:thisChar.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   367
		outCol := outCol + 1
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   368
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   369
	    thisChar := source nextPeek.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   370
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   371
	tokenLineNr := tokenLineNr + 1.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   372
	ignoreWarnings ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   373
	    warnSTXSpecialComment ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   374
		self warning:'end-of-line comments are a nonstandard feature of ST/X' 
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   375
		     position:startPos to:(source position).
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   376
		"
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   377
		 only warn once
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   378
		"
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   379
		warnSTXSpecialComment := false
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   380
	    ]
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   381
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   382
	outStream notNil ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   383
	    outStream cr.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   384
	    outCol := 1
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   385
	].
15
992c3d87edbf *** empty log message ***
claus
parents: 10
diff changeset
   386
    ] ifFalse:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   387
	[thisChar notNil and:[thisChar ~~ (Character doubleQuote)]] whileTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   388
	    thisChar == (Character cr) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   389
		tokenLineNr := tokenLineNr + 1.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   390
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   391
	    saveComments ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   392
		comment := comment copyWith:thisChar
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   393
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   394
	    outStream notNil ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   395
		outStream nextPut:thisChar.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   396
		outCol := outCol + 1
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   397
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   398
	    thisChar := source nextPeek
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   399
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   400
	thisChar isNil ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   401
	    self warning:'unclosed comment' position:startPos to:(source position)
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   402
	] ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   403
	    outStream notNil ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   404
		outStream nextPut:(Character doubleQuote).
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   405
		outCol := outCol + 1
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   406
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   407
	]
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   408
    ].
15
992c3d87edbf *** empty log message ***
claus
parents: 10
diff changeset
   409
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   410
    saveComments ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   411
	currentComments isNil ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   412
	    currentComments := OrderedCollection with:comment
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   413
	] ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   414
	    currentComments add:comment
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   415
	]
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   416
    ].
7
6c2bc76f0b8f *** empty log message ***
claus
parents: 4
diff changeset
   417
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   418
    "skip final dQuote or cr"
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   419
    source next.
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   420
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   421
    self endComment:comment.
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   422
!
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   423
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   424
nextToken
7ad01559b262 Initial revision
claus
parents:
diff changeset
   425
    "return the next token from the source-stream"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   426
41
62214c6ca833 allow turning off warnings
claus
parents: 38
diff changeset
   427
    |skipping actionBlock|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   428
7ad01559b262 Initial revision
claus
parents:
diff changeset
   429
    peekChar notNil ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   430
	thisChar := peekChar.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   431
	peekChar := nil
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   432
    ] ifFalse:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   433
	skipping := true.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   434
	[skipping] whileTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   435
	    outStream notNil ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   436
		[(thisChar := source peek) == Character space] whileTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   437
		    source next.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   438
		    outStream space. 
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   439
		    outCol := outCol + 1.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   440
		]
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   441
	    ] ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   442
		thisChar := source skipSeparatorsExceptCR.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   443
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   444
	    thisChar == (Character cr) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   445
		tokenLineNr := tokenLineNr + 1.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   446
		source next.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   447
		outStream notNil ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   448
		    outStream cr.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   449
		    outCol := 1
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   450
		]
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   451
	    ] ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   452
		thisChar == (Character doubleQuote) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   453
		    "start of a comment"
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   454
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   455
		    self skipComment.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   456
		    thisChar := source peek.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   457
		] ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   458
		    skipping := false
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   459
		]
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   460
	    ]
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   461
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   462
	thisChar isNil ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   463
	    tokenType := #EOF.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   464
	    ^ tokenType
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   465
	]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   466
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   467
    tokenPosition := source position.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   468
10
73e97b6175c4 *** empty log message ***
claus
parents: 7
diff changeset
   469
    actionBlock := ActionArray at:(thisChar asciiValue).
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   470
    actionBlock notNil ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   471
	^ actionBlock value:self value:thisChar
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   472
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   473
7ad01559b262 Initial revision
claus
parents:
diff changeset
   474
    self syntaxError:('invalid character: ''' , thisChar asString , ''' ',
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   475
		      '(' , thisChar asciiValue printString , ')')
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   476
	    position:tokenPosition to:tokenPosition.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   477
    tokenType := #Error.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   478
    ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
   479
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   480
7ad01559b262 Initial revision
claus
parents:
diff changeset
   481
nextToken:aCharacter
7ad01559b262 Initial revision
claus
parents:
diff changeset
   482
    tokenType := aCharacter.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   483
    source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   484
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   485
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   486
7ad01559b262 Initial revision
claus
parents:
diff changeset
   487
nextColonOrAssign
7ad01559b262 Initial revision
claus
parents:
diff changeset
   488
    "colon has been read - look for = to make it an assign"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   489
7ad01559b262 Initial revision
claus
parents:
diff changeset
   490
    (source nextPeek == $=) ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   491
	source next.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   492
	tokenType := $_
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   493
    ] ifFalse:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   494
	tokenType := $:
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   495
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   496
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   497
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   498
    
7ad01559b262 Initial revision
claus
parents:
diff changeset
   499
nextSpecial
7ad01559b262 Initial revision
claus
parents:
diff changeset
   500
    "a special character has been read, look for another one.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   501
     also -number is handled here"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   502
7ad01559b262 Initial revision
claus
parents:
diff changeset
   503
    |firstChar secondChar thirdChar string p|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   504
7ad01559b262 Initial revision
claus
parents:
diff changeset
   505
    firstChar := source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   506
    secondChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   507
    (firstChar == $-) ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   508
	secondChar isDigit ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   509
	    self nextNumber.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   510
	    tokenValue := tokenValue negated.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   511
	    ^ tokenType
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   512
	]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   513
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   514
    string := firstChar asString.
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   515
    secondChar notNil ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   516
	((TypeArray at:(secondChar asciiValue)) == #special) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   517
	    (secondChar == $-) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   518
		"special- look if minus belongs to number following"
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   519
		p := source position.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   520
		source next.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   521
		thirdChar := source peek.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   522
		source position:p.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   523
		thirdChar isDigit ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   524
		    tokenName := string.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   525
		    tokenType := #BinaryOperator.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   526
		    ^ tokenType
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   527
		]
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   528
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   529
	    source next.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   530
	    string := string copyWith:secondChar
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   531
	].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   532
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   533
    tokenName := string.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   534
    tokenType := #BinaryOperator.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   535
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   536
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   537
7ad01559b262 Initial revision
claus
parents:
diff changeset
   538
nextCharacter
7ad01559b262 Initial revision
claus
parents:
diff changeset
   539
    "a $ has been read - return a character token"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   540
7ad01559b262 Initial revision
claus
parents:
diff changeset
   541
    |nextChar|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   542
7ad01559b262 Initial revision
claus
parents:
diff changeset
   543
    source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   544
    nextChar := source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   545
    nextChar notNil ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   546
	tokenValue := nextChar.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   547
	tokenType := #Character
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   548
    ] ifFalse:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   549
	tokenType := #EOF
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   550
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   551
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   552
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   553
7ad01559b262 Initial revision
claus
parents:
diff changeset
   554
nextMantissa:radix
7ad01559b262 Initial revision
claus
parents:
diff changeset
   555
    |nextChar value factor|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   556
7ad01559b262 Initial revision
claus
parents:
diff changeset
   557
    value := 0.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   558
    factor := 1.0 / radix.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   559
    nextChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   560
    [(nextChar notNil and:[nextChar isDigitRadix:radix])] whileTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   561
	value := value + (nextChar digitValue * factor).
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   562
	factor := factor / radix.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   563
	nextChar := source nextPeek
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   564
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   565
    ^ value
7ad01559b262 Initial revision
claus
parents:
diff changeset
   566
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   567
7ad01559b262 Initial revision
claus
parents:
diff changeset
   568
nextNumber
30
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
   569
    |nextChar value s|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   570
30
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
   571
    tokenRadix := 10.
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
   572
    value := Integer readFrom:source radix:tokenRadix.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   573
    nextChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   574
    (nextChar == $r) ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   575
	tokenRadix := value.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   576
	source next.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   577
	s := 1.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   578
	source peek == $- ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   579
	    source next.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   580
	    s := -1
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   581
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   582
	value := Integer readFrom:source radix:tokenRadix.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   583
	value := value * s.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   584
	nextChar := source peek
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   585
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   586
    (nextChar == $.) ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   587
	nextChar := source nextPeek.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   588
	(nextChar notNil and:[nextChar isDigitRadix:tokenRadix]) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   589
	    value := value asFloat + (self nextMantissa:tokenRadix).
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   590
	    nextChar := source peek
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   591
	] ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   592
	    nextChar == (Character cr) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   593
		tokenLineNr := tokenLineNr + 1.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   594
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   595
	    peekChar := $.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   596
	]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   597
    ].
30
26e2f849916a keep tokenRadix; accept E in floats
claus
parents: 20
diff changeset
   598
    ((nextChar == $e) or:[nextChar == $E]) ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   599
	nextChar := source nextPeek.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   600
	(nextChar notNil and:[(nextChar isDigitRadix:tokenRadix) or:['+-' includes:nextChar]]) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   601
	    s := 1.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   602
	    (nextChar == $+) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   603
		nextChar := source nextPeek
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   604
	    ] ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   605
		(nextChar == $-) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   606
		    nextChar := source nextPeek.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   607
		    s := s negated
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   608
		]
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   609
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   610
	    value := value asFloat
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   611
		     * (10.0 raisedToInteger:((Integer readFrom:source radix:tokenRadix) * s))
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   612
	]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   613
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   614
    tokenValue := value.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   615
    (value isMemberOf:Float) ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   616
	tokenType := #Float
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   617
    ] ifFalse:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   618
	tokenType := #Integer
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   619
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   620
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   621
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   622
7ad01559b262 Initial revision
claus
parents:
diff changeset
   623
nextId
7ad01559b262 Initial revision
claus
parents:
diff changeset
   624
    |nextChar string oldString 
7ad01559b262 Initial revision
claus
parents:
diff changeset
   625
     index "{ Class: SmallInteger }"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   626
     max   "{ Class: SmallInteger }" |
7ad01559b262 Initial revision
claus
parents:
diff changeset
   627
7ad01559b262 Initial revision
claus
parents:
diff changeset
   628
    nextChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   629
    string := String new:10.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   630
    index := 0.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   631
    max := 10.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   632
    [true] whileTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   633
	(nextChar notNil and:[nextChar isLetterOrDigit]) ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   634
	    ^ string copyTo:index
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   635
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   636
	(index == max) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   637
	    oldString := string.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   638
	    string := String new:(max * 2).
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   639
	    string replaceFrom:1 to:max with:oldString.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   640
	    max := max * 2
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   641
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   642
	index := index + 1.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   643
	string at:index put:nextChar.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   644
	nextChar := source nextPeek
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   645
    ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   646
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   647
7ad01559b262 Initial revision
claus
parents:
diff changeset
   648
nextIdentifier
7ad01559b262 Initial revision
claus
parents:
diff changeset
   649
    |nextChar string firstChar|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   650
7ad01559b262 Initial revision
claus
parents:
diff changeset
   651
    string := source nextWord "self nextId".
7ad01559b262 Initial revision
claus
parents:
diff changeset
   652
    nextChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   653
    (nextChar == $:) ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   654
	source next.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   655
	(source peek == $=) ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   656
	    tokenName := string copyWith:nextChar.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   657
	    tokenType := #Keyword.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   658
	    ^ self
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   659
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   660
	peekChar := $_
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   661
    ].
20
f8dd8ba75205 *** empty log message ***
claus
parents: 17
diff changeset
   662
    tokenName := string.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   663
    firstChar := string at:1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   664
    (firstChar == $s) ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   665
	(string = 'self') ifTrue:[tokenType := #Self. ^self].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   666
	(string = 'super') ifTrue:[tokenType := #Super. ^self]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   667
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   668
    (firstChar == $n) ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   669
	(string = 'nil') ifTrue:[tokenType := #Nil. ^self]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   670
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   671
    (firstChar == $t) ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   672
	(string = 'true') ifTrue:[tokenType := #True. ^self].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   673
	(string = 'thisContext') ifTrue:[tokenType := #ThisContext. ^self]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   674
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   675
    (firstChar == $f) ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   676
	(string = 'false') ifTrue:[tokenType := #False. ^self]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   677
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   678
    tokenType := #Identifier.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   679
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   680
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   681
7ad01559b262 Initial revision
claus
parents:
diff changeset
   682
nextPrimitive
7ad01559b262 Initial revision
claus
parents:
diff changeset
   683
    |nextChar inPrimitive string 
7ad01559b262 Initial revision
claus
parents:
diff changeset
   684
     index "{ Class: SmallInteger }"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   685
     len   "{ Class: SmallInteger }" |
7ad01559b262 Initial revision
claus
parents:
diff changeset
   686
7ad01559b262 Initial revision
claus
parents:
diff changeset
   687
    nextChar := source nextPeek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   688
    string := String new:500.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   689
    len := 500.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   690
    index := 1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   691
    (nextChar == ${) ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   692
	nextChar := source nextPeek.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   693
	inPrimitive := true.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   694
	[inPrimitive] whileTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   695
	    [nextChar == $%] whileFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   696
		string at:index put:nextChar.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   697
		(index == len) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   698
		    string := string , (String new:len).
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   699
		    len := len * 2
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   700
		].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   701
		index := index + 1.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   702
		nextChar := source next
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   703
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   704
	    (source peek == $}) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   705
		inPrimitive := false
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   706
	    ] ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   707
		string at:index put:nextChar.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   708
		(index == len) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   709
		    string := string , (String new:len).
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   710
		    len := len * 2
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   711
		].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   712
		index := index + 1.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   713
		nextChar := source next
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   714
	    ]
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   715
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   716
	source next.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   717
	tokenValue := string copyTo:(index - 1).
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   718
	tokenType := #Primitive.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   719
	tokenLineNr := tokenLineNr + (tokenValue occurrencesOf:(Character cr)).
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   720
	^ tokenType
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   721
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   722
7ad01559b262 Initial revision
claus
parents:
diff changeset
   723
    "a % alone is a binary operator"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   724
    tokenName := '%'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   725
    tokenType := #BinaryOperator.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   726
    ^ tokenType.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   727
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   728
    self syntaxError:('invalid character: ''' , nextChar asString , '''')
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   729
	    position:tokenPosition to:(tokenPosition + 1).
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   730
    ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
   731
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   732
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   733
7ad01559b262 Initial revision
claus
parents:
diff changeset
   734
nextHash
7ad01559b262 Initial revision
claus
parents:
diff changeset
   735
    |nextChar string|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   736
7ad01559b262 Initial revision
claus
parents:
diff changeset
   737
    nextChar := source nextPeek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   738
    nextChar notNil ifTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   739
	nextChar isLetterOrDigit ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   740
	    string := ''.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   741
	    [nextChar notNil and:[nextChar isLetterOrDigit]] whileTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   742
		string := string , (source nextWord "self nextId").
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   743
		nextChar := source peek.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   744
		(nextChar == $:) ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   745
		    tokenValue := string asSymbol.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   746
		    tokenType := #Symbol.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   747
		    ^ tokenType
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   748
		].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   749
		string := string copyWith:nextChar.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   750
		nextChar := source nextPeek
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   751
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   752
	    tokenValue := string asSymbol.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   753
	    tokenType := #Symbol.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   754
	    ^ tokenType
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   755
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   756
	(nextChar == $( ) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   757
	    source next.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   758
	    tokenType := #HashLeftParen.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   759
	    ^ tokenType
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   760
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   761
	(nextChar == $[ ) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   762
	    "it seems that ST-80 supports Constant ByteArrays as #[...]
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   763
	     (seen in a PD program)"
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   764
	    source next.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   765
	    tokenType := #HashLeftBrack.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   766
	    ^ tokenType
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   767
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   768
	(nextChar == $' ) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   769
	    "it seems that ST-80 supports arbitrary symbols as #'...'
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   770
	     (seen in a PD program)"
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   771
	    self nextString.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   772
	    tokenValue := tokenValue asSymbol.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   773
	    tokenType := #Symbol.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   774
	    ^ tokenType
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   775
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   776
	((TypeArray at:(nextChar asciiValue)) == #special) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   777
	    string := source next asString.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   778
	    nextChar := source peek.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   779
	    nextChar notNil ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   780
		((TypeArray at:(nextChar asciiValue)) == #special) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   781
		    source next.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   782
		    string := string copyWith:nextChar
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   783
		]
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   784
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   785
	    tokenValue := string asSymbol.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   786
	    tokenType := #Symbol.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   787
	    ^ tokenType
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   788
	]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   789
    ].
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   790
    "this allows hash to be used as binop -
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   791
     I dont know, if this is correct ..."
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   792
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   793
    tokenName := '#'.
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   794
    tokenType := #BinaryOperator.
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   795
    ^ tokenType
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   796
"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   797
    self syntaxError:'unexpected end-of-input in Symbol'
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   798
	    position:tokenPosition to:(tokenPosition + 1).
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   799
    ^ #Error
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   800
"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   801
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   802
7ad01559b262 Initial revision
claus
parents:
diff changeset
   803
nextString
7ad01559b262 Initial revision
claus
parents:
diff changeset
   804
    |nextChar string pos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   805
     index "{ Class: SmallInteger }"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   806
     len   "{ Class: SmallInteger }"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   807
     inString|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   808
7ad01559b262 Initial revision
claus
parents:
diff changeset
   809
    string := String new:20.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   810
    len := 20.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   811
    index := 1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   812
    pos := source position.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   813
    source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   814
    nextChar := source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   815
    inString := true.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   816
7ad01559b262 Initial revision
claus
parents:
diff changeset
   817
    [inString] whileTrue:[
45
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   818
	nextChar isNil ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   819
	    self syntaxError:'unexpected end-of-input in String'
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   820
		    position:pos to:(source position - 1).
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   821
	    tokenType := #EOF.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   822
	    ^ tokenType
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   823
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   824
	(nextChar == Character cr) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   825
	    tokenLineNr := tokenLineNr + 1
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   826
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   827
	(nextChar == Character quote) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   828
	    (source peek == Character quote) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   829
		source next
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   830
	    ] ifFalse:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   831
		inString := false
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   832
	    ]
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   833
	].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   834
	inString ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   835
	    string at:index put:nextChar.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   836
	    (index == len) ifTrue:[
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   837
		string := string , (String new:len).
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   838
		len := len * 2
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   839
	    ].
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   840
	    index := index + 1.
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   841
	    nextChar := source next
e8331ba8ad5d *** empty log message ***
claus
parents: 41
diff changeset
   842
	]
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   843
    ].
15
992c3d87edbf *** empty log message ***
claus
parents: 10
diff changeset
   844
    tokenValue := string copyTo:(index - 1).
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   845
    tokenType := #String.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   846
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   847
! !