compiler/PPCMergingVisitor.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Mon, 18 Jan 2016 08:05:03 +0000
changeset 555 4aa0496e6c22
parent 452 9f4558b3be66
permissions -rw-r--r--
For tests on Pharo 5.0, use Spur VM

"{ 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
! !