aboutsummaryrefslogtreecommitdiff
path: root/src/primitives/eval.d
diff options
context:
space:
mode:
authorAdrian Kummerlaender2017-04-12 18:15:38 +0200
committerAdrian Kummerlaender2017-04-12 18:15:38 +0200
commit061db1f3810efac768dc7a83a8fbfaecfc512577 (patch)
tree3f09b618a2c52b6137f6e0d6735749aa61681216 /src/primitives/eval.d
parentd0c6994a0c3706a3eb09d32c8bf33513b1dbd3be (diff)
downloadslang-061db1f3810efac768dc7a83a8fbfaecfc512577.tar
slang-061db1f3810efac768dc7a83a8fbfaecfc512577.tar.gz
slang-061db1f3810efac768dc7a83a8fbfaecfc512577.tar.bz2
slang-061db1f3810efac768dc7a83a8fbfaecfc512577.tar.lz
slang-061db1f3810efac768dc7a83a8fbfaecfc512577.tar.xz
slang-061db1f3810efac768dc7a83a8fbfaecfc512577.tar.zst
slang-061db1f3810efac768dc7a83a8fbfaecfc512577.zip
Expand conditional primitive to choose between `then` and `else` branch
i.e. `1 if true then false else` evaluates to `true`, `0 if true then false else` evaluates to `false`.
Diffstat (limited to 'src/primitives/eval.d')
-rw-r--r--src/primitives/eval.d17
1 files changed, 11 insertions, 6 deletions
diff --git a/src/primitives/eval.d b/src/primitives/eval.d
index 3f52e6d..533f491 100644
--- a/src/primitives/eval.d
+++ b/src/primitives/eval.d
@@ -8,10 +8,13 @@ bool evaluate(int value) {
bool evaluate(string word) {
if ( drop_mode ) {
- if ( word == "then" ) {
- return conditional_end;
- } else {
- return true;
+ switch ( word ) {
+ case "then":
+ return conditional_then;
+ case "else":
+ return conditional_else;
+ default:
+ return true;
}
}
@@ -23,9 +26,11 @@ bool evaluate(string word) {
case "@":
return unary_op_variable_resolve;
case "if":
- return conditional_start;
+ return conditional_if;
case "then":
- return conditional_end;
+ return conditional_then;
+ case "else":
+ return conditional_else;
case "+":
return binary_op_add;
case "*":