aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--compile.c28
-rw-r--r--test/integers.tm10
2 files changed, 33 insertions, 5 deletions
diff --git a/compile.c b/compile.c
index 8bd88fc6..2b1751ae 100644
--- a/compile.c
+++ b/compile.c
@@ -2863,13 +2863,31 @@ CORD compile(env_t *env, ast_t *ast)
type_t *actual = get_type(env, call->args->value);
arg_t *args = new(arg_t, .name="i", .type=actual); // No truncation argument
CORD arg_code = compile_arguments(env, ast, args, call->args);
- return CORD_all(type_to_cord(actual), "_to_", type_to_cord(t), "(", arg_code, ")");
+ if (is_numeric_type(actual)) {
+ return CORD_all(type_to_cord(actual), "_to_", type_to_cord(t), "(", arg_code, ")");
+ } else if (actual->tag == BoolType) {
+ if (t->tag == NumType) {
+ return CORD_all("((", compile_type(t), ")(", arg_code, "))");
+ } else {
+ return CORD_all("I((int)(", arg_code, "))");
+ }
+ } else {
+ code_err(ast, "You cannot convert a %T to a %T this way.", actual, t);
+ }
} else if (t->tag == IntType) {
type_t *actual = get_type(env, call->args->value);
- arg_t *args = new(arg_t, .name="i", .type=actual, .next=new(arg_t, .name="truncate", .type=Type(BoolType),
- .default_val=FakeAST(Bool, false)));
- CORD arg_code = compile_arguments(env, ast, args, call->args);
- return CORD_all(type_to_cord(actual), "_to_", type_to_cord(t), "(", arg_code, ")");
+ if (is_numeric_type(actual)) {
+ arg_t *args = new(arg_t, .name="i", .type=actual, .next=new(arg_t, .name="truncate", .type=Type(BoolType),
+ .default_val=FakeAST(Bool, false)));
+ CORD arg_code = compile_arguments(env, ast, args, call->args);
+ return CORD_all(type_to_cord(actual), "_to_", type_to_cord(t), "(", arg_code, ")");
+ } else if (actual->tag == BoolType) {
+ arg_t *args = new(arg_t, .name="i", .type=actual);
+ CORD arg_code = compile_arguments(env, ast, args, call->args);
+ return CORD_all("((", compile_type(t),")(", arg_code, "))");
+ } else {
+ code_err(ast, "You cannot convert a %T to a %T this way.", actual, t);
+ }
} else if (t->tag == TextType) {
if (!call->args) code_err(ast, "This constructor needs a value");
const char *lang = Match(t, TextType)->lang;
diff --git a/test/integers.tm b/test/integers.tm
index 363fdfdd..eb0c3fed 100644
--- a/test/integers.tm
+++ b/test/integers.tm
@@ -111,3 +111,13 @@ func main():
292590241572454328697048860273*754893741683930091960170890717,
]
= no
+
+ >> Int(yes)
+ = 1
+ >> Int(no)
+ = 0
+
+ >> Int64(yes)
+ = 1[64]
+ >> Int64(no)
+ = 0[64]