From a1f9c949825bac1068a4e00e93e95b0dbfa8b5a7 Mon Sep 17 00:00:00 2001 From: guipublic <47281315+guipublic@users.noreply.github.com> Date: Mon, 23 Dec 2024 18:00:44 +0100 Subject: [PATCH] fix: bigint builtins are foreigns (#6892) --- .../src/hir/comptime/interpreter/builtin.rs | 5 +---- .../noir/standard_library/containers/boundedvec.md | 4 ++-- noir_stdlib/src/bigint.nr | 12 ++++++------ 3 files changed, 9 insertions(+), 12 deletions(-) diff --git a/compiler/noirc_frontend/src/hir/comptime/interpreter/builtin.rs b/compiler/noirc_frontend/src/hir/comptime/interpreter/builtin.rs index 3d8ccf78926..a1d244d9aca 100644 --- a/compiler/noirc_frontend/src/hir/comptime/interpreter/builtin.rs +++ b/compiler/noirc_frontend/src/hir/comptime/interpreter/builtin.rs @@ -1,6 +1,6 @@ use std::rc::Rc; -use acvm::{acir::BlackBoxFunc, AcirField, FieldElement}; +use acvm::{AcirField, FieldElement}; use builtin_helpers::{ block_expression_to_value, byte_array_type, check_argument_count, check_function_not_yet_resolved, check_one_argument, check_three_arguments, @@ -236,9 +236,6 @@ impl<'local, 'context> Interpreter<'local, 'context> { "unresolved_type_is_field" => unresolved_type_is_field(interner, arguments, location), "unresolved_type_is_unit" => unresolved_type_is_unit(interner, arguments, location), "zeroed" => zeroed(return_type, location.span), - blackbox if BlackBoxFunc::is_valid_black_box_func_name(blackbox) => { - self.call_foreign(blackbox, arguments, return_type, location) - } _ => { let item = format!("Comptime evaluation for builtin function '{name}'"); Err(InterpreterError::Unimplemented { item, location }) diff --git a/docs/versioned_docs/version-v1.0.0-beta.1/noir/standard_library/containers/boundedvec.md b/docs/versioned_docs/version-v1.0.0-beta.1/noir/standard_library/containers/boundedvec.md index 1453a99e86e..dad25f26717 100644 --- a/docs/versioned_docs/version-v1.0.0-beta.1/noir/standard_library/containers/boundedvec.md +++ b/docs/versioned_docs/version-v1.0.0-beta.1/noir/standard_library/containers/boundedvec.md @@ -400,7 +400,7 @@ let vec: BoundedVec = BoundedVec::from_parts([1, 2, 3, 0], 3); assert_eq(vec.len(), 3); // Any elements past the given length are zeroed out, so these - // two BoundedVecs will be completely equal + // two vectors will be completely equal let vec1: BoundedVec = BoundedVec::from_parts([1, 2, 3, 1], 3); let vec2: BoundedVec = BoundedVec::from_parts([1, 2, 3, 2], 3); assert_eq(vec1, vec2); @@ -433,7 +433,7 @@ let vec: BoundedVec = BoundedVec::from_parts_unchecked([1, 2, 3, 0], 3); let vec1: BoundedVec = BoundedVec::from_parts_unchecked([1, 2, 3, 1], 3); let vec2: BoundedVec = BoundedVec::from_parts_unchecked([1, 2, 3, 2], 3); - // both vecs have length 3 so we'd expect them to be equal, but this + // both vectors have length 3 so we'd expect them to be equal, but this // fails because elements past the length are still checked in eq assert(vec1 != vec2); ``` diff --git a/noir_stdlib/src/bigint.nr b/noir_stdlib/src/bigint.nr index c94a7a75f25..6ce3ea7d72a 100644 --- a/noir_stdlib/src/bigint.nr +++ b/noir_stdlib/src/bigint.nr @@ -33,17 +33,17 @@ pub struct BigInt { // docs:end:big_int_definition impl BigInt { - #[builtin(bigint_add)] + #[foreign(bigint_add)] fn bigint_add(self, other: BigInt) -> BigInt {} - #[builtin(bigint_sub)] + #[foreign(bigint_sub)] fn bigint_sub(self, other: BigInt) -> BigInt {} - #[builtin(bigint_mul)] + #[foreign(bigint_mul)] fn bigint_mul(self, other: BigInt) -> BigInt {} - #[builtin(bigint_div)] + #[foreign(bigint_div)] fn bigint_div(self, other: BigInt) -> BigInt {} - #[builtin(bigint_from_le_bytes)] + #[foreign(bigint_from_le_bytes)] fn from_le_bytes(bytes: [u8], modulus: [u8]) -> BigInt {} - #[builtin(bigint_to_le_bytes)] + #[foreign(bigint_to_le_bytes)] fn to_le_bytes(self) -> [u8; 32] {} fn check_32_bytes(self: Self, other: BigInt) -> bool {