aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/check_expr.cpp3
-rw-r--r--src/llvm_backend_expr.cpp17
2 files changed, 20 insertions, 0 deletions
diff --git a/src/check_expr.cpp b/src/check_expr.cpp
index 1e8c24fd6..2139cd777 100644
--- a/src/check_expr.cpp
+++ b/src/check_expr.cpp
@@ -2453,6 +2453,9 @@ bool check_is_castable_to(CheckerContext *c, Operand *operand, Type *y) {
return true;
}
+ if (is_type_float(src) && is_type_quaternion(dst)) {
+ return true;
+ }
if (is_type_complex(src) && is_type_quaternion(dst)) {
return true;
}
diff --git a/src/llvm_backend_expr.cpp b/src/llvm_backend_expr.cpp
index d49863c2a..8fd39fdb9 100644
--- a/src/llvm_backend_expr.cpp
+++ b/src/llvm_backend_expr.cpp
@@ -1658,6 +1658,23 @@ lbValue lb_emit_conv(lbProcedure *p, lbValue value, Type *t) {
}
return res;
}
+
+ if (is_type_float(src) && is_type_complex(dst)) {
+ Type *ft = base_complex_elem_type(dst);
+ lbAddr gen = lb_add_local_generated(p, dst, false);
+ lbValue gp = lb_addr_get_ptr(p, gen);
+ lbValue real = lb_emit_conv(p, value, ft);
+ lb_emit_store(p, lb_emit_struct_ep(p, gp, 0), real);
+ return lb_addr_load(p, gen);
+ }
+ if (is_type_float(src) && is_type_quaternion(dst)) {
+ Type *ft = base_complex_elem_type(dst);
+ lbAddr gen = lb_add_local_generated(p, dst, false);
+ lbValue gp = lb_addr_get_ptr(p, gen);
+ lbValue real = lb_emit_conv(p, value, ft);
+ lb_emit_store(p, lb_emit_struct_ep(p, gp, 0), real);
+ return lb_addr_load(p, gen);
+ }
if (is_type_complex(src) && is_type_complex(dst)) {
Type *ft = base_complex_elem_type(dst);