about summary refs log tree commit diff
path: root/pkg/lang/compiler/compiler_test.go
diff options
context:
space:
mode:
authorMel <einebeere@gmail.com>2022-07-05 22:15:29 +0200
committerMel <einebeere@gmail.com>2022-07-05 22:15:29 +0200
commitb09fce67753e199d4ae0fe6138f909b5e3413208 (patch)
treee2010cc61b2614b43556a738eae38053ef8be345 /pkg/lang/compiler/compiler_test.go
parente29ee3e310044ddb2356513808554a46de957659 (diff)
downloadjinx-b09fce67753e199d4ae0fe6138f909b5e3413208.tar.zst
jinx-b09fce67753e199d4ae0fe6138f909b5e3413208.zip
Fix nested if block compiling
Diffstat (limited to 'pkg/lang/compiler/compiler_test.go')
-rw-r--r--pkg/lang/compiler/compiler_test.go31
1 files changed, 31 insertions, 0 deletions
diff --git a/pkg/lang/compiler/compiler_test.go b/pkg/lang/compiler/compiler_test.go
index a6a1ba7..88413c7 100644
--- a/pkg/lang/compiler/compiler_test.go
+++ b/pkg/lang/compiler/compiler_test.go
@@ -203,6 +203,37 @@ func TestIfNoElse(t *testing.T) {
 	mustCompileTo(t, src, expected)
 }
 
+func TestNestedIfs(t *testing.T) {
+	src := `
+	if true {
+		if false {
+			1
+		} else {
+			2
+		}
+	}
+	`
+
+	expected := `
+	push_true
+	jf @end
+
+	push_false
+	jf @else
+
+	push_int 1
+	jmp @end
+
+	@else:
+	push_int 2
+	
+	@end:
+	halt
+	`
+
+	mustCompileTo(t, src, expected)
+}
+
 func mustCompileTo(t *testing.T, src, expected string) {
 	scanner := scanner.New(strings.NewReader(src))
 	tokens, err := scanner.Scan()