use super::PolyOverZq;
use crate::macros::unsafe_passthrough::{
unsafe_getter, unsafe_getter_indirect, unsafe_setter_indirect,
};
use flint_sys::{
fmpz_mod::fmpz_mod_ctx,
fmpz_mod_poly::{fmpz_mod_poly_clear, fmpz_mod_poly_struct},
};
unsafe_getter!(PolyOverZq, poly, fmpz_mod_poly_struct);
unsafe_getter_indirect!(PolyOverZq, modulus, get_fmpz_mod_ctx, fmpz_mod_ctx);
impl PolyOverZq {
pub unsafe fn set_fmpz_mod_poly_struct(&mut self, flint_struct: fmpz_mod_poly_struct) {
unsafe { fmpz_mod_poly_clear(&mut self.poly, self.modulus.get_fmpz_mod_ctx_struct()) };
self.poly = flint_struct;
}
}
unsafe_setter_indirect!(PolyOverZq, modulus, set_fmpz_mod_ctx, fmpz_mod_ctx);
#[cfg(test)]
mod test_get_fmpz_mod_poly_struct {
use super::PolyOverZq;
use flint_sys::fmpz_mod_poly::fmpz_mod_poly_set_ui;
#[test]
#[allow(unused_mut)]
fn availability_and_modification() {
let mut poly = PolyOverZq::from((3, 7));
let mut fmpz_poly = unsafe { poly.get_fmpz_mod_poly_struct() };
unsafe { fmpz_mod_poly_set_ui(fmpz_poly, 5, poly.get_fmpz_mod_ctx()) };
assert_eq!(PolyOverZq::from((5, 7)), poly);
}
}
#[cfg(test)]
mod test_set_fmpz_mod_poly_struct {
use super::PolyOverZq;
use crate::integer_mod_q::Modulus;
use flint_sys::fmpz_mod_poly::fmpz_mod_poly_init;
use std::mem::MaybeUninit;
#[test]
#[allow(unused_mut)]
fn availability_and_modification() {
let mut poly = PolyOverZq::from((3, 7));
let modulus = Modulus::from(7);
let mut flint_struct = MaybeUninit::uninit();
let flint_struct = unsafe {
fmpz_mod_poly_init(flint_struct.as_mut_ptr(), modulus.get_fmpz_mod_ctx_struct());
flint_struct.assume_init()
};
unsafe { poly.set_fmpz_mod_poly_struct(flint_struct) };
assert_eq!(PolyOverZq::from((0, 7)), poly);
}
}