added a test case to check a block expression as a conditional expression for if
All checks were successful
continuous-integration/drone/push Build is passing

This commit is contained in:
hyung-hwan 2024-03-09 22:48:04 +09:00
parent 8345e2f949
commit 00ad4dd779
3 changed files with 6 additions and 4 deletions

View File

@ -4497,7 +4497,6 @@ redo:
if (compile_cons_mlist_expression(hcl, oprnd, 0) <= -1) return -1;
break;
case HCL_CONCODE_BLOCK:
if (!(hcl->option.trait & HCL_TRAIT_LANG_ENABLE_BLOCK))
{

View File

@ -49,6 +49,9 @@ if (eqv? J 1296) {
}
k := 5
if { q := 10; k < q } { ## a block expression is a normal expression. so t can be used as a conditional expression for if
printf "OK: k is less than q\n"
} else (printf "BAD: k is not less than q\n")
} ## END

View File

@ -20,7 +20,7 @@ defun mkfun(t) {
});
}
defun mkfund(t) {
defun mkfun2(t) {
return {fun(c) {
return (fun(d) {
return (+ d c t)
@ -55,7 +55,7 @@ if (k = 60) {
printf "ERROR - %d\n" k
};
k := (((mkfund 10) 40) 30)
k := (((mkfun2 10) 40) 30)
if (k = 80) {
printf "OK - %d\n" k
} else {