2021-10-29 05:00:30 +02:00
|
|
|
package prog8tests.ast
|
2021-10-21 22:06:21 +02:00
|
|
|
|
2021-11-07 17:25:53 +01:00
|
|
|
import io.kotest.core.spec.style.AnnotationSpec
|
2021-11-07 21:18:18 +01:00
|
|
|
import io.kotest.matchers.shouldBe
|
2021-10-21 22:06:21 +02:00
|
|
|
import prog8.ast.statements.Block
|
|
|
|
import prog8.ast.statements.Subroutine
|
2022-03-10 22:38:16 +01:00
|
|
|
import prog8.code.core.DataType
|
2021-10-21 22:06:21 +02:00
|
|
|
import prog8.parser.Prog8Parser.parseModule
|
2022-03-21 01:01:21 +01:00
|
|
|
import prog8.code.core.SourceCode
|
2021-10-21 22:06:21 +02:00
|
|
|
|
|
|
|
|
2021-11-07 17:25:53 +01:00
|
|
|
class TestSubroutines: AnnotationSpec() {
|
2021-10-21 22:06:21 +02:00
|
|
|
|
|
|
|
@Test
|
|
|
|
fun stringParameterAcceptedInParser() {
|
|
|
|
// note: the *parser* should accept this as it is valid *syntax*,
|
|
|
|
// however, the compiler itself may or may not complain about it later.
|
|
|
|
val text = """
|
|
|
|
main {
|
|
|
|
asmsub asmfunc(str thing @AY) {
|
|
|
|
}
|
|
|
|
|
|
|
|
sub func(str thing) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
val src = SourceCode.Text(text)
|
|
|
|
val module = parseModule(src)
|
|
|
|
val mainBlock = module.statements.single() as Block
|
|
|
|
val asmfunc = mainBlock.statements.filterIsInstance<Subroutine>().single { it.name=="asmfunc"}
|
|
|
|
val func = mainBlock.statements.filterIsInstance<Subroutine>().single { it.name=="func"}
|
2021-11-07 21:18:18 +01:00
|
|
|
asmfunc.isAsmSubroutine shouldBe true
|
|
|
|
asmfunc.parameters.single().type shouldBe DataType.STR
|
|
|
|
asmfunc.statements.isEmpty() shouldBe true
|
|
|
|
func.isAsmSubroutine shouldBe false
|
|
|
|
func.parameters.single().type shouldBe DataType.STR
|
|
|
|
func.statements.isEmpty() shouldBe true
|
2021-10-21 22:06:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
fun arrayParameterAcceptedInParser() {
|
|
|
|
// note: the *parser* should accept this as it is valid *syntax*,
|
|
|
|
// however, the compiler itself may or may not complain about it later.
|
|
|
|
val text = """
|
|
|
|
main {
|
|
|
|
asmsub asmfunc(ubyte[] thing @AY) {
|
|
|
|
}
|
|
|
|
|
|
|
|
sub func(ubyte[22] thing) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
"""
|
|
|
|
val src = SourceCode.Text(text)
|
|
|
|
val module = parseModule(src)
|
|
|
|
val mainBlock = module.statements.single() as Block
|
|
|
|
val asmfunc = mainBlock.statements.filterIsInstance<Subroutine>().single { it.name=="asmfunc"}
|
|
|
|
val func = mainBlock.statements.filterIsInstance<Subroutine>().single { it.name=="func"}
|
2021-11-07 21:18:18 +01:00
|
|
|
asmfunc.isAsmSubroutine shouldBe true
|
|
|
|
asmfunc.parameters.single().type shouldBe DataType.ARRAY_UB
|
|
|
|
asmfunc.statements.isEmpty() shouldBe true
|
|
|
|
func.isAsmSubroutine shouldBe false
|
|
|
|
func.parameters.single().type shouldBe DataType.ARRAY_UB
|
|
|
|
func.statements.isEmpty() shouldBe true
|
2021-10-21 22:06:21 +02:00
|
|
|
}
|
|
|
|
}
|