compiler/PPCMergingVisitor.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Mon, 17 Aug 2015 23:11:56 +0100
changeset 518 a6d8b93441b0
parent 452 9f4558b3be66
permissions -rw-r--r--
Portability fixes * do not use Object>>asString. Not all Smalltalks implement it. * do not use Object>>name. Not all Smalltalks implement it. * do not use Dictionary keysAndValuesRemove:. Not all Smalltalks implement it. * do not use Class>>methods The semantics is different among Smalltalks. Use `Class methodDictionary values` instead. * do not modify dictionary in #at:ifAbsentPut: block!

"{ Package: 'stx:goodies/petitparser/compiler' }"

"{ NameSpace: Smalltalk }"

PPCRewritingVisitor subclass:#PPCMergingVisitor
	instanceVariableNames:'nodeSet'
	classVariableNames:''
	poolDictionaries:''
	category:'PetitCompiler-Visitors'
!

!PPCMergingVisitor methodsFor:'as yet unclassified'!

equivalentNode: node
    ^  nodeSet detect: [ :e | e = node ]
!

hasEquivalentNode: node
    ^ nodeSet includes: node
!

initialize
    super initialize.
    
    nodeSet := Set new
!

store: node
    self assert: (self hasEquivalentNode: node) not.
    nodeSet add: node
!

visitNode: node
    super visitNode: node.
    
    (self hasEquivalentNode: node) ifTrue: [
        self change.
        ^ self equivalentNode: node
    ] ifFalse: [  
        self store: node
    ].

    ^ node
! !