parsers/java/PJSimpleNameNode.st
author Jan Vrany <jan.vrany@fit.cvut.cz>
Tue, 16 Jun 2015 06:45:26 +0100
changeset 489 0ca7a70db0f5
parent 436 e1c44b571db9
permissions -rw-r--r--
Fix in codegen for inlined sequence nodes. For inlined sequence nodes, generate nested ifs rather than sequential code which does not work when inlined. The reason is that #codeReturn: in inline generates instvar assignment, not method return, so in sequential code the next child of a sequence will be probed even if previous failed. If that happends, the whole sequence fail and therefore we must generate nested ifs to correctly handle this w.r.t. inlining.

"{ Package: 'stx:goodies/petitparser/parsers/java' }"

"{ NameSpace: Smalltalk }"

PJNameNode subclass:#PJSimpleNameNode
	instanceVariableNames:'isDeclaration identifier'
	classVariableNames:''
	poolDictionaries:''
	category:'PetitJava-AST'
!

!PJSimpleNameNode class methodsFor:'instance creation'!

identifier: aString 
	
	^(self new) identifier: aString; yourself
! !

!PJSimpleNameNode methodsFor:'accessing'!

fullyQualifiedName
	^ self identifier value
!

identifier
	^ identifier
!

identifier: anObject
	identifier := anObject
!

isDeclaration
	^ isDeclaration
!

isDeclaration: anObject
	isDeclaration := anObject
! !