Updated to PetitCompiler-JanKurs.111, PetitCompiler-Tests-JanKurs.51, PetitCompiler-Benchmarks-JanKurs.7, added PetitCompiler-Extras-Tests-JanKurs.4
Name: PetitCompiler-JanKurs.111
Author: JanKurs
Time: 08-05-2015, 05:56:05.327 PM
UUID: 8805e696-9933-49b8-a5c8-a963b931b996
Name: PetitCompiler-Tests-JanKurs.51
Author: JanKurs
Time: 08-05-2015, 05:17:44.224 PM
UUID: 21c24114-73be-4ba2-86cd-5a4402f778a0
Name: PetitCompiler-Benchmarks-JanKurs.7
Author: JanKurs
Time: 07-05-2015, 06:06:12.918 PM
UUID: 0e6e2c0a-90f6-4f46-9663-c66f636da602
Name: PetitCompiler-Extras-Tests-JanKurs.4
Author: JanKurs
Time: 08-05-2015, 05:56:46.180 PM
UUID: 4d4d4d23-c5bc-41ef-ad41-8a56528ddb42
"{ Package: 'stx:goodies/petitparser/compiler' }"
"{ NameSpace: Smalltalk }"
PPCRewritingVisitor subclass:#PPCLL1Visitor
instanceVariableNames:''
classVariableNames:''
poolDictionaries:''
category:'PetitCompiler-Visitors'
!
!PPCLL1Visitor methodsFor:'as yet unclassified'!
isDeterministicChoice: node
| firsts |
firsts := OrderedCollection new.
node children do: [ :child |
(self startsWithToken: child) ifFalse: [ ^ false ].
firsts addAll: child firstSetWithTokens.
].
(firsts asIdentitySet size = firsts size) ifFalse: [ ^ false ].
firsts allPairsDo: [ :e1 :e2 |
e1 == e2 ifFalse: [
(e1 overlapsWith: e2) ifTrue: [ ^ false ] ].
].
^ true
!
startsWithToken: node
| firstSet terminal total |
total := 0.
firstSet := node firstSetWithTokens.
terminal := (firstSet detect: [ :e | e isTerminal ] ifNone: [ nil ]).
terminal isNil ifFalse: [ ^ false ].
^ true
!
visitChoiceNode: node
super visitChoiceNode: node.
(self isDeterministicChoice: node) ifTrue: [
self change.
^ PPCDeterministicChoiceNode new
children: node children;
name: node name;
firstFollowCache: node firstFollowCache;
yourself
].
^ node
! !