aboutsummaryrefslogtreecommitdiff
path: root/src/check_type.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2021-07-11 16:08:16 +0100
committergingerBill <bill@gingerbill.org>2021-07-11 16:08:16 +0100
commit460e14e5860a503b8e7716ce18a29eb99f517cf7 (patch)
tree058edb259fd5e6cab889f7b12156938c748509c0 /src/check_type.cpp
parentebcabb8a27ace67c3cd869a573df62b260000ee8 (diff)
Change the compiler's big integer library to use libTomMath
This now replaces Bill's crappy big int implementation
Diffstat (limited to 'src/check_type.cpp')
-rw-r--r--src/check_type.cpp8
1 files changed, 4 insertions, 4 deletions
diff --git a/src/check_type.cpp b/src/check_type.cpp
index cc4ffebca..e8000d66c 100644
--- a/src/check_type.cpp
+++ b/src/check_type.cpp
@@ -207,7 +207,7 @@ bool check_custom_align(CheckerContext *ctx, Ast *node, i64 *align_) {
if (is_type_untyped(type) || is_type_integer(type)) {
if (o.value.kind == ExactValue_Integer) {
BigInt v = o.value.value_integer;
- if (v.len > 1) {
+ if (v.used > 1) {
gbAllocator a = heap_allocator();
String str = big_int_to_string(a, &v);
error(node, "#align too large, %.*s", LIT(str));
@@ -1998,16 +1998,16 @@ i64 check_array_count(CheckerContext *ctx, Operand *o, Ast *e) {
if (is_type_untyped(type) || is_type_integer(type)) {
if (o->value.kind == ExactValue_Integer) {
BigInt count = o->value.value_integer;
- if (o->value.value_integer.neg) {
+ if (o->value.value_integer.sign) {
gbAllocator a = heap_allocator();
String str = big_int_to_string(a, &count);
error(e, "Invalid negative array count, %.*s", LIT(str));
gb_free(a, str.text);
return 0;
}
- switch (count.len) {
+ switch (count.used) {
case 0: return 0;
- case 1: return count.d.word;
+ case 1: return big_int_to_u64(&count);
}
gbAllocator a = heap_allocator();
String str = big_int_to_string(a, &count);