Merged with PetitCompiler-JanKurs.20150510144201, PetitCompiler-Tests-JanKurs.20150510144201, PetitCompiler-Extras-Tests-JanKurs.20150510144201, PetitCompiler-Benchmarks-JanKurs.20150510144201
Name: PetitCompiler-JanKurs.20150510144201
Author: JanKurs
Time: 10-05-2015, 04:42:29.192 PM
UUID: 58a4786b-1182-4904-8b44-a13d3918f244
Name: PetitCompiler-Tests-JanKurs.20150510144201
Author: JanKurs
Time: 10-05-2015, 04:32:12.870 PM
UUID: 2a8fd41a-331b-4dcf-a7a3-752a50ce86e7
Name: PetitCompiler-Extras-Tests-JanKurs.20150510144201
Author: JanKurs
Time: 10-05-2015, 04:59:25.308 PM
UUID: ef43bd1a-be60-4e88-b749-8b635622c969
Name: PetitCompiler-Benchmarks-JanKurs.20150510144201
Author: JanKurs
Time: 10-05-2015, 05:04:54.561 PM
UUID: d8e764fd-016b-46e2-9fc1-17c38c18f0e5
"{ Package: 'stx:goodies/petitparser/compiler' }"
"{ NameSpace: Smalltalk }"
PPCRewritingVisitor subclass:#PPCTokenizingVisitor
instanceVariableNames:'tokens'
classVariableNames:''
poolDictionaries:''
category:'PetitCompiler-Visitors'
!
!PPCTokenizingVisitor methodsFor:'hooks'!
afterAccept: node retval: parserNode
self isRoot ifTrue: [
| tokenizerNode whitespaceNode |
self change.
tokens addLast: self eofToken.
tokens do: [ :token | token unmarkForInline ].
whitespaceNode := tokens detect: [ :e | e isTrimmingTokenNode ] ifFound: [:token |
token whitespace copy
unmarkForInline;
name: 'consumeWhitespace';
yourself
] ifNone: [
PPCNilNode new
name: 'consumeWhitespace';
yourself
].
tokenizerNode := PPCTokenChoiceNode new
children: tokens asArray;
name: 'nextToken';
yourself.
^ PPCTokenizingParserNode new
parser: parserNode;
tokenizer: tokenizerNode;
whitespace: whitespaceNode;
name: #'mainParser';
yourself
].
^ parserNode
!
eofToken
| ws |
ws := PPCStarNode new
child: (PPCMessagePredicateNode new
message: #isSeparator;
yourself);
yourself.
^ PPCTrimmingTokenNode new
child: PPCEndOfFileNode new;
whitespace: ws;
tokenClass: PPToken;
yourself.
! !
!PPCTokenizingVisitor methodsFor:'initialization'!
initialize
super initialize.
tokens := OrderedCollection new.
! !
!PPCTokenizingVisitor methodsFor:'testing'!
isRoot
^ openSet size = 1
! !
!PPCTokenizingVisitor methodsFor:'tokens'!
addToken: token
(tokens contains: [:e | e == token] ) ifFalse: [
tokens addLast: token
]
! !
!PPCTokenizingVisitor methodsFor:'visiting'!
visitActionNode: node
(node hasProperty: #trimmingToken) ifTrue: [
self change.
self addToken: node.
^ PPCTokenConsumeNode new
child: node;
yourself
].
^ super visitActionNode: node
!
visitTokenNode: node
self change.
self addToken: node.
^ PPCTokenConsumeNode new
child: node;
yourself.
!
visitTrimmingTokenNode: node
self change.
self addToken: node.
^ PPCTokenConsumeNode new
child: node;
yourself.
! !