compiler/PEGFsaEpsilonTransition.st
author Jan Vrany <jan.vrany@labware.com>
Wed, 10 Jun 2020 21:33:27 +0100
changeset 650 4c6ed0a28d18
parent 515 b5316ef15274
permissions -rw-r--r--
Replace `ifNil:[...]` with `isNil ifTrue:[...]` The latter is optimized by compilers and therefore faster.

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

"{ NameSpace: Smalltalk }"

PEGFsaTransition subclass:#PEGFsaEpsilonTransition
	instanceVariableNames:''
	classVariableNames:''
	poolDictionaries:''
	category:'PetitCompiler-FSA'
!

!PEGFsaEpsilonTransition methodsFor:'gt'!

gtName
    | gtName |
    gtName := '<eps>'.
    priority < 0 ifTrue: [ gtName := gtName, ',', priority asString ].
    ^ gtName
! !

!PEGFsaEpsilonTransition methodsFor:'modifications'!

decreasePriorityBy: value
    "
        My value has special semantics, when I have negative priority, all the reachable states and transitions should
        be decreased by that value.
        
        In case I am preceded by another epsilon with negative priority, I do not decrease my value, that would multiply
        the the negative priority effect....
    "
    ^ self
! !

!PEGFsaEpsilonTransition methodsFor:'set operations'!

intersection: anotherState
    ^ anotherState
! !

!PEGFsaEpsilonTransition methodsFor:'testing'!

isEpsilon
    ^ true
!

isEpsilonTransition
    ^ true
! !