Scanner.st
author claus
Wed, 13 Oct 1993 01:26:26 +0100
changeset 3 b63b8a6b71fb
parent 0 7ad01559b262
child 4 f6fd83437415
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
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1989-93 by Claus Gittinger
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
7ad01559b262 Initial revision
claus
parents:
diff changeset
    16
                              tokenName tokenLineNr
7ad01559b262 Initial revision
claus
parents:
diff changeset
    17
                              thisChar peekChar
7ad01559b262 Initial revision
claus
parents:
diff changeset
    18
                              requestor exitBlock
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
    19
                              errorFlag
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
    20
			      saveComments currentComments'
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    21
          classVariableNames:'typeArray actionArray'
7ad01559b262 Initial revision
claus
parents:
diff changeset
    22
            poolDictionaries:''
7ad01559b262 Initial revision
claus
parents:
diff changeset
    23
                    category:'System-Compiler'
7ad01559b262 Initial revision
claus
parents:
diff changeset
    24
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    25
7ad01559b262 Initial revision
claus
parents:
diff changeset
    26
Scanner comment:'
7ad01559b262 Initial revision
claus
parents:
diff changeset
    27
7ad01559b262 Initial revision
claus
parents:
diff changeset
    28
COPYRIGHT (c) 1989-93 by Claus Gittinger
7ad01559b262 Initial revision
claus
parents:
diff changeset
    29
             All Rights Reserved
7ad01559b262 Initial revision
claus
parents:
diff changeset
    30
7ad01559b262 Initial revision
claus
parents:
diff changeset
    31
Scanner reads from a stream and returns individual smalltalk tokens
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
    32
$Header: /cvs/stx/stx/libcomp/Scanner.st,v 1.2 1993-10-13 00:26:15 claus Exp $
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    33
'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    34
7ad01559b262 Initial revision
claus
parents:
diff changeset
    35
!Scanner class methodsFor:'instance creation'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    36
7ad01559b262 Initial revision
claus
parents:
diff changeset
    37
for:aStream
7ad01559b262 Initial revision
claus
parents:
diff changeset
    38
    "return a new scanner reading from aStream"
7ad01559b262 Initial revision
claus
parents:
diff changeset
    39
7ad01559b262 Initial revision
claus
parents:
diff changeset
    40
    ^ (super new) initializeFor:aStream
7ad01559b262 Initial revision
claus
parents:
diff changeset
    41
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
    42
7ad01559b262 Initial revision
claus
parents:
diff changeset
    43
!Scanner methodsFor:'private'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    44
7ad01559b262 Initial revision
claus
parents:
diff changeset
    45
initializeFor:aStream
7ad01559b262 Initial revision
claus
parents:
diff changeset
    46
    "initialize -
7ad01559b262 Initial revision
claus
parents:
diff changeset
    47
     if this is the first time, setup character- and action tables"
7ad01559b262 Initial revision
claus
parents:
diff changeset
    48
7ad01559b262 Initial revision
claus
parents:
diff changeset
    49
    |block|
7ad01559b262 Initial revision
claus
parents:
diff changeset
    50
7ad01559b262 Initial revision
claus
parents:
diff changeset
    51
    errorFlag := false.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    52
    tokenLineNr := 1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    53
    source := aStream.
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
    54
    currentComments := nil.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
    55
    saveComments := false.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
    56
7ad01559b262 Initial revision
claus
parents:
diff changeset
    57
    actionArray isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
    58
        actionArray := Array new:256.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    59
        typeArray := Array new:256.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    60
7ad01559b262 Initial revision
claus
parents:
diff changeset
    61
        block := [:s :char | s nextNumber].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    62
        ($0 asciiValue) to:($9 asciiValue) do:[:index |
7ad01559b262 Initial revision
claus
parents:
diff changeset
    63
            actionArray at:index put:block
7ad01559b262 Initial revision
claus
parents:
diff changeset
    64
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    65
7ad01559b262 Initial revision
claus
parents:
diff changeset
    66
        block := [:s :char | s nextIdentifier].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    67
        ($a asciiValue) to:($z asciiValue) do:[:index |
7ad01559b262 Initial revision
claus
parents:
diff changeset
    68
            actionArray at:index put:block
7ad01559b262 Initial revision
claus
parents:
diff changeset
    69
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    70
        ($A asciiValue) to:($Z asciiValue) do:[:index |
7ad01559b262 Initial revision
claus
parents:
diff changeset
    71
            actionArray at:index put:block
7ad01559b262 Initial revision
claus
parents:
diff changeset
    72
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    73
7ad01559b262 Initial revision
claus
parents:
diff changeset
    74
        block := [:s :char | s nextSpecial].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    75
        #( $& $- $+ $= $* $/ $\ $< $> $~ $@ $, $? ) do:[:binop |
7ad01559b262 Initial revision
claus
parents:
diff changeset
    76
            typeArray at:(binop asciiValue) put:#special.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    77
            actionArray at:(binop asciiValue) put:block
7ad01559b262 Initial revision
claus
parents:
diff changeset
    78
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    79
7ad01559b262 Initial revision
claus
parents:
diff changeset
    80
        block := [:s :char | s nextToken:char].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    81
        #( $; $. $( $) $[ $] $!! $^ $| $_ ) do:[:ch |
7ad01559b262 Initial revision
claus
parents:
diff changeset
    82
            actionArray at:(ch asciiValue) put:block
7ad01559b262 Initial revision
claus
parents:
diff changeset
    83
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    84
7ad01559b262 Initial revision
claus
parents:
diff changeset
    85
        "kludge: action is characterToken, but type is special"
7ad01559b262 Initial revision
claus
parents:
diff changeset
    86
        typeArray at:($| asciiValue) put:#special.
7ad01559b262 Initial revision
claus
parents:
diff changeset
    87
7ad01559b262 Initial revision
claus
parents:
diff changeset
    88
        actionArray at:($' asciiValue) put:[:s :char | s nextString].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    89
        actionArray at:($$ asciiValue) put:[:s :char | s nextCharacter].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    90
        actionArray at:($# asciiValue) put:[:s :char | s nextHash].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    91
        actionArray at:($% asciiValue) put:[:s :char | s nextPrimitive].
7ad01559b262 Initial revision
claus
parents:
diff changeset
    92
        actionArray at:($: asciiValue) put:[:s :char | s nextColonOrAssign]
7ad01559b262 Initial revision
claus
parents:
diff changeset
    93
    ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
    94
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
    95
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
    96
initialize
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
    97
    "prepare a scan"
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
    98
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
    99
    errorFlag := false.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   100
    tokenLineNr := 1.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   101
    currentComments := nil.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   102
    saveComments := false.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   103
!
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   104
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   105
notifying:anObject
7ad01559b262 Initial revision
claus
parents:
diff changeset
   106
    "set the requestor to be notified"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   107
7ad01559b262 Initial revision
claus
parents:
diff changeset
   108
    requestor := anObject
7ad01559b262 Initial revision
claus
parents:
diff changeset
   109
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   110
7ad01559b262 Initial revision
claus
parents:
diff changeset
   111
backupPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
   112
    "if reading from a stream, at the end we might have read
7ad01559b262 Initial revision
claus
parents:
diff changeset
   113
     one token too many"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   114
7ad01559b262 Initial revision
claus
parents:
diff changeset
   115
    (tokenType == #EOF) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   116
        source position:tokenPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
   117
    ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   118
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   119
7ad01559b262 Initial revision
claus
parents:
diff changeset
   120
!Scanner methodsFor:'error handling'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   121
7ad01559b262 Initial revision
claus
parents:
diff changeset
   122
showErrorMessage:aMessage position:pos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   123
    "show an errormessage on the Transcript"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   124
7ad01559b262 Initial revision
claus
parents:
diff changeset
   125
    Transcript showCr:(pos printString , ' ' , aMessage)
7ad01559b262 Initial revision
claus
parents:
diff changeset
   126
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   127
7ad01559b262 Initial revision
claus
parents:
diff changeset
   128
notifyError:aMessage position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   129
    "notify requestor of an error - if there is no requestor
7ad01559b262 Initial revision
claus
parents:
diff changeset
   130
     put it on the transcript.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   131
     Return the result passed back by the requestor."
7ad01559b262 Initial revision
claus
parents:
diff changeset
   132
7ad01559b262 Initial revision
claus
parents:
diff changeset
   133
    requestor isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   134
        self showErrorMessage:aMessage position:position.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   135
        ^ false
7ad01559b262 Initial revision
claus
parents:
diff changeset
   136
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   137
    ^ requestor error:aMessage position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   138
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   139
7ad01559b262 Initial revision
claus
parents:
diff changeset
   140
notifyWarning:aMessage position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   141
    "notify requestor of an warning - if there is no requestor
7ad01559b262 Initial revision
claus
parents:
diff changeset
   142
     put it on the transcript.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   143
     Return the result passed back by the requestor."
7ad01559b262 Initial revision
claus
parents:
diff changeset
   144
7ad01559b262 Initial revision
claus
parents:
diff changeset
   145
    requestor isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   146
        self showErrorMessage:aMessage position:position.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   147
        ^ false
7ad01559b262 Initial revision
claus
parents:
diff changeset
   148
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   149
    ^ requestor warning:aMessage position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   150
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   151
7ad01559b262 Initial revision
claus
parents:
diff changeset
   152
syntaxError:aMessage position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   153
    "a syntax error happened"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   154
7ad01559b262 Initial revision
claus
parents:
diff changeset
   155
    self notifyError:(' Error:' , aMessage) position:position to:endPos.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   156
    exitBlock notNil ifTrue:[exitBlock value].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   157
    ^ false
7ad01559b262 Initial revision
claus
parents:
diff changeset
   158
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   159
7ad01559b262 Initial revision
claus
parents:
diff changeset
   160
syntaxError:aMessage position:position
7ad01559b262 Initial revision
claus
parents:
diff changeset
   161
    "a syntax error happened - only start position is known"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   162
7ad01559b262 Initial revision
claus
parents:
diff changeset
   163
    ^ self syntaxError:aMessage position:position to:nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
   164
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   165
7ad01559b262 Initial revision
claus
parents:
diff changeset
   166
syntaxError:aMessage
7ad01559b262 Initial revision
claus
parents:
diff changeset
   167
    "a syntax error happened - position is not known"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   168
7ad01559b262 Initial revision
claus
parents:
diff changeset
   169
    ^ self syntaxError:aMessage position:tokenPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
   170
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   171
7ad01559b262 Initial revision
claus
parents:
diff changeset
   172
warning:aMessage position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   173
    "a warning"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   174
7ad01559b262 Initial revision
claus
parents:
diff changeset
   175
    ^ self notifyWarning:(' Warning:' , aMessage) position:position to:endPos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   176
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   177
7ad01559b262 Initial revision
claus
parents:
diff changeset
   178
warning:aMessage position:position
7ad01559b262 Initial revision
claus
parents:
diff changeset
   179
    "a warning - only start position is known"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   180
7ad01559b262 Initial revision
claus
parents:
diff changeset
   181
    ^ self warning:aMessage position:position to:nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
   182
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   183
7ad01559b262 Initial revision
claus
parents:
diff changeset
   184
warning:aMessage
7ad01559b262 Initial revision
claus
parents:
diff changeset
   185
    "a warning - position is not known"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   186
7ad01559b262 Initial revision
claus
parents:
diff changeset
   187
    ^ self warning:aMessage position:tokenPosition
7ad01559b262 Initial revision
claus
parents:
diff changeset
   188
! !
7ad01559b262 Initial revision
claus
parents:
diff changeset
   189
7ad01559b262 Initial revision
claus
parents:
diff changeset
   190
!Scanner methodsFor:'reading next token'!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   191
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   192
skipComment
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   193
    |comment|
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   194
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   195
    comment := ''.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   196
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   197
    source next.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   198
    thisChar := source peek.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   199
    [thisChar notNil and:[thisChar ~~ (Character doubleQuote)]] whileTrue:[
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   200
        thisChar == (Character cr) ifTrue:[
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   201
            tokenLineNr := tokenLineNr + 1.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   202
        ].
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   203
	saveComments ifTrue:[
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   204
	    comment := comment copyWith:thisChar
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   205
	].
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   206
        source next.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   207
        thisChar := source peek
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   208
    ].
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   209
    saveComments ifTrue:[
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   210
        currentComments isNil ifTrue:[
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   211
	    currentComments := OrderedCollection with:comment
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   212
        ] ifFalse:[
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   213
	    currentComments add:comment
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   214
        ]
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   215
    ].
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   216
    "skip final dQuote"
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   217
    source next.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   218
!
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   219
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   220
nextToken
7ad01559b262 Initial revision
claus
parents:
diff changeset
   221
    "return the next token from the source-stream"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   222
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   223
    |skipping actionBlock comment|
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   224
7ad01559b262 Initial revision
claus
parents:
diff changeset
   225
    peekChar notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   226
        thisChar := peekChar.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   227
        peekChar := nil
7ad01559b262 Initial revision
claus
parents:
diff changeset
   228
    ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   229
        skipping := true.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   230
        [skipping] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   231
            thisChar := source skipSeparatorsExceptCR.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   232
            thisChar == (Character cr) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   233
                tokenLineNr := tokenLineNr + 1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   234
                source next
7ad01559b262 Initial revision
claus
parents:
diff changeset
   235
            ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   236
                thisChar == (Character doubleQuote) ifTrue:[
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   237
		    "start of a comment"
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   238
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   239
		    self skipComment.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   240
                    thisChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   241
                ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   242
                    skipping := false
7ad01559b262 Initial revision
claus
parents:
diff changeset
   243
                ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   244
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   245
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   246
        thisChar isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   247
            tokenType := #EOF.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   248
            ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   249
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   250
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   251
    tokenPosition := source position.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   252
7ad01559b262 Initial revision
claus
parents:
diff changeset
   253
    actionBlock := actionArray at:(thisChar asciiValue).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   254
    actionBlock notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   255
        ^ actionBlock value:self value:thisChar
7ad01559b262 Initial revision
claus
parents:
diff changeset
   256
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   257
7ad01559b262 Initial revision
claus
parents:
diff changeset
   258
    self syntaxError:('invalid character: ''' , thisChar asString , ''' ',
7ad01559b262 Initial revision
claus
parents:
diff changeset
   259
                      '(' , thisChar asciiValue printString , ')')
7ad01559b262 Initial revision
claus
parents:
diff changeset
   260
            position:tokenPosition to:tokenPosition.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   261
    tokenType := #Error.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   262
    ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
   263
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   264
7ad01559b262 Initial revision
claus
parents:
diff changeset
   265
nextToken:aCharacter
7ad01559b262 Initial revision
claus
parents:
diff changeset
   266
    tokenType := aCharacter.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   267
    source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   268
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   269
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   270
7ad01559b262 Initial revision
claus
parents:
diff changeset
   271
nextColonOrAssign
7ad01559b262 Initial revision
claus
parents:
diff changeset
   272
    "colon has been read - look for = to make it an assign"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   273
7ad01559b262 Initial revision
claus
parents:
diff changeset
   274
    (source nextPeek == $=) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   275
        source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   276
        tokenType := $_
7ad01559b262 Initial revision
claus
parents:
diff changeset
   277
    ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   278
        tokenType := $:
7ad01559b262 Initial revision
claus
parents:
diff changeset
   279
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   280
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   281
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   282
    
7ad01559b262 Initial revision
claus
parents:
diff changeset
   283
nextSpecial
7ad01559b262 Initial revision
claus
parents:
diff changeset
   284
    "a special character has been read, look for another one.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   285
     also -number is handled here"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   286
7ad01559b262 Initial revision
claus
parents:
diff changeset
   287
    |firstChar secondChar thirdChar string p|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   288
7ad01559b262 Initial revision
claus
parents:
diff changeset
   289
    firstChar := source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   290
    secondChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   291
    (firstChar == $-) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   292
        secondChar isDigit ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   293
            self nextNumber.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   294
            tokenValue := tokenValue negated.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   295
            ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   296
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   297
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   298
    string := firstChar asString.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   299
    ((typeArray at:(secondChar asciiValue)) == #special) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   300
        (secondChar == $-) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   301
            "special- look if minus belongs to number following"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   302
            p := source position.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   303
            source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   304
            thirdChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   305
            source position:p.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   306
            thirdChar isDigit ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   307
                tokenName := string.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   308
                tokenType := #BinaryOperator.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   309
                ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   310
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   311
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   312
        source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   313
        string := string copyWith:secondChar
7ad01559b262 Initial revision
claus
parents:
diff changeset
   314
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   315
    tokenName := string.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   316
    tokenType := #BinaryOperator.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   317
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   318
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   319
7ad01559b262 Initial revision
claus
parents:
diff changeset
   320
nextCharacter
7ad01559b262 Initial revision
claus
parents:
diff changeset
   321
    "a $ has been read - return a character token"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   322
7ad01559b262 Initial revision
claus
parents:
diff changeset
   323
    |nextChar|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   324
7ad01559b262 Initial revision
claus
parents:
diff changeset
   325
    source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   326
    nextChar := source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   327
    nextChar notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   328
        tokenValue := nextChar.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   329
        tokenType := #Character
7ad01559b262 Initial revision
claus
parents:
diff changeset
   330
    ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   331
        tokenType := #EOF
7ad01559b262 Initial revision
claus
parents:
diff changeset
   332
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   333
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   334
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   335
7ad01559b262 Initial revision
claus
parents:
diff changeset
   336
nextMantissa:radix
7ad01559b262 Initial revision
claus
parents:
diff changeset
   337
    |nextChar value factor|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   338
7ad01559b262 Initial revision
claus
parents:
diff changeset
   339
    value := 0.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   340
    factor := 1.0 / radix.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   341
    nextChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   342
    [(nextChar notNil and:[nextChar isDigitRadix:radix])] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   343
        value := value + (nextChar digitValue * factor).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   344
        factor := factor / radix.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   345
        nextChar := source nextPeek
7ad01559b262 Initial revision
claus
parents:
diff changeset
   346
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   347
    ^ value
7ad01559b262 Initial revision
claus
parents:
diff changeset
   348
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   349
7ad01559b262 Initial revision
claus
parents:
diff changeset
   350
nextNumber
7ad01559b262 Initial revision
claus
parents:
diff changeset
   351
    |nextChar value radix s|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   352
7ad01559b262 Initial revision
claus
parents:
diff changeset
   353
    radix := 10.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   354
    value := Integer readFrom:source radix:radix.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   355
    nextChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   356
    (nextChar == $r) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   357
        radix := value.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   358
        source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   359
        value := Integer readFrom:source radix:radix.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   360
        nextChar := source peek
7ad01559b262 Initial revision
claus
parents:
diff changeset
   361
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   362
    (nextChar == $.) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   363
        nextChar := source nextPeek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   364
        (nextChar notNil and:[nextChar isDigitRadix:radix]) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   365
            value := value asFloat + (self nextMantissa:radix).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   366
            nextChar := source peek
7ad01559b262 Initial revision
claus
parents:
diff changeset
   367
        ] ifFalse:[
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   368
            nextChar == (Character cr) ifTrue:[
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   369
                tokenLineNr := tokenLineNr + 1.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   370
            ].
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   371
            peekChar := $.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   372
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   373
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   374
    (nextChar == $e) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   375
        nextChar := source nextPeek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   376
        (nextChar notNil and:[(nextChar isDigitRadix:radix) or:['+-' includes:nextChar]]) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   377
            s := 1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   378
            (nextChar == $+) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   379
                nextChar := source nextPeek
7ad01559b262 Initial revision
claus
parents:
diff changeset
   380
            ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   381
                (nextChar == $-) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   382
                    nextChar := source nextPeek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   383
                    s := s negated
7ad01559b262 Initial revision
claus
parents:
diff changeset
   384
                ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   385
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   386
            value := value asFloat
7ad01559b262 Initial revision
claus
parents:
diff changeset
   387
                     * (10.0 raisedToInteger:((Integer readFrom:source radix:radix) * s))
7ad01559b262 Initial revision
claus
parents:
diff changeset
   388
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   389
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   390
    tokenValue := value.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   391
    (value isMemberOf:Float) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   392
        tokenType := #Float
7ad01559b262 Initial revision
claus
parents:
diff changeset
   393
    ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   394
        tokenType := #Integer
7ad01559b262 Initial revision
claus
parents:
diff changeset
   395
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   396
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   397
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   398
7ad01559b262 Initial revision
claus
parents:
diff changeset
   399
nextId
7ad01559b262 Initial revision
claus
parents:
diff changeset
   400
    |nextChar string oldString 
7ad01559b262 Initial revision
claus
parents:
diff changeset
   401
     index "{ Class: SmallInteger }"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   402
     max   "{ Class: SmallInteger }" |
7ad01559b262 Initial revision
claus
parents:
diff changeset
   403
7ad01559b262 Initial revision
claus
parents:
diff changeset
   404
    nextChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   405
    string := String new:10.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   406
    index := 0.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   407
    max := 10.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   408
    [true] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   409
        (nextChar notNil and:[nextChar isAlphaNumeric]) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   410
            ^ string copyFrom:1 to:index
7ad01559b262 Initial revision
claus
parents:
diff changeset
   411
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   412
        (index == max) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   413
            oldString := string.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   414
            string := String new:(max * 2).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   415
            string replaceFrom:1 to:max with:oldString.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   416
            max := max * 2
7ad01559b262 Initial revision
claus
parents:
diff changeset
   417
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   418
        index := index + 1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   419
        string at:index put:nextChar.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   420
        nextChar := source nextPeek
7ad01559b262 Initial revision
claus
parents:
diff changeset
   421
    ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   422
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   423
7ad01559b262 Initial revision
claus
parents:
diff changeset
   424
nextIdentifier
7ad01559b262 Initial revision
claus
parents:
diff changeset
   425
    |nextChar string firstChar|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   426
7ad01559b262 Initial revision
claus
parents:
diff changeset
   427
    string := source nextWord "self nextId".
7ad01559b262 Initial revision
claus
parents:
diff changeset
   428
    nextChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   429
    (nextChar == $:) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   430
        source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   431
        (source peek == $=) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   432
            tokenName := string copyWith:nextChar.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   433
            tokenType := #Keyword.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   434
            ^ self
7ad01559b262 Initial revision
claus
parents:
diff changeset
   435
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   436
        peekChar := $_
7ad01559b262 Initial revision
claus
parents:
diff changeset
   437
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   438
    firstChar := string at:1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   439
    (firstChar == $s) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   440
        (string = 'self') ifTrue:[tokenType := #Self. ^self].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   441
        (string = 'super') ifTrue:[tokenType := #Super. ^self]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   442
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   443
    (firstChar == $n) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   444
        (string = 'nil') ifTrue:[tokenType := #Nil. ^self]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   445
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   446
    (firstChar == $t) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   447
        (string = 'true') ifTrue:[tokenType := #True. ^self].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   448
        (string = 'thisContext') ifTrue:[tokenType := #ThisContext. ^self]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   449
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   450
    (firstChar == $f) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   451
        (string = 'false') ifTrue:[tokenType := #False. ^self]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   452
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   453
    tokenName := string.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   454
    tokenType := #Identifier.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   455
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   456
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   457
7ad01559b262 Initial revision
claus
parents:
diff changeset
   458
nextPrimitive
7ad01559b262 Initial revision
claus
parents:
diff changeset
   459
    |nextChar inPrimitive string 
7ad01559b262 Initial revision
claus
parents:
diff changeset
   460
     index "{ Class: SmallInteger }"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   461
     len   "{ Class: SmallInteger }" |
7ad01559b262 Initial revision
claus
parents:
diff changeset
   462
7ad01559b262 Initial revision
claus
parents:
diff changeset
   463
    nextChar := source nextPeek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   464
    string := String new:500.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   465
    len := 500.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   466
    index := 1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   467
    (nextChar == ${) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   468
        nextChar := source nextPeek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   469
        inPrimitive := true.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   470
        [inPrimitive] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   471
            [nextChar == $%] whileFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   472
                string at:index put:nextChar.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   473
                (index == len) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   474
                    string := string , (String new:len).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   475
                    len := len * 2
7ad01559b262 Initial revision
claus
parents:
diff changeset
   476
                ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   477
                index := index + 1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   478
                nextChar := source next
7ad01559b262 Initial revision
claus
parents:
diff changeset
   479
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   480
            (source peek == $}) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   481
                inPrimitive := false
7ad01559b262 Initial revision
claus
parents:
diff changeset
   482
            ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   483
                string at:index put:nextChar.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   484
                (index == len) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   485
                    string := string , (String new:len).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   486
                    len := len * 2
7ad01559b262 Initial revision
claus
parents:
diff changeset
   487
                ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   488
                index := index + 1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   489
                nextChar := source next
7ad01559b262 Initial revision
claus
parents:
diff changeset
   490
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   491
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   492
        source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   493
        tokenValue := string copyFrom:1 to:(index - 1).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   494
        tokenType := #Primitive.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   495
        tokenLineNr := tokenLineNr + (tokenValue occurrencesOf:(Character cr)).
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
    "a % alone is a binary operator"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   500
    tokenName := '%'.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   501
    tokenType := #BinaryOperator.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   502
    ^ tokenType.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   503
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   504
    self syntaxError:('invalid character: ''' , nextChar asString , '''')
7ad01559b262 Initial revision
claus
parents:
diff changeset
   505
            position:tokenPosition to:(tokenPosition + 1).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   506
    ^ #Error
7ad01559b262 Initial revision
claus
parents:
diff changeset
   507
"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   508
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   509
7ad01559b262 Initial revision
claus
parents:
diff changeset
   510
nextHash
7ad01559b262 Initial revision
claus
parents:
diff changeset
   511
    |nextChar string|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   512
7ad01559b262 Initial revision
claus
parents:
diff changeset
   513
    nextChar := source nextPeek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   514
    nextChar notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   515
        nextChar isAlphaNumeric ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   516
            string := ''.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   517
            [nextChar notNil and:[nextChar isAlphaNumeric]] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   518
                string := string , (source nextWord "self nextId").
7ad01559b262 Initial revision
claus
parents:
diff changeset
   519
                nextChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   520
                (nextChar == $:) ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   521
                    tokenValue := string asSymbol.
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   522
            	    tokenType := #Symbol.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   523
                    ^ tokenType
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   524
                ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   525
                string := string copyWith:nextChar.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   526
                nextChar := source nextPeek
7ad01559b262 Initial revision
claus
parents:
diff changeset
   527
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   528
            tokenValue := string asSymbol.
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   529
            tokenType := #Symbol.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   530
            ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   531
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   532
        (nextChar == $( ) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   533
            source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   534
            tokenType := #HashLeftParen.
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
        (nextChar == $[ ) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   538
            "it seems that ST-80 supports Constant ByteArrays as #[...]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   539
             (seen in a PD program)"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   540
            source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   541
            tokenType := #HashLeftBrack.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   542
            ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   543
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   544
        (nextChar == $' ) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   545
            "it seems that ST-80 supports arbitrary symbols as #'...'
7ad01559b262 Initial revision
claus
parents:
diff changeset
   546
             (seen in a PD program)"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   547
            self nextString.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   548
            tokenValue := tokenValue asSymbol.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   549
            tokenType := #Symbol.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   550
            ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   551
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   552
        ((typeArray at:(nextChar asciiValue)) == #special) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   553
            string := source next asString.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   554
            nextChar := source peek.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   555
            nextChar notNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   556
                ((typeArray at:(nextChar asciiValue)) == #special) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   557
                    source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   558
                    string := string copyWith:nextChar
7ad01559b262 Initial revision
claus
parents:
diff changeset
   559
                ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   560
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   561
            tokenValue := string asSymbol.
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   562
            tokenType := #Symbol.
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   563
            ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   564
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   565
    ].
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   566
    "this allows hash to be used as binop -
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   567
     I dont know, if this is correct ..."
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   568
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   569
    tokenName := '#'.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   570
    tokenType := BinaryOperator.
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   571
    ^ tokenType
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   572
"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   573
    self syntaxError:'unexpected end-of-input in Symbol'
7ad01559b262 Initial revision
claus
parents:
diff changeset
   574
            position:tokenPosition to:(tokenPosition + 1).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   575
    ^ #Error
3
b63b8a6b71fb *** empty log message ***
claus
parents: 0
diff changeset
   576
"
0
7ad01559b262 Initial revision
claus
parents:
diff changeset
   577
!
7ad01559b262 Initial revision
claus
parents:
diff changeset
   578
7ad01559b262 Initial revision
claus
parents:
diff changeset
   579
nextString
7ad01559b262 Initial revision
claus
parents:
diff changeset
   580
    |nextChar string pos
7ad01559b262 Initial revision
claus
parents:
diff changeset
   581
     index "{ Class: SmallInteger }"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   582
     len   "{ Class: SmallInteger }"
7ad01559b262 Initial revision
claus
parents:
diff changeset
   583
     inString|
7ad01559b262 Initial revision
claus
parents:
diff changeset
   584
7ad01559b262 Initial revision
claus
parents:
diff changeset
   585
    string := String new:20.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   586
    len := 20.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   587
    index := 1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   588
    pos := source position.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   589
    source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   590
    nextChar := source next.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   591
    inString := true.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   592
7ad01559b262 Initial revision
claus
parents:
diff changeset
   593
    [inString] whileTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   594
        nextChar isNil ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   595
            self syntaxError:'unexpected end-of-input in String'
7ad01559b262 Initial revision
claus
parents:
diff changeset
   596
                    position:pos to:(source position - 1).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   597
            tokenType := #EOF.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   598
            ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   599
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   600
        (nextChar == Character cr) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   601
            tokenLineNr := tokenLineNr + 1
7ad01559b262 Initial revision
claus
parents:
diff changeset
   602
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   603
        (nextChar == Character quote) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   604
            (source peek == Character quote) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   605
                source next
7ad01559b262 Initial revision
claus
parents:
diff changeset
   606
            ] ifFalse:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   607
                inString := false
7ad01559b262 Initial revision
claus
parents:
diff changeset
   608
            ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   609
        ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   610
        inString ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   611
            string at:index put:nextChar.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   612
            (index == len) ifTrue:[
7ad01559b262 Initial revision
claus
parents:
diff changeset
   613
                string := string , (String new:len).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   614
                len := len * 2
7ad01559b262 Initial revision
claus
parents:
diff changeset
   615
            ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   616
            index := index + 1.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   617
            nextChar := source next
7ad01559b262 Initial revision
claus
parents:
diff changeset
   618
        ]
7ad01559b262 Initial revision
claus
parents:
diff changeset
   619
    ].
7ad01559b262 Initial revision
claus
parents:
diff changeset
   620
    tokenValue := string copyFrom:1 to:(index - 1).
7ad01559b262 Initial revision
claus
parents:
diff changeset
   621
    tokenType := #String.
7ad01559b262 Initial revision
claus
parents:
diff changeset
   622
    ^ tokenType
7ad01559b262 Initial revision
claus
parents:
diff changeset
   623
! !