diff options
| author | gingerBill <bill@gingerbill.org> | 2021-08-31 23:47:57 +0100 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2021-08-31 23:47:57 +0100 |
| commit | 720884e0f1d6f15c248f8fbe7b86aa146cedac72 (patch) | |
| tree | 046cb8ca71dbce74ba3337806f00dabd3c71285b /core/math/big | |
| parent | 773a766b83c327069f3634ad982e29e9e06119e9 (diff) | |
Strip even more semicolons if followed by a `}` or `)` on the same line
Diffstat (limited to 'core/math/big')
| -rw-r--r-- | core/math/big/common.odin | 2 | ||||
| -rw-r--r-- | core/math/big/helpers.odin | 30 | ||||
| -rw-r--r-- | core/math/big/internal.odin | 130 | ||||
| -rw-r--r-- | core/math/big/logical.odin | 2 | ||||
| -rw-r--r-- | core/math/big/prime.odin | 2 | ||||
| -rw-r--r-- | core/math/big/private.odin | 10 | ||||
| -rw-r--r-- | core/math/big/public.odin | 20 | ||||
| -rw-r--r-- | core/math/big/radix.odin | 4 | ||||
| -rw-r--r-- | core/math/big/test.odin | 120 |
9 files changed, 160 insertions, 160 deletions
diff --git a/core/math/big/common.odin b/core/math/big/common.odin index 643e8b49d..c43346f5a 100644 --- a/core/math/big/common.odin +++ b/core/math/big/common.odin @@ -87,7 +87,7 @@ FACTORIAL_BINARY_SPLIT_MAX_RECURSIONS := 100 */ MATH_BIG_FORCE_64_BIT :: #config(MATH_BIG_FORCE_64_BIT, false) MATH_BIG_FORCE_32_BIT :: #config(MATH_BIG_FORCE_32_BIT, false) -when (MATH_BIG_FORCE_32_BIT && MATH_BIG_FORCE_64_BIT) { #panic("Cannot force 32-bit and 64-bit big backend simultaneously."); } +when (MATH_BIG_FORCE_32_BIT && MATH_BIG_FORCE_64_BIT) { #panic("Cannot force 32-bit and 64-bit big backend simultaneously.") } _LOW_MEMORY :: #config(BIGINT_SMALL_MEMORY, false) when _LOW_MEMORY { diff --git a/core/math/big/helpers.odin b/core/math/big/helpers.odin index 6b01fc241..45c6771da 100644 --- a/core/math/big/helpers.odin +++ b/core/math/big/helpers.odin @@ -56,7 +56,7 @@ int_copy :: proc(dest, src: ^Int, minimize := false, allocator := context.alloca /* If dest == src, do nothing */ - if (dest == src) { return nil; } + if (dest == src) { return nil } /* Check that `src` is usable and `dest` isn't immutable. @@ -383,7 +383,7 @@ assert_initialized :: proc(a: ^Int, loc := #caller_location) { zero_unused :: proc(dest: ^Int, old_used := -1) { assert_if_nil(dest) - if ! #force_inline is_initialized(dest) { return; } + if ! #force_inline is_initialized(dest) { return } #force_inline internal_zero_unused(dest, old_used) } @@ -405,13 +405,13 @@ clear_if_uninitialized_multi :: proc(args: ..^Int, allocator := context.allocato clear_if_uninitialized :: proc {clear_if_uninitialized_single, clear_if_uninitialized_multi, } error_if_immutable_single :: proc(arg: ^Int) -> (err: Error) { - if arg != nil && .Immutable in arg.flags { return .Assignment_To_Immutable; } + if arg != nil && .Immutable in arg.flags { return .Assignment_To_Immutable } return nil } error_if_immutable_multi :: proc(args: ..^Int) -> (err: Error) { for i in args { - if i != nil && .Immutable in i.flags { return .Assignment_To_Immutable; } + if i != nil && .Immutable in i.flags { return .Assignment_To_Immutable } } return nil } @@ -489,7 +489,7 @@ int_to_bytes_little :: proc(a: ^Int, buf: []u8, signed := false, allocator := co size_in_bytes := int_to_bytes_size(a, signed, allocator) or_return l := len(buf) - if size_in_bytes > l { return .Buffer_Overflow; } + if size_in_bytes > l { return .Buffer_Overflow } size_in_bits := internal_count_bits(a) i := 0 @@ -512,7 +512,7 @@ int_to_bytes_big :: proc(a: ^Int, buf: []u8, signed := false, allocator := conte size_in_bytes := int_to_bytes_size(a, signed, allocator) or_return l := len(buf) - if size_in_bytes > l { return .Buffer_Overflow; } + if size_in_bytes > l { return .Buffer_Overflow } size_in_bits := internal_count_bits(a) i := l - 1 @@ -534,11 +534,11 @@ int_to_bytes_big :: proc(a: ^Int, buf: []u8, signed := false, allocator := conte int_to_bytes_little_python :: proc(a: ^Int, buf: []u8, signed := false, allocator := context.allocator) -> (err: Error) { assert_if_nil(a) - if !signed && a.sign == .Negative { return .Invalid_Argument; } + if !signed && a.sign == .Negative { return .Invalid_Argument } l := len(buf) size_in_bytes := int_to_bytes_size(a, signed, allocator) or_return - if size_in_bytes > l { return .Buffer_Overflow; } + if size_in_bytes > l { return .Buffer_Overflow } if a.sign == .Negative { t := &Int{} @@ -570,12 +570,12 @@ int_to_bytes_little_python :: proc(a: ^Int, buf: []u8, signed := false, allocato int_to_bytes_big_python :: proc(a: ^Int, buf: []u8, signed := false, allocator := context.allocator) -> (err: Error) { assert_if_nil(a) - if !signed && a.sign == .Negative { return .Invalid_Argument; } - if a.sign == .Zero_or_Positive { return int_to_bytes_big(a, buf, signed, allocator); } + if !signed && a.sign == .Negative { return .Invalid_Argument } + if a.sign == .Zero_or_Positive { return int_to_bytes_big(a, buf, signed, allocator) } l := len(buf) size_in_bytes := int_to_bytes_size(a, signed, allocator) or_return - if size_in_bytes > l { return .Buffer_Overflow; } + if size_in_bytes > l { return .Buffer_Overflow } t := &Int{} defer destroy(t) @@ -601,7 +601,7 @@ int_from_bytes_big :: proc(a: ^Int, buf: []u8, signed := false, allocator := con assert_if_nil(a) buf := buf l := len(buf) - if l == 0 { return .Invalid_Argument; } + if l == 0 { return .Invalid_Argument } sign: Sign size_in_bits := l * 8 @@ -638,7 +638,7 @@ int_from_bytes_big_python :: proc(a: ^Int, buf: []u8, signed := false, allocator assert_if_nil(a) buf := buf l := len(buf) - if l == 0 { return .Invalid_Argument; } + if l == 0 { return .Invalid_Argument } sign: Sign size_in_bits := l * 8 @@ -684,7 +684,7 @@ int_from_bytes_little :: proc(a: ^Int, buf: []u8, signed := false, allocator := assert_if_nil(a) buf := buf l := len(buf) - if l == 0 { return .Invalid_Argument; } + if l == 0 { return .Invalid_Argument } sign: Sign size_in_bits := l * 8 @@ -722,7 +722,7 @@ int_from_bytes_little_python :: proc(a: ^Int, buf: []u8, signed := false, alloca assert_if_nil(a) buf := buf l := len(buf) - if l == 0 { return .Invalid_Argument; } + if l == 0 { return .Invalid_Argument } sign: Sign size_in_bits := l * 8 diff --git a/core/math/big/internal.odin b/core/math/big/internal.odin index b0e0c1f5d..63c702f5e 100644 --- a/core/math/big/internal.odin +++ b/core/math/big/internal.odin @@ -628,7 +628,7 @@ internal_int_mul :: proc(dest, src, multiplier: ^Int, allocator := context.alloc /* Early out for `multiplier` is zero; Set `dest` to zero. */ - if multiplier.used == 0 || src.used == 0 { return internal_zero(dest); } + if multiplier.used == 0 || src.used == 0 { return internal_zero(dest) } neg := src.sign != multiplier.sign @@ -715,7 +715,7 @@ internal_sqr :: proc (dest, src: ^Int, allocator := context.allocator) -> (res: */ internal_int_divmod :: proc(quotient, remainder, numerator, denominator: ^Int, allocator := context.allocator) -> (err: Error) { context.allocator = allocator - if denominator.used == 0 { return .Division_by_Zero; } + if denominator.used == 0 { return .Division_by_Zero } /* If numerator < denominator then quotient = 0, remainder = numerator. */ @@ -757,7 +757,7 @@ internal_int_divmod_digit :: proc(quotient, numerator: ^Int, denominator: DIGIT, /* Cannot divide by zero. */ - if denominator == 0 { return 0, .Division_by_Zero; } + if denominator == 0 { return 0, .Division_by_Zero } /* Quick outs. @@ -854,7 +854,7 @@ internal_div :: proc { internal_int_div, } internal_int_mod :: proc(remainder, numerator, denominator: ^Int, allocator := context.allocator) -> (err: Error) { #force_inline internal_int_divmod(nil, remainder, numerator, denominator, allocator) or_return - if remainder.used == 0 || denominator.sign == remainder.sign { return nil; } + if remainder.used == 0 || denominator.sign == remainder.sign { return nil } return #force_inline internal_add(remainder, remainder, numerator, allocator) } @@ -937,7 +937,7 @@ internal_int_factorial :: proc(res: ^Int, n: int, allocator := context.allocator `res_gcd` and `res_lcm` can be nil or ^Int depending on which results are desired. */ internal_int_gcd_lcm :: proc(res_gcd, res_lcm, a, b: ^Int, allocator := context.allocator) -> (err: Error) { - if res_gcd == nil && res_lcm == nil { return nil; } + if res_gcd == nil && res_lcm == nil { return nil } return #force_inline _private_int_gcd_lcm(res_gcd, res_lcm, a, b, allocator) } @@ -951,7 +951,7 @@ internal_int_mod_bits :: proc(remainder, numerator: ^Int, bits: int, allocator : /* Everything is divisible by 1 << 0 == 1, so this returns 0. */ - if bits == 0 { return internal_zero(remainder); } + if bits == 0 { return internal_zero(remainder) } /* If the modulus is larger than the value, return the value. @@ -1034,7 +1034,7 @@ internal_is_negative :: proc { internal_int_is_negative, } Assumes `a` not to be `nil`. */ internal_int_is_even :: #force_inline proc(a: ^Int) -> (even: bool) { - if internal_is_zero(a) { return true; } + if internal_is_zero(a) { return true } /* `a.used` > 0 here, because the above handled `is_zero`. @@ -1062,23 +1062,23 @@ internal_int_is_power_of_two :: #force_inline proc(a: ^Int) -> (power_of_two: bo /* Early out for Int == 0. */ - if #force_inline internal_is_zero(a) { return true; } + if #force_inline internal_is_zero(a) { return true } /* For an `Int` to be a power of two, its bottom limb has to be a power of two. */ - if ! #force_inline platform_int_is_power_of_two(int(a.digit[a.used - 1])) { return false; } + if ! #force_inline platform_int_is_power_of_two(int(a.digit[a.used - 1])) { return false } /* We've established that the bottom limb is a power of two. If it's the only limb, that makes the entire Int a power of two. */ - if a.used == 1 { return true; } + if a.used == 1 { return true } /* For an `Int` to be a power of two, all limbs except the top one have to be zero. */ - for i := 1; i < a.used && a.digit[i - 1] != 0; i += 1 { return false; } + for i := 1; i < a.used && a.digit[i - 1] != 0; i += 1 { return false } return true } @@ -1096,11 +1096,11 @@ internal_int_compare :: #force_inline proc(a, b: ^Int) -> (comparison: int) { /* Compare based on sign. */ - if a.sign != b.sign { return -1 if a_is_negative else +1; } + if a.sign != b.sign { return -1 if a_is_negative else +1 } /* If `a` is negative, compare in the opposite direction */ - if a_is_negative { return #force_inline internal_compare_magnitude(b, a); } + if a_is_negative { return #force_inline internal_compare_magnitude(b, a) } return #force_inline internal_compare_magnitude(a, b) } @@ -1186,20 +1186,20 @@ internal_int_is_square :: proc(a: ^Int, allocator := context.allocator) -> (squa */ square = false - if internal_is_negative(a) { return; } - if internal_is_zero(a) { return; } + if internal_is_negative(a) { return } + if internal_is_zero(a) { return } /* First check mod 128 (suppose that _DIGIT_BITS is at least 7). */ - if _private_int_rem_128[127 & a.digit[0]] == 1 { return; } + if _private_int_rem_128[127 & a.digit[0]] == 1 { return } /* Next check mod 105 (3*5*7). */ c: DIGIT c, err = internal_mod(a, 105) - if _private_int_rem_105[c] == 1 { return; } + if _private_int_rem_105[c] == 1 { return } t := &Int{} defer destroy(t) @@ -1215,13 +1215,13 @@ internal_int_is_square :: proc(a: ^Int, allocator := context.allocator) -> (squa free "t" so the easiest way is to goto LBL_ERR. We know that err is already equal to MP_OKAY from the mp_mod call */ - if (1 << (r % 11) & 0x5C4) != 0 { return; } - if (1 << (r % 13) & 0x9E4) != 0 { return; } - if (1 << (r % 17) & 0x5CE8) != 0 { return; } - if (1 << (r % 19) & 0x4F50C) != 0 { return; } - if (1 << (r % 23) & 0x7ACCA0) != 0 { return; } - if (1 << (r % 29) & 0xC2EDD0C) != 0 { return; } - if (1 << (r % 31) & 0x6DE2B848) != 0 { return; } + if (1 << (r % 11) & 0x5C4) != 0 { return } + if (1 << (r % 13) & 0x9E4) != 0 { return } + if (1 << (r % 17) & 0x5CE8) != 0 { return } + if (1 << (r % 19) & 0x4F50C) != 0 { return } + if (1 << (r % 23) & 0x7ACCA0) != 0 { return } + if (1 << (r % 29) & 0xC2EDD0C) != 0 { return } + if (1 << (r % 31) & 0x6DE2B848) != 0 { return } /* Final check - is sqr(sqrt(arg)) == arg? @@ -1243,20 +1243,20 @@ internal_int_is_square :: proc(a: ^Int, allocator := context.allocator) -> (squa Assumes `a` to not be `nil` and have been iniialized. */ internal_int_log :: proc(a: ^Int, base: DIGIT) -> (res: int, err: Error) { - if base < 2 || DIGIT(base) > _DIGIT_MAX { return -1, .Invalid_Argument; } + if base < 2 || DIGIT(base) > _DIGIT_MAX { return -1, .Invalid_Argument } - if internal_is_negative(a) { return -1, .Math_Domain_Error; } - if internal_is_zero(a) { return -1, .Math_Domain_Error; } + if internal_is_negative(a) { return -1, .Math_Domain_Error } + if internal_is_zero(a) { return -1, .Math_Domain_Error } /* Fast path for bases that are a power of two. */ - if platform_int_is_power_of_two(int(base)) { return _private_log_power_of_two(a, base); } + if platform_int_is_power_of_two(int(base)) { return _private_log_power_of_two(a, base) } /* Fast path for `Int`s that fit within a single `DIGIT`. */ - if a.used == 1 { return internal_log(a.digit[0], DIGIT(base)); } + if a.used == 1 { return internal_log(a.digit[0], DIGIT(base)) } return _private_int_log(a, base) @@ -1270,12 +1270,12 @@ internal_digit_log :: proc(a: DIGIT, base: DIGIT) -> (log: int, err: Error) { If the number is smaller than the base, it fits within a fraction. Therefore, we return 0. */ - if a < base { return 0, nil; } + if a < base { return 0, nil } /* If a number equals the base, the log is 1. */ - if a == base { return 1, nil; } + if a == base { return 1, nil } N := _WORD(a) bracket_low := _WORD(1) @@ -1334,8 +1334,8 @@ internal_int_pow :: proc(dest, base: ^Int, power: int, allocator := context.allo internal_zero(dest) or_return return .Math_Domain_Error } - if power == 0 { return internal_one(dest); } - if power > 0 { return internal_zero(dest); } + if power == 0 { return internal_one(dest) } + if power > 0 { return internal_zero(dest) } } if power < 0 { @@ -1435,12 +1435,12 @@ internal_int_sqrt :: proc(dest, src: ^Int, allocator := context.allocator) -> (e /* Must be positive. */ - if #force_inline internal_is_negative(src) { return .Invalid_Argument; } + if #force_inline internal_is_negative(src) { return .Invalid_Argument } /* Easy out. If src is zero, so is dest. */ - if #force_inline internal_is_zero(src) { return internal_zero(dest); } + if #force_inline internal_is_zero(src) { return internal_zero(dest) } /* Set up temporaries. @@ -1489,11 +1489,11 @@ internal_int_root_n :: proc(dest, src: ^Int, n: int, allocator := context.alloca /* Fast path for n == 2 */ - if n == 2 { return #force_inline internal_sqrt(dest, src); } + if n == 2 { return #force_inline internal_sqrt(dest, src) } - if n < 0 || n > int(_DIGIT_MAX) { return .Invalid_Argument; } + if n < 0 || n > int(_DIGIT_MAX) { return .Invalid_Argument } - if n & 1 == 0 && #force_inline internal_is_negative(src) { return .Invalid_Argument; } + if n & 1 == 0 && #force_inline internal_is_negative(src) { return .Invalid_Argument } /* Set up temporaries. @@ -1576,8 +1576,8 @@ internal_int_root_n :: proc(dest, src: ^Int, n: int, allocator := context.alloca Number of rounds is at most log_2(root). If it is more it got stuck, so break out of the loop and do the rest manually. */ - if ilog2 -= 1; ilog2 == 0 { break; } - if internal_cmp(t1, t2) == 0 { break; } + if ilog2 -= 1; ilog2 == 0 { break } + if internal_cmp(t1, t2) == 0 { break } iterations += 1 if iterations == MAX_ITERATIONS_ROOT_N { @@ -1615,7 +1615,7 @@ internal_int_root_n :: proc(dest, src: ^Int, n: int, allocator := context.alloca for { internal_pow(t2, t1, n) or_return - if internal_cmp(t2, a) != 1 { break; } + if internal_cmp(t2, a) != 1 { break } internal_sub(t1, t1, DIGIT(1)) or_return @@ -1712,7 +1712,7 @@ internal_int_copy :: proc(dest, src: ^Int, minimize := false, allocator := conte /* If dest == src, do nothing */ - if (dest == src) { return nil; } + if (dest == src) { return nil } internal_error_if_immutable(dest) or_return @@ -1821,17 +1821,17 @@ internal_int_inverse_modulo :: proc(dest, a, b: ^Int, allocator := context.alloc /* For all n in N and n > 0, n = 0 mod 1. */ - if internal_is_positive(a) && internal_cmp(b, 1) == 0 { return internal_zero(dest); } + if internal_is_positive(a) && internal_cmp(b, 1) == 0 { return internal_zero(dest) } /* `b` cannot be negative and has to be > 1 */ - if internal_is_negative(b) && internal_cmp(b, 1) != 1 { return .Invalid_Argument; } + if internal_is_negative(b) && internal_cmp(b, 1) != 1 { return .Invalid_Argument } /* If the modulus is odd we can use a faster routine instead. */ - if internal_is_odd(b) { return _private_inverse_modulo_odd(dest, a, b); } + if internal_is_odd(b) { return _private_inverse_modulo_odd(dest, a, b) } return _private_inverse_modulo(dest, a, b) } @@ -1850,12 +1850,12 @@ internal_int_bitfield_extract :: proc(a: ^Int, offset, count: int) -> (res: _WOR */ if count == 1 { limb := offset / _DIGIT_BITS - if limb < 0 || limb >= a.used { return 0, .Invalid_Argument; } + if limb < 0 || limb >= a.used { return 0, .Invalid_Argument } i := _WORD(1 << _WORD((offset % _DIGIT_BITS))) return 1 if ((_WORD(a.digit[limb]) & i) != 0) else 0, nil } - if count > _WORD_BITS || count < 1 { return 0, .Invalid_Argument; } + if count > _WORD_BITS || count < 1 { return 0, .Invalid_Argument } /* There are 3 possible cases. @@ -1880,7 +1880,7 @@ internal_int_bitfield_extract :: proc(a: ^Int, offset, count: int) -> (res: _WOR res = (_WORD(a.digit[limb]) >> uint(shift)) & mask bits_left -= num_bits - if bits_left == 0 { return res, nil; } + if bits_left == 0 { return res, nil } res_shift := num_bits num_bits = min(bits_left, _DIGIT_BITS) @@ -1889,7 +1889,7 @@ internal_int_bitfield_extract :: proc(a: ^Int, offset, count: int) -> (res: _WOR res |= (_WORD(a.digit[limb + 1]) & mask) << uint(res_shift) bits_left -= num_bits - if bits_left == 0 { return res, nil; } + if bits_left == 0 { return res, nil } mask = (1 << uint(bits_left)) - 1 res_shift += _DIGIT_BITS @@ -1908,7 +1908,7 @@ internal_int_bitfield_extract :: proc(a: ^Int, offset, count: int) -> (res: _WOR internal_int_shrink :: proc(a: ^Int) -> (err: Error) { needed := max(_MIN_DIGIT_COUNT, a.used) - if a.used != needed { return internal_grow(a, needed, true); } + if a.used != needed { return internal_grow(a, needed, true) } return nil } internal_shrink :: proc { internal_int_shrink, } @@ -2006,7 +2006,7 @@ internal_nan :: proc { internal_int_nan, } internal_int_power_of_two :: proc(a: ^Int, power: int, allocator := context.allocator) -> (err: Error) { context.allocator = allocator - if power < 0 || power > _MAX_BIT_COUNT { return .Invalid_Argument; } + if power < 0 || power > _MAX_BIT_COUNT { return .Invalid_Argument } /* Grow to accomodate the single bit. @@ -2080,7 +2080,7 @@ internal_int_get :: proc(a: ^Int, $T: typeid) -> (res: T, err: Error) where intr /* Set the sign. */ - if a.sign == .Negative { res = -res; } + if a.sign == .Negative { res = -res } } return } @@ -2326,7 +2326,7 @@ internal_int_shrmod :: proc(quotient, remainder, numerator: ^Int, bits: int, all context.allocator = allocator bits := bits - if bits < 0 { return .Invalid_Argument; } + if bits < 0 { return .Invalid_Argument } internal_copy(quotient, numerator) or_return @@ -2387,12 +2387,12 @@ internal_shr :: proc { internal_int_shr, } internal_int_shr_digit :: proc(quotient: ^Int, digits: int, allocator := context.allocator) -> (err: Error) { context.allocator = allocator - if digits <= 0 { return nil; } + if digits <= 0 { return nil } /* If digits > used simply zero and return. */ - if digits > quotient.used { return internal_zero(quotient); } + if digits > quotient.used { return internal_zero(quotient) } /* Much like `int_shl_digit`, this is implemented using a sliding window, @@ -2436,7 +2436,7 @@ internal_int_shl :: proc(dest, src: ^Int, bits: int, allocator := context.alloca bits := bits - if bits < 0 { return .Invalid_Argument; } + if bits < 0 { return .Invalid_Argument } internal_copy(dest, src) or_return @@ -2487,7 +2487,7 @@ internal_shl :: proc { internal_int_shl, } internal_int_shl_digit :: proc(quotient: ^Int, digits: int, allocator := context.allocator) -> (err: Error) { context.allocator = allocator - if digits <= 0 { return nil; } + if digits <= 0 { return nil } /* No need to shift a zero. @@ -2527,7 +2527,7 @@ internal_count_bits :: proc(a: ^Int) -> (count: int) { /* Fast path for zero. */ - if #force_inline internal_is_zero(a) { return {}; } + if #force_inline internal_is_zero(a) { return {} } /* Get the number of DIGITs and use it. */ @@ -2550,7 +2550,7 @@ internal_int_count_lsb :: proc(a: ^Int) -> (count: int, err: Error) { /* Easy out. */ - if #force_inline internal_is_zero(a) { return {}, nil; } + if #force_inline internal_is_zero(a) { return {}, nil } /* Scan lower digits until non-zero. @@ -2588,7 +2588,7 @@ internal_int_rand :: proc(dest: ^Int, bits: int, r: ^rnd.Rand = nil, allocator : bits := bits - if bits <= 0 { return .Invalid_Argument; } + if bits <= 0 { return .Invalid_Argument } digits := bits / _DIGIT_BITS bits %= _DIGIT_BITS @@ -2632,7 +2632,7 @@ internal_clear_if_uninitialized_multi :: proc(args: ..^Int, allocator := context for i in args { if ! #force_inline internal_is_initialized(i) { e := #force_inline internal_grow(i, _DEFAULT_DIGIT_COUNT) - if e != nil { err = e; } + if e != nil { err = e } } } return err @@ -2640,13 +2640,13 @@ internal_clear_if_uninitialized_multi :: proc(args: ..^Int, allocator := context internal_clear_if_uninitialized :: proc {internal_clear_if_uninitialized_single, internal_clear_if_uninitialized_multi, } internal_error_if_immutable_single :: proc(arg: ^Int) -> (err: Error) { - if arg != nil && .Immutable in arg.flags { return .Assignment_To_Immutable; } + if arg != nil && .Immutable in arg.flags { return .Assignment_To_Immutable } return nil } internal_error_if_immutable_multi :: proc(args: ..^Int) -> (err: Error) { for i in args { - if i != nil && .Immutable in i.flags { return .Assignment_To_Immutable; } + if i != nil && .Immutable in i.flags { return .Assignment_To_Immutable } } return nil } @@ -2674,9 +2674,9 @@ internal_init_multi :: proc { internal_int_init_multi, } Typically very fast. Also fixes the sign if there are no more leading digits. */ internal_clamp :: proc(a: ^Int) -> (err: Error) { - for a.used > 0 && a.digit[a.used - 1] == 0 { a.used -= 1; } + for a.used > 0 && a.digit[a.used - 1] == 0 { a.used -= 1 } - if #force_inline internal_is_zero(a) { a.sign = .Zero_or_Positive; } + if #force_inline internal_is_zero(a) { a.sign = .Zero_or_Positive } return nil } diff --git a/core/math/big/logical.odin b/core/math/big/logical.odin index d455d480d..008450319 100644 --- a/core/math/big/logical.odin +++ b/core/math/big/logical.odin @@ -77,7 +77,7 @@ int_shrmod :: proc(quotient, remainder, numerator: ^Int, bits: int, allocator := assert_if_nil(quotient, numerator) context.allocator = allocator - if err = internal_clear_if_uninitialized(quotient, numerator); err != nil { return err; } + if err = internal_clear_if_uninitialized(quotient, numerator); err != nil { return err } return #force_inline internal_int_shrmod(quotient, remainder, numerator, bits) } shrmod :: proc { int_shrmod, } diff --git a/core/math/big/prime.odin b/core/math/big/prime.odin index b943da83b..f78c1894c 100644 --- a/core/math/big/prime.odin +++ b/core/math/big/prime.odin @@ -183,7 +183,7 @@ internal_int_montgomery_setup :: proc(n: ^Int) -> (rho: DIGIT, err: Error) { => 2*(1) - (1) = 1 */ b := n.digit[0] - if b & 1 == 0 { return 0, .Invalid_Argument; } + if b & 1 == 0 { return 0, .Invalid_Argument } x := (((b + 2) & 4) << 1) + b /* here x*a==1 mod 2**4 */ x *= 2 - (b * x) /* here x*a==1 mod 2**8 */ diff --git a/core/math/big/private.odin b/core/math/big/private.odin index f0d73a008..241cd7441 100644 --- a/core/math/big/private.odin +++ b/core/math/big/private.odin @@ -1088,7 +1088,7 @@ _private_int_div_school :: proc(quotient, remainder, numerator, denominator: ^In Step 3. for i from n down to (t + 1).
*/
#no_bounds_check for i := n; i >= (t + 1); i -= 1 {
- if (i > x.used) { continue; }
+ if (i > x.used) { continue }
/*
step 3.1 if xi == yt then set q{i-t-1} to b-1, otherwise set q{i-t-1} to (xi*b + x{i-1})/yt
@@ -1744,7 +1744,7 @@ _private_montgomery_reduce_comba :: proc(x, n: ^Int, rho: DIGIT, allocator := co context.allocator = allocator
W: [_WARRAY]_WORD = ---
- if x.used > _WARRAY { return .Invalid_Argument; }
+ if x.used > _WARRAY { return .Invalid_Argument }
/*
Get old used count.
@@ -2022,7 +2022,7 @@ _private_inverse_modulo_odd :: proc(dest, a, b: ^Int, allocator := context.alloc /*
2. [modified] `b` must be odd.
*/
- if internal_is_even(b) { return .Invalid_Argument; }
+ if internal_is_even(b) { return .Invalid_Argument }
/*
Init all our temps.
@@ -2042,7 +2042,7 @@ _private_inverse_modulo_odd :: proc(dest, a, b: ^Int, allocator := context.alloc /*
If one of `x`, `y` is zero return an error!
*/
- if internal_is_zero(x) || internal_is_zero(y) { return .Invalid_Argument; }
+ if internal_is_zero(x) || internal_is_zero(y) { return .Invalid_Argument }
/*
3. `u` = `x`, `v` = `y`, `A` = 1, `B` = 0, `C` = 0, `D` = 1
@@ -2122,7 +2122,7 @@ _private_inverse_modulo_odd :: proc(dest, a, b: ^Int, allocator := context.alloc /*
If not zero goto step 4.
*/
- if internal_is_zero(u) { break; }
+ if internal_is_zero(u) { break }
}
/*
diff --git a/core/math/big/public.odin b/core/math/big/public.odin index 9f82e618b..d7c6ec19c 100644 --- a/core/math/big/public.odin +++ b/core/math/big/public.odin @@ -120,7 +120,7 @@ int_double :: proc(dest, src: ^Int, allocator := context.allocator) -> (err: Err /*
Grow destination as required.
*/
- if dest != src { grow(dest, src.used + 1) or_return; }
+ if dest != src { grow(dest, src.used + 1) or_return }
return #force_inline internal_int_shl1(dest, src)
}
@@ -153,7 +153,7 @@ int_mul :: proc(dest, src, multiplier: ^Int, allocator := context.allocator) -> mul :: proc { int_mul, int_mul_digit, }
-sqr :: proc(dest, src: ^Int) -> (err: Error) { return mul(dest, src, src); }
+sqr :: proc(dest, src: ^Int) -> (err: Error) { return mul(dest, src, src) }
/*
divmod.
@@ -165,7 +165,7 @@ int_divmod :: proc(quotient, remainder, numerator, denominator: ^Int, allocator /*
Early out if neither of the results is wanted.
*/
- if quotient == nil && remainder == nil { return nil; }
+ if quotient == nil && remainder == nil { return nil }
internal_clear_if_uninitialized(numerator, denominator) or_return
return #force_inline internal_divmod(quotient, remainder, numerator, denominator)
@@ -275,7 +275,7 @@ sqrmod :: proc { int_sqrmod, } int_factorial :: proc(res: ^Int, n: int, allocator := context.allocator) -> (err: Error) {
- if n < 0 || n > FACTORIAL_MAX_N { return .Invalid_Argument; }
+ if n < 0 || n > FACTORIAL_MAX_N { return .Invalid_Argument }
assert_if_nil(res)
return #force_inline internal_int_factorial(res, n, allocator)
@@ -302,8 +302,8 @@ int_choose_digit :: proc(res: ^Int, n, k: int, allocator := context.allocator) - assert_if_nil(res)
context.allocator = allocator
- if n < 0 || n > FACTORIAL_MAX_N { return .Invalid_Argument; }
- if k > n { return internal_zero(res); }
+ if n < 0 || n > FACTORIAL_MAX_N { return .Invalid_Argument }
+ if k > n { return internal_zero(res) }
/*
res = n! / (k! * (n - k)!)
@@ -326,7 +326,7 @@ choose :: proc { int_choose_digit, } Function computing both GCD and (if target isn't `nil`) also LCM.
*/
int_gcd_lcm :: proc(res_gcd, res_lcm, a, b: ^Int, allocator := context.allocator) -> (err: Error) {
- if res_gcd == nil && res_lcm == nil { return nil; }
+ if res_gcd == nil && res_lcm == nil { return nil }
assert_if_nil(a, b)
context.allocator = allocator
@@ -359,7 +359,7 @@ int_mod_bits :: proc(remainder, numerator: ^Int, bits: int, allocator := context context.allocator = allocator
internal_clear_if_uninitialized(remainder, numerator) or_return
- if bits < 0 { return .Invalid_Argument; }
+ if bits < 0 { return .Invalid_Argument }
return #force_inline internal_int_mod_bits(remainder, numerator, bits)
}
@@ -439,7 +439,7 @@ int_root_n :: proc(dest, src: ^Int, n: int, allocator := context.allocator) -> ( /*
Fast path for n == 2.
*/
- if n == 2 { return sqrt(dest, src); }
+ if n == 2 { return sqrt(dest, src) }
assert_if_nil(dest, src)
/*
@@ -456,7 +456,7 @@ root_n :: proc { int_root_n, } */
int_is_initialized :: proc(a: ^Int) -> bool {
- if a == nil { return false; }
+ if a == nil { return false }
return #force_inline internal_int_is_initialized(a)
}
diff --git a/core/math/big/radix.odin b/core/math/big/radix.odin index 8908f7775..f0a80d7b2 100644 --- a/core/math/big/radix.odin +++ b/core/math/big/radix.odin @@ -244,7 +244,7 @@ int_atoi :: proc(res: ^Int, input: string, radix := i8(10), allocator := context Make sure the radix is ok. */ - if radix < 2 || radix > 64 { return .Invalid_Argument; } + if radix < 2 || radix > 64 { return .Invalid_Argument } /* Set the integer to the default of zero. @@ -327,7 +327,7 @@ radix_size :: proc(a: ^Int, radix: i8, zero_terminate := false, allocator := con a := a assert_if_nil(a) - if radix < 2 || radix > 64 { return -1, .Invalid_Argument; } + if radix < 2 || radix > 64 { return -1, .Invalid_Argument } clear_if_uninitialized(a) or_return if internal_is_zero(a) { diff --git a/core/math/big/test.odin b/core/math/big/test.odin index 8a48962cb..76cb6b7ef 100644 --- a/core/math/big/test.odin +++ b/core/math/big/test.odin @@ -44,17 +44,17 @@ PyRes :: struct { aa, bb, sum := &Int{}, &Int{}, &Int{} defer internal_destroy(aa, bb, sum) - if err = atoi(aa, string(a), 16); err != nil { return PyRes{res=":add:atoi(a):", err=err}; } - if err = atoi(bb, string(b), 16); err != nil { return PyRes{res=":add:atoi(b):", err=err}; } + if err = atoi(aa, string(a), 16); err != nil { return PyRes{res=":add:atoi(a):", err=err} } + if err = atoi(bb, string(b), 16); err != nil { return PyRes{res=":add:atoi(b):", err=err} } if bb.used == 1 { - if err = #force_inline internal_add(sum, aa, bb.digit[0]); err != nil { return PyRes{res=":add:add(sum,a,b):", err=err}; } + if err = #force_inline internal_add(sum, aa, bb.digit[0]); err != nil { return PyRes{res=":add:add(sum,a,b):", err=err} } } else { - if err = #force_inline internal_add(sum, aa, bb); err != nil { return PyRes{res=":add:add(sum,a,b):", err=err}; } + if err = #force_inline internal_add(sum, aa, bb); err != nil { return PyRes{res=":add:add(sum,a,b):", err=err} } } r: cstring r, err = int_itoa_cstring(sum, 16, context.temp_allocator) - if err != nil { return PyRes{res=":add:itoa(sum):", err=err}; } + if err != nil { return PyRes{res=":add:itoa(sum):", err=err} } return PyRes{res = r, err = nil} } @@ -65,17 +65,17 @@ PyRes :: struct { aa, bb, sum := &Int{}, &Int{}, &Int{} defer internal_destroy(aa, bb, sum) - if err = atoi(aa, string(a), 16); err != nil { return PyRes{res=":sub:atoi(a):", err=err}; } - if err = atoi(bb, string(b), 16); err != nil { return PyRes{res=":sub:atoi(b):", err=err}; } + if err = atoi(aa, string(a), 16); err != nil { return PyRes{res=":sub:atoi(a):", err=err} } + if err = atoi(bb, string(b), 16); err != nil { return PyRes{res=":sub:atoi(b):", err=err} } if bb.used == 1 { - if err = #force_inline internal_sub(sum, aa, bb.digit[0]); err != nil { return PyRes{res=":sub:sub(sum,a,b):", err=err}; } + if err = #force_inline internal_sub(sum, aa, bb.digit[0]); err != nil { return PyRes{res=":sub:sub(sum,a,b):", err=err} } } else { - if err = #force_inline internal_sub(sum, aa, bb); err != nil { return PyRes{res=":sub:sub(sum,a,b):", err=err}; } + if err = #force_inline internal_sub(sum, aa, bb); err != nil { return PyRes{res=":sub:sub(sum,a,b):", err=err} } } r: cstring r, err = int_itoa_cstring(sum, 16, context.temp_allocator) - if err != nil { return PyRes{res=":sub:itoa(sum):", err=err}; } + if err != nil { return PyRes{res=":sub:itoa(sum):", err=err} } return PyRes{res = r, err = nil} } @@ -86,13 +86,13 @@ PyRes :: struct { aa, bb, product := &Int{}, &Int{}, &Int{} defer internal_destroy(aa, bb, product) - if err = atoi(aa, string(a), 16); err != nil { return PyRes{res=":mul:atoi(a):", err=err}; } - if err = atoi(bb, string(b), 16); err != nil { return PyRes{res=":mul:atoi(b):", err=err}; } - if err = #force_inline internal_mul(product, aa, bb); err != nil { return PyRes{res=":mul:mul(product,a,b):", err=err}; } + if err = atoi(aa, string(a), 16); err != nil { return PyRes{res=":mul:atoi(a):", err=err} } + if err = atoi(bb, string(b), 16); err != nil { return PyRes{res=":mul:atoi(b):", err=err} } + if err = #force_inline internal_mul(product, aa, bb); err != nil { return PyRes{res=":mul:mul(product,a,b):", err=err} } r: cstring r, err = int_itoa_cstring(product, 16, context.temp_allocator) - if err != nil { return PyRes{res=":mul:itoa(product):", err=err}; } + if err != nil { return PyRes{res=":mul:itoa(product):", err=err} } return PyRes{res = r, err = nil} } @@ -103,12 +103,12 @@ PyRes :: struct { aa, square := &Int{}, &Int{} defer internal_destroy(aa, square) - if err = atoi(aa, string(a), 16); err != nil { return PyRes{res=":sqr:atoi(a):", err=err}; } - if err = #force_inline internal_sqr(square, aa); err != nil { return PyRes{res=":sqr:sqr(square,a):", err=err}; } + if err = atoi(aa, string(a), 16); err != nil { return PyRes{res=":sqr:atoi(a):", err=err} } + if err = #force_inline internal_sqr(square, aa); err != nil { return PyRes{res=":sqr:sqr(square,a):", err=err} } r: cstring r, err = int_itoa_cstring(square, 16, context.temp_allocator) - if err != nil { return PyRes{res=":sqr:itoa(square):", err=err}; } + if err != nil { return PyRes{res=":sqr:itoa(square):", err=err} } return PyRes{res = r, err = nil} } @@ -122,13 +122,13 @@ PyRes :: struct { aa, bb, quotient := &Int{}, &Int{}, &Int{} defer internal_destroy(aa, bb, quotient) - if err = atoi(aa, string(a), 16); err != nil { return PyRes{res=":div:atoi(a):", err=err}; } - if err = atoi(bb, string(b), 16); err != nil { return PyRes{res=":div:atoi(b):", err=err}; } - if err = #force_inline internal_div(quotient, aa, bb); err != nil { return PyRes{res=":div:div(quotient,a,b):", err=err}; } + if err = atoi(aa, string(a), 16); err != nil { return PyRes{res=":div:atoi(a):", err=err} } + if err = atoi(bb, string(b), 16); err != nil { return PyRes{res=":div:atoi(b):", err=err} } + if err = #force_inline internal_div(quotient, aa, bb); err != nil { return PyRes{res=":div:div(quotient,a,b):", err=err} } r: cstring r, err = int_itoa_cstring(quotient, 16, context.temp_allocator) - if err != nil { return PyRes{res=":div:itoa(quotient):", err=err}; } + if err != nil { return PyRes{res=":div:itoa(quotient):", err=err} } return PyRes{res = r, err = nil} } @@ -144,8 +144,8 @@ PyRes :: struct { aa := &Int{} defer internal_destroy(aa) - if err = atoi(aa, string(a), 16); err != nil { return PyRes{res=":log:atoi(a):", err=err}; } - if l, err = #force_inline internal_log(aa, base); err != nil { return PyRes{res=":log:log(a, base):", err=err}; } + if err = atoi(aa, string(a), 16); err != nil { return PyRes{res=":log:atoi(a):", err=err} } + if l, err = #force_inline internal_log(aa, base); err != nil { return PyRes{res=":log:log(a, base):", err=err} } #force_inline internal_zero(aa) aa.digit[0] = DIGIT(l) & _MASK @@ -155,7 +155,7 @@ PyRes :: struct { r: cstring r, err = int_itoa_cstring(aa, 16, context.temp_allocator) - if err != nil { return PyRes{res=":log:itoa(res):", err=err}; } + if err != nil { return PyRes{res=":log:itoa(res):", err=err} } return PyRes{res = r, err = nil} } @@ -169,12 +169,12 @@ PyRes :: struct { dest, bb := &Int{}, &Int{} defer internal_destroy(dest, bb) - if err = atoi(bb, string(base), 16); err != nil { return PyRes{res=":pow:atoi(base):", err=err}; } - if err = #force_inline internal_pow(dest, bb, power); err != nil { return PyRes{res=":pow:pow(dest, base, power):", err=err}; } + if err = atoi(bb, string(base), 16); err != nil { return PyRes{res=":pow:atoi(base):", err=err} } + if err = #force_inline internal_pow(dest, bb, power); err != nil { return PyRes{res=":pow:pow(dest, base, power):", err=err} } r: cstring r, err = int_itoa_cstring(dest, 16, context.temp_allocator) - if err != nil { return PyRes{res=":log:itoa(res):", err=err}; } + if err != nil { return PyRes{res=":log:itoa(res):", err=err} } return PyRes{res = r, err = nil} } @@ -188,12 +188,12 @@ PyRes :: struct { src := &Int{} defer internal_destroy(src) - if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":sqrt:atoi(src):", err=err}; } - if err = #force_inline internal_sqrt(src, src); err != nil { return PyRes{res=":sqrt:sqrt(src):", err=err}; } + if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":sqrt:atoi(src):", err=err} } + if err = #force_inline internal_sqrt(src, src); err != nil { return PyRes{res=":sqrt:sqrt(src):", err=err} } r: cstring r, err = int_itoa_cstring(src, 16, context.temp_allocator) - if err != nil { return PyRes{res=":log:itoa(res):", err=err}; } + if err != nil { return PyRes{res=":log:itoa(res):", err=err} } return PyRes{res = r, err = nil} } @@ -207,12 +207,12 @@ PyRes :: struct { src := &Int{} defer internal_destroy(src) - if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":root_n:atoi(src):", err=err}; } - if err = #force_inline internal_root_n(src, src, power); err != nil { return PyRes{res=":root_n:root_n(src):", err=err}; } + if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":root_n:atoi(src):", err=err} } + if err = #force_inline internal_root_n(src, src, power); err != nil { return PyRes{res=":root_n:root_n(src):", err=err} } r: cstring r, err = int_itoa_cstring(src, 16, context.temp_allocator) - if err != nil { return PyRes{res=":root_n:itoa(res):", err=err}; } + if err != nil { return PyRes{res=":root_n:itoa(res):", err=err} } return PyRes{res = r, err = nil} } @@ -226,12 +226,12 @@ PyRes :: struct { src := &Int{} defer internal_destroy(src) - if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":shr_digit:atoi(src):", err=err}; } - if err = #force_inline internal_shr_digit(src, digits); err != nil { return PyRes{res=":shr_digit:shr_digit(src):", err=err}; } + if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":shr_digit:atoi(src):", err=err} } + if err = #force_inline internal_shr_digit(src, digits); err != nil { return PyRes{res=":shr_digit:shr_digit(src):", err=err} } r: cstring r, err = int_itoa_cstring(src, 16, context.temp_allocator) - if err != nil { return PyRes{res=":shr_digit:itoa(res):", err=err}; } + if err != nil { return PyRes{res=":shr_digit:itoa(res):", err=err} } return PyRes{res = r, err = nil} } @@ -245,12 +245,12 @@ PyRes :: struct { src := &Int{} defer internal_destroy(src) - if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":shl_digit:atoi(src):", err=err}; } - if err = #force_inline internal_shl_digit(src, digits); err != nil { return PyRes{res=":shl_digit:shr_digit(src):", err=err}; } + if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":shl_digit:atoi(src):", err=err} } + if err = #force_inline internal_shl_digit(src, digits); err != nil { return PyRes{res=":shl_digit:shr_digit(src):", err=err} } r: cstring r, err = int_itoa_cstring(src, 16, context.temp_allocator) - if err != nil { return PyRes{res=":shl_digit:itoa(res):", err=err}; } + if err != nil { return PyRes{res=":shl_digit:itoa(res):", err=err} } return PyRes{res = r, err = nil} } @@ -264,12 +264,12 @@ PyRes :: struct { src := &Int{} defer internal_destroy(src) - if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":shr:atoi(src):", err=err}; } - if err = #force_inline internal_shr(src, src, bits); err != nil { return PyRes{res=":shr:shr(src, bits):", err=err}; } + if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":shr:atoi(src):", err=err} } + if err = #force_inline internal_shr(src, src, bits); err != nil { return PyRes{res=":shr:shr(src, bits):", err=err} } r: cstring r, err = int_itoa_cstring(src, 16, context.temp_allocator) - if err != nil { return PyRes{res=":shr:itoa(res):", err=err}; } + if err != nil { return PyRes{res=":shr:itoa(res):", err=err} } return PyRes{res = r, err = nil} } @@ -283,12 +283,12 @@ PyRes :: struct { src := &Int{} defer internal_destroy(src) - if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":shr_signed:atoi(src):", err=err}; } - if err = #force_inline internal_shr_signed(src, src, bits); err != nil { return PyRes{res=":shr_signed:shr_signed(src, bits):", err=err}; } + if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":shr_signed:atoi(src):", err=err} } + if err = #force_inline internal_shr_signed(src, src, bits); err != nil { return PyRes{res=":shr_signed:shr_signed(src, bits):", err=err} } r: cstring r, err = int_itoa_cstring(src, 16, context.temp_allocator) - if err != nil { return PyRes{res=":shr_signed:itoa(res):", err=err}; } + if err != nil { return PyRes{res=":shr_signed:itoa(res):", err=err} } return PyRes{res = r, err = nil} } @@ -302,12 +302,12 @@ PyRes :: struct { src := &Int{} defer internal_destroy(src) - if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":shl:atoi(src):", err=err}; } - if err = #force_inline internal_shl(src, src, bits); err != nil { return PyRes{res=":shl:shl(src, bits):", err=err}; } + if err = atoi(src, string(source), 16); err != nil { return PyRes{res=":shl:atoi(src):", err=err} } + if err = #force_inline internal_shl(src, src, bits); err != nil { return PyRes{res=":shl:shl(src, bits):", err=err} } r: cstring r, err = int_itoa_cstring(src, 16, context.temp_allocator) - if err != nil { return PyRes{res=":shl:itoa(res):", err=err}; } + if err != nil { return PyRes{res=":shl:itoa(res):", err=err} } return PyRes{res = r, err = nil} } @@ -321,11 +321,11 @@ PyRes :: struct { dest := &Int{} defer internal_destroy(dest) - if err = #force_inline internal_int_factorial(dest, n); err != nil { return PyRes{res=":factorial:factorial(n):", err=err}; } + if err = #force_inline internal_int_factorial(dest, n); err != nil { return PyRes{res=":factorial:factorial(n):", err=err} } r: cstring r, err = int_itoa_cstring(dest, 16, context.temp_allocator) - if err != nil { return PyRes{res=":factorial:itoa(res):", err=err}; } + if err != nil { return PyRes{res=":factorial:itoa(res):", err=err} } return PyRes{res = r, err = nil} } @@ -339,13 +339,13 @@ PyRes :: struct { ai, bi, dest := &Int{}, &Int{}, &Int{} defer internal_destroy(ai, bi, dest) - if err = atoi(ai, string(a), 16); err != nil { return PyRes{res=":gcd:atoi(a):", err=err}; } - if err = atoi(bi, string(b), 16); err != nil { return PyRes{res=":gcd:atoi(b):", err=err}; } - if err = #force_inline internal_int_gcd_lcm(dest, nil, ai, bi); err != nil { return PyRes{res=":gcd:gcd(a, b):", err=err}; } + if err = atoi(ai, string(a), 16); err != nil { return PyRes{res=":gcd:atoi(a):", err=err} } + if err = atoi(bi, string(b), 16); err != nil { return PyRes{res=":gcd:atoi(b):", err=err} } + if err = #force_inline internal_int_gcd_lcm(dest, nil, ai, bi); err != nil { return PyRes{res=":gcd:gcd(a, b):", err=err} } r: cstring r, err = int_itoa_cstring(dest, 16, context.temp_allocator) - if err != nil { return PyRes{res=":gcd:itoa(res):", err=err}; } + if err != nil { return PyRes{res=":gcd:itoa(res):", err=err} } return PyRes{res = r, err = nil} } @@ -359,13 +359,13 @@ PyRes :: struct { ai, bi, dest := &Int{}, &Int{}, &Int{} defer internal_destroy(ai, bi, dest) - if err = atoi(ai, string(a), 16); err != nil { return PyRes{res=":lcm:atoi(a):", err=err}; } - if err = atoi(bi, string(b), 16); err != nil { return PyRes{res=":lcm:atoi(b):", err=err}; } - if err = #force_inline internal_int_gcd_lcm(nil, dest, ai, bi); err != nil { return PyRes{res=":lcm:lcm(a, b):", err=err}; } + if err = atoi(ai, string(a), 16); err != nil { return PyRes{res=":lcm:atoi(a):", err=err} } + if err = atoi(bi, string(b), 16); err != nil { return PyRes{res=":lcm:atoi(b):", err=err} } + if err = #force_inline internal_int_gcd_lcm(nil, dest, ai, bi); err != nil { return PyRes{res=":lcm:lcm(a, b):", err=err} } r: cstring r, err = int_itoa_cstring(dest, 16, context.temp_allocator) - if err != nil { return PyRes{res=":lcm:itoa(res):", err=err}; } + if err != nil { return PyRes{res=":lcm:itoa(res):", err=err} } return PyRes{res = r, err = nil} } @@ -380,8 +380,8 @@ PyRes :: struct { ai := &Int{} defer internal_destroy(ai) - if err = atoi(ai, string(a), 16); err != nil { return PyRes{res=":is_square:atoi(a):", err=err}; } - if square, err = #force_inline internal_int_is_square(ai); err != nil { return PyRes{res=":is_square:is_square(a):", err=err}; } + if err = atoi(ai, string(a), 16); err != nil { return PyRes{res=":is_square:atoi(a):", err=err} } + if square, err = #force_inline internal_int_is_square(ai); err != nil { return PyRes{res=":is_square:is_square(a):", err=err} } if square { return PyRes{"True", nil} |