#![forbid(unsafe_code)]
#![cfg_attr(not(test), warn(unused_crate_dependencies, unused_extern_crates))]
mod field_element;
mod generic_ark;
pub use generic_ark::AcirField;
pub use field_element::FieldElement as GenericFieldElement;
use num_bigint::BigInt;
pub fn truncate_to<F: AcirField>(input: &F, bits: u32) -> F {
let num_bits = input.num_bits();
if bits >= num_bits {
*input
} else if num_bits < 128 {
let mask = 2u128.pow(bits) - 1;
F::from(input.to_u128() & mask)
} else {
let input_int = BigInt::from_bytes_be(num_bigint::Sign::Plus, &input.to_be_bytes());
let modulus = BigInt::from(2u32).pow(bits);
let result = input_int % modulus;
F::from_be_bytes_reduce(&result.to_bytes_be().1)
}
}
cfg_if::cfg_if! {
if #[cfg(feature = "bls12_381")] {
pub type FieldElement = field_element::FieldElement<ark_bls12_381::Fr>;
} else {
pub type FieldElement = field_element::FieldElement<ark_bn254::Fr>;
}
}
#[macro_export]
macro_rules! assert_unique_feature {
() => {};
($first:tt $(,$rest:tt)*) => {
$(
#[cfg(all(feature = $first, feature = $rest))]
compile_error!(concat!("features \"", $first, "\" and \"", $rest, "\" cannot be used together"));
)*
assert_unique_feature!($($rest),*);
}
}
assert_unique_feature!("bn254", "bls12_381");