diff --git a/sway-lib-std/src/math.sw b/sway-lib-std/src/math.sw index a52627693ff..6ffd4071865 100644 --- a/sway-lib-std/src/math.sw +++ b/sway-lib-std/src/math.sw @@ -339,10 +339,18 @@ impl Logarithm for u256 { assert(base >= 2); // Logarithm is undefined for 0 assert(self != 0); + } else { + // Logarithm is undefined for bases less than 2 + // Logarithm is undefined for 0 + if (base < 2) || (self == 0) { + set_flags(flags); + return 0x00u256; + } } // Decimals rounded to 0 if self < base { + set_flags(flags); return 0x00u256; } diff --git a/test/src/in_language_tests/test_programs/bytes_inline_tests/src/main.sw b/test/src/in_language_tests/test_programs/bytes_inline_tests/src/main.sw index 9a0b0eae392..65597943ef7 100644 --- a/test/src/in_language_tests/test_programs/bytes_inline_tests/src/main.sw +++ b/test/src/in_language_tests/test_programs/bytes_inline_tests/src/main.sw @@ -716,7 +716,7 @@ fn bytes_append() { assert(bytes2.len() == second_length); assert(!bytes2.is_empty()); - + assert(bytes2.get(0).unwrap() == d); assert(bytes2.get(1).unwrap() == e); assert(bytes2.get(2).unwrap() == f); diff --git a/test/src/in_language_tests/test_programs/math_inline_tests/src/main.sw b/test/src/in_language_tests/test_programs/math_inline_tests/src/main.sw index b294d52788b..c2641d71272 100644 --- a/test/src/in_language_tests/test_programs/math_inline_tests/src/main.sw +++ b/test/src/in_language_tests/test_programs/math_inline_tests/src/main.sw @@ -1,6 +1,6 @@ library; -use std::flags::disable_panic_on_overflow; +use std::{flags::{disable_panic_on_overflow, disable_panic_on_unsafe_math}, registers::flags}; #[test] fn math_root_u256() { @@ -272,6 +272,7 @@ fn math_log_u8() { #[test] fn math_log_u256() { let max_u256 = u256::max(); + let prior_flags = flags(); assert(0x2u256.log(0x2u256) == 0x1u256); assert(0x1u256.log(0x3u256) == 0); assert(0x8u256.log(0x2u256) == 0x3u256); @@ -279,6 +280,13 @@ fn math_log_u256() { assert(0x64u256.log(0x2u256) == 0x6u256); assert(0x64u256.log(0x9u256) == 0x2u256); assert(max_u256.log(0x2u256) == 0xffu256); + assert(prior_flags == flags()); + + let _ = disable_panic_on_unsafe_math(); + let prior_flags = flags(); + assert(0x1u256.log(0x1u256) == 0); + assert(0x0u256.log(0x3u256) == 0); + assert(prior_flags == flags()); } #[test]