Skip to content

Commit

Permalink
Merge pull request #471 from smeup/bugfix/NW23001440/reset-inline-dec…
Browse files Browse the repository at this point in the history
…laration

Bugfix/nw23001440/reset inline declaration
  • Loading branch information
lanarimarco authored Mar 20, 2024
2 parents da712af + c6f2e95 commit 0d8c161
Show file tree
Hide file tree
Showing 4 changed files with 42 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -2029,22 +2029,27 @@ data class XlateStmt(
@Serializable
data class ResetStmt(
val name: String,
@Derived val dataDefinition: InStatementDataDefinition? = null,
override val position: Position? = null
) : Statement(position) {
) : Statement(position), StatementThatCanDefineData {

override fun execute(interpreter: InterpreterCore) {
val dataDefinition = interpreter.dataDefinitionByName(name)
require(dataDefinition != null) {
this.error("Data definition $name not found")
}
require(dataDefinition is DataDefinition) {
this.error("Data definition $name is not an instance of DataDefinition")
}
require(dataDefinition.defaultValue != null) {
this.error("Data definition $name has no default value")
when (val dataDefinition = interpreter.dataDefinitionByName(name)) {
null -> this.error("Data definition $name not found")
is DataDefinition -> {
require(dataDefinition.defaultValue != null) {
this.error("Data definition $name has no default value")
}
interpreter.assign(dataDefinition, dataDefinition.defaultValue!!)
}
is InStatementDataDefinition -> {
interpreter.assign(dataDefinition, dataDefinition.type.blank())
}
else -> this.error("Data definition $name is not a valid instance of DataDefinition")
}
interpreter.assign(dataDefinition, dataDefinition.defaultValue!!)
}

override fun dataDefinition(): List<InStatementDataDefinition> = dataDefinition?.let { listOf(it) } ?: emptyList()
}

@Serializable
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1956,6 +1956,7 @@ internal fun CsCLOSEContext.toAst(conf: ToAstConfiguration = ToAstConfiguration(

internal fun CsRESETContext.toAst(conf: ToAstConfiguration = ToAstConfiguration()): Statement {
val position = toPosition(conf.considerPosition)

require(this.cspec_fixed_standard_parts().factor().text.isEmptyTrim()) {
"RESET operation does not support factor1"
}
Expand All @@ -1966,8 +1967,12 @@ internal fun CsRESETContext.toAst(conf: ToAstConfiguration = ToAstConfiguration(
require(!result.isEmptyTrim()) {
"RESET operation requires result"
}

val dataDefinition = this.cspec_fixed_standard_parts().toDataDefinition(result, position, conf)

return ResetStmt(
name = result,
dataDefinition = dataDefinition,
position = position
)
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,16 @@
package com.smeup.rpgparser.smeup

open class MULANGT40ArrayAndDSTest : MULANGTTest()
import org.junit.Test
import kotlin.test.assertEquals

open class MULANGT40ArrayAndDSTest : MULANGTTest() {
/**
* Reset with inline declaration
* @see #242
*/
@Test
fun executeT40_A10_P10() {
val expected = listOf("Contenuto Pre-RESET: AAA - Contenuto Post-RESET:")
assertEquals(expected, "smeup/T40_A10_P10".outputOf(configuration = smeupConfig))
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
D £DBG_Str S 150 VARYING
C EVAL A10_D1='AAA'
C EVAL £DBG_Str='Contenuto Pre-RESET: '+A10_D1
C RESET A10_D1 10
C EVAL £DBG_Str=%TRIMR(£DBG_Str)
C +' - Contenuto Post-RESET: '+A10_D1
C £DBG_Str DSPLY

0 comments on commit 0d8c161

Please sign in to comment.