aboutsummaryrefslogtreecommitdiff
path: root/src/checker.c
diff options
context:
space:
mode:
authorGinger Bill <bill@gingerbill.org>2017-04-01 22:41:23 +0100
committerGinger Bill <bill@gingerbill.org>2017-04-01 22:41:23 +0100
commit5008e2c88b314156e0388db7f7ed789fb828c7e4 (patch)
treeb9e34773c4bf332c270c8ab20459c732c1539a5b /src/checker.c
parent90fc9abeae5c580202909a35ccb0dd367a142f99 (diff)
Add Quaternions: quaternion128, quaternion256
Diffstat (limited to 'src/checker.c')
-rw-r--r--src/checker.c51
1 files changed, 35 insertions, 16 deletions
diff --git a/src/checker.c b/src/checker.c
index 5f1352a29..c594bbe8a 100644
--- a/src/checker.c
+++ b/src/checker.c
@@ -53,8 +53,12 @@ typedef enum BuiltinProcId {
BuiltinProc_swizzle,
BuiltinProc_complex,
+ BuiltinProc_quaternion,
BuiltinProc_real,
BuiltinProc_imag,
+ BuiltinProc_jmag,
+ BuiltinProc_kmag,
+ BuiltinProc_conj,
// BuiltinProc_ptr_offset,
// BuiltinProc_ptr_sub,
@@ -101,8 +105,12 @@ gb_global BuiltinProc builtin_procs[BuiltinProc_Count] = {
{STR_LIT("swizzle"), 1, true, Expr_Expr},
{STR_LIT("complex"), 2, false, Expr_Expr},
+ {STR_LIT("quaternion"), 4, false, Expr_Expr},
{STR_LIT("real"), 1, false, Expr_Expr},
{STR_LIT("imag"), 1, false, Expr_Expr},
+ {STR_LIT("jmag"), 1, false, Expr_Expr},
+ {STR_LIT("kmag"), 1, false, Expr_Expr},
+ {STR_LIT("conj"), 1, false, Expr_Expr},
// {STR_LIT("ptr_offset"), 2, false, Expr_Expr},
// {STR_LIT("ptr_sub"), 2, false, Expr_Expr},
@@ -957,6 +965,15 @@ void add_type_info_type(Checker *c, Type *t) {
add_type_info_type(c, t_type_info_float);
add_type_info_type(c, t_f64);
break;
+
+ case Basic_quaternion128:
+ add_type_info_type(c, t_type_info_float);
+ add_type_info_type(c, t_f32);
+ break;
+ case Basic_quaternion256:
+ add_type_info_type(c, t_type_info_float);
+ add_type_info_type(c, t_f64);
+ break;
}
} break;
@@ -1145,33 +1162,35 @@ void init_preload(Checker *c) {
- if (record->variant_count != 20) {
+ if (record->variant_count != 21) {
compiler_error("Invalid `Type_Info` layout");
}
t_type_info_named = record->variants[ 1]->type;
t_type_info_integer = record->variants[ 2]->type;
t_type_info_float = record->variants[ 3]->type;
t_type_info_complex = record->variants[ 4]->type;
- t_type_info_string = record->variants[ 5]->type;
- t_type_info_boolean = record->variants[ 6]->type;
- t_type_info_any = record->variants[ 7]->type;
- t_type_info_pointer = record->variants[ 8]->type;
- t_type_info_procedure = record->variants[ 9]->type;
- t_type_info_array = record->variants[10]->type;
- t_type_info_dynamic_array = record->variants[11]->type;
- t_type_info_slice = record->variants[12]->type;
- t_type_info_vector = record->variants[13]->type;
- t_type_info_tuple = record->variants[14]->type;
- t_type_info_struct = record->variants[15]->type;
- t_type_info_raw_union = record->variants[16]->type;
- t_type_info_union = record->variants[17]->type;
- t_type_info_enum = record->variants[18]->type;
- t_type_info_map = record->variants[19]->type;
+ t_type_info_quaternion = record->variants[ 5]->type;
+ t_type_info_string = record->variants[ 6]->type;
+ t_type_info_boolean = record->variants[ 7]->type;
+ t_type_info_any = record->variants[ 8]->type;
+ t_type_info_pointer = record->variants[ 9]->type;
+ t_type_info_procedure = record->variants[10]->type;
+ t_type_info_array = record->variants[11]->type;
+ t_type_info_dynamic_array = record->variants[12]->type;
+ t_type_info_slice = record->variants[13]->type;
+ t_type_info_vector = record->variants[14]->type;
+ t_type_info_tuple = record->variants[15]->type;
+ t_type_info_struct = record->variants[16]->type;
+ t_type_info_raw_union = record->variants[17]->type;
+ t_type_info_union = record->variants[18]->type;
+ t_type_info_enum = record->variants[19]->type;
+ t_type_info_map = record->variants[20]->type;
t_type_info_named_ptr = make_type_pointer(c->allocator, t_type_info_named);
t_type_info_integer_ptr = make_type_pointer(c->allocator, t_type_info_integer);
t_type_info_float_ptr = make_type_pointer(c->allocator, t_type_info_float);
t_type_info_complex_ptr = make_type_pointer(c->allocator, t_type_info_complex);
+ t_type_info_quaternion_ptr = make_type_pointer(c->allocator, t_type_info_quaternion);
t_type_info_string_ptr = make_type_pointer(c->allocator, t_type_info_string);
t_type_info_boolean_ptr = make_type_pointer(c->allocator, t_type_info_boolean);
t_type_info_any_ptr = make_type_pointer(c->allocator, t_type_info_any);