use super::Modulus;
use crate::macros::unsafe_passthrough::unsafe_getter_mod;
use flint_sys::fmpz_mod::{fmpz_mod_ctx, fmpz_mod_ctx_clear};
unsafe_getter_mod!(Modulus, modulus, fmpz_mod_ctx);
impl Modulus {
pub unsafe fn set_fmpz_mod_ctx(&mut self, flint_struct: fmpz_mod_ctx) {
let modulus = std::rc::Rc::<fmpz_mod_ctx>::get_mut(&mut self.modulus).unwrap();
unsafe { fmpz_mod_ctx_clear(modulus) };
modulus.add_fxn = flint_struct.add_fxn;
modulus.mod_ = flint_struct.mod_;
modulus.mul_fxn = flint_struct.mul_fxn;
modulus.n = flint_struct.n;
modulus.n_limbs = flint_struct.n_limbs;
modulus.ninv_limbs = flint_struct.ninv_limbs;
modulus.sub_fxn = flint_struct.sub_fxn;
}
}
#[cfg(test)]
mod test_get_fmpz_mod_ctx {
use super::Modulus;
#[test]
#[allow(unused_mut)]
fn availability_and_modification() {
let mut modulus = Modulus::from(3);
let mut fmpz_mod = unsafe { modulus.get_fmpz_mod_ctx() };
fmpz_mod.n[0].0 = 2;
assert_eq!(Modulus::from(2), modulus);
}
}
#[cfg(test)]
mod test_set_fmpz_mod_ctx {
use super::Modulus;
use flint_sys::{fmpz::fmpz, fmpz_mod::fmpz_mod_ctx_init};
use std::mem::MaybeUninit;
#[test]
#[allow(unused_mut)]
fn availability_and_modification() {
let mut modulus = Modulus::from(3);
let mut flint_struct = MaybeUninit::uninit();
let mut flint_struct = unsafe {
fmpz_mod_ctx_init(flint_struct.as_mut_ptr(), &fmpz(2));
flint_struct.assume_init()
};
unsafe { modulus.set_fmpz_mod_ctx(flint_struct) };
assert_eq!(Modulus::from(2), modulus);
}
}