1
|
1 |
"{ Package: 'stx:goodies/smaCC' }"
|
|
2 |
|
|
3 |
"{ NameSpace: SmaCC }"
|
|
4 |
|
|
5 |
SmaCCRegularExpressionNode subclass:#SmaCCCharacterRENode
|
|
6 |
instanceVariableNames:'characters'
|
|
7 |
classVariableNames:''
|
|
8 |
poolDictionaries:''
|
|
9 |
category:'SmaCC-Scanner Generator'
|
|
10 |
!
|
|
11 |
|
|
12 |
SmaCCCharacterRENode comment:'SmaCCCharacterRENode represents a regular expression that matches one of a set of characters.
|
|
13 |
|
|
14 |
Instance Variables:
|
|
15 |
characters <SortedCollection of: Character> The characters that this node can accept. Note that there are no duplicates and all characters are sorted.
|
|
16 |
|
|
17 |
'
|
|
18 |
!
|
|
19 |
|
|
20 |
|
|
21 |
!SmaCCCharacterRENode class methodsFor:'instance creation'!
|
|
22 |
|
|
23 |
characters: aString
|
|
24 |
^(self new)
|
|
25 |
characters: (self sortedCharactersFor: aString);
|
|
26 |
yourself
|
|
27 |
! !
|
|
28 |
|
|
29 |
!SmaCCCharacterRENode class methodsFor:'private'!
|
|
30 |
|
|
31 |
sortedCharactersFor: aString
|
|
32 |
| characters stream |
|
|
33 |
SmaCCGrammar ignoreCase
|
|
34 |
ifTrue:
|
|
35 |
[stream := WriteStream on: UnicodeString new.
|
|
36 |
aString do:
|
|
37 |
[:each |
|
|
38 |
stream
|
|
39 |
nextPut: each asUppercase;
|
|
40 |
nextPut: each asLowercase]]
|
|
41 |
ifFalse:
|
|
42 |
[stream := WriteStream on: (UnicodeString new: aString size).
|
|
43 |
stream nextPutAll: aString].
|
|
44 |
characters := stream contents
|
|
45 |
asSortedCollection: [:a :b | a asInteger < b asInteger].
|
|
46 |
stream := WriteStream on: UnicodeString new.
|
|
47 |
characters inject: nil
|
|
48 |
into:
|
|
49 |
[:sum :each |
|
|
50 |
sum = each ifFalse: [stream nextPut: each].
|
|
51 |
each].
|
|
52 |
^stream contents
|
|
53 |
|
|
54 |
"Modified: / 26-05-2006 / 22:17:33 / janfrog"
|
|
55 |
! !
|
|
56 |
|
|
57 |
!SmaCCCharacterRENode methodsFor:'accessing'!
|
|
58 |
|
|
59 |
possibleMatchesSize
|
|
60 |
^self matchingCharacters size
|
|
61 |
!
|
|
62 |
|
|
63 |
| aScannerNode
|
|
64 |
(self canMergeWith: aScannerNode) ifFalse: [^super | aScannerNode].
|
|
65 |
characters := String
|
|
66 |
withAll: ((characters , aScannerNode characters) asSet
|
|
67 |
asSortedCollection: [:a :b | a asInteger < b asInteger]).
|
|
68 |
^self
|
|
69 |
! !
|
|
70 |
|
|
71 |
!SmaCCCharacterRENode methodsFor:'initialize-release'!
|
|
72 |
|
|
73 |
characters: aString
|
|
74 |
characters := aString
|
|
75 |
! !
|
|
76 |
|
|
77 |
!SmaCCCharacterRENode methodsFor:'printing'!
|
|
78 |
|
|
79 |
printCharacter: aCharacter on: aStream
|
|
80 |
(aCharacter asInteger between: 32 and: 126) ifTrue: [^aStream nextPut: aCharacter].
|
|
81 |
aStream nextPutAll: '\x'.
|
|
82 |
aCharacter asInteger
|
|
83 |
printOn: aStream
|
|
84 |
base: 16
|
|
85 |
showRadix: false
|
|
86 |
!
|
|
87 |
|
|
88 |
printOn: aStream
|
|
89 |
| allCharacters |
|
|
90 |
characters size = 1
|
|
91 |
ifTrue: [^self printCharacter: characters first on: aStream].
|
|
92 |
aStream nextPut: $[.
|
|
93 |
allCharacters := characters.
|
|
94 |
characters size > 128
|
|
95 |
ifTrue:
|
|
96 |
[aStream nextPut: $^.
|
|
97 |
allCharacters := ((0 to: SmaCCGrammar maximumCharacterValue)
|
|
98 |
collect: [:each | Character value: each])
|
|
99 |
reject: [:each | characters includes: each]].
|
|
100 |
allCharacters do: [:each | self printCharacter: each on: aStream].
|
|
101 |
aStream nextPut: $]
|
|
102 |
! !
|
|
103 |
|
|
104 |
!SmaCCCharacterRENode methodsFor:'private'!
|
|
105 |
|
|
106 |
asNFAStartingWith: startNode
|
|
107 |
| endNode |
|
|
108 |
endNode := SmaCCNode new.
|
|
109 |
endNode action: action.
|
|
110 |
startNode addEdgeTo: endNode on: characters.
|
|
111 |
^endNode
|
|
112 |
!
|
|
113 |
|
|
114 |
characters
|
|
115 |
^characters
|
|
116 |
!
|
|
117 |
|
|
118 |
matchingCharacters
|
|
119 |
^SmaCCGrammar ignoreCase
|
|
120 |
ifTrue: [characters reject: [:each | each isLowercase]]
|
|
121 |
ifFalse: [characters]
|
|
122 |
!
|
|
123 |
|
|
124 |
possibleMatchesDo: aBlock on: aStream
|
|
125 |
self matchingCharacters do:
|
|
126 |
[:each |
|
|
127 |
aStream nextPut: each.
|
|
128 |
aBlock value.
|
|
129 |
aStream skip: -1]
|
|
130 |
! !
|
|
131 |
|
|
132 |
!SmaCCCharacterRENode methodsFor:'public'!
|
|
133 |
|
|
134 |
canMergeWith: aScannerNode
|
|
135 |
^self class = aScannerNode class and:
|
|
136 |
[characters notNil
|
|
137 |
and: [aScannerNode characters notNil and: [self action = aScannerNode action]]]
|
|
138 |
! !
|
|
139 |
|
|
140 |
!SmaCCCharacterRENode class methodsFor:'documentation'!
|
|
141 |
|
|
142 |
version
|
|
143 |
^ '$Header: /opt/data/cvs/stx/goodies/smaCC/SmaCC__SmaCCCharacterRENode.st,v 1.2 2006-05-28 20:10:18 vranyj1 Exp $'
|
15
|
144 |
!
|
|
145 |
|
|
146 |
version_SVN
|
|
147 |
^ '$Id$'
|
1
|
148 |
! !
|