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