use super::PolyOverZ;
use crate::macros::unsafe_passthrough::{unsafe_getter, unsafe_setter};
use flint_sys::fmpz_poly::{fmpz_poly_clear, fmpz_poly_struct};
unsafe_getter!(PolyOverZ, poly, fmpz_poly_struct);
unsafe_setter!(PolyOverZ, poly, fmpz_poly_struct, fmpz_poly_clear);
#[cfg(test)]
mod test_get_fmpz_poly_struct {
use super::PolyOverZ;
use flint_sys::{fmpz::fmpz, fmpz_poly::fmpz_poly_set_fmpz};
#[test]
#[allow(unused_mut)]
fn availability_and_modification() {
let mut poly = PolyOverZ::from(1);
let mut fmpz_poly = unsafe { poly.get_fmpz_poly_struct() };
unsafe { fmpz_poly_set_fmpz(fmpz_poly, &fmpz(2)) };
assert_eq!(PolyOverZ::from(2), poly);
}
}
#[cfg(test)]
mod test_set_fmpz_poly_struct {
use super::PolyOverZ;
use flint_sys::fmpz_poly::fmpz_poly_init;
use std::mem::MaybeUninit;
#[test]
#[allow(unused_mut)]
fn availability_and_modification() {
let mut poly = PolyOverZ::from(1);
let mut flint_struct = MaybeUninit::uninit();
let flint_struct = unsafe {
fmpz_poly_init(flint_struct.as_mut_ptr());
flint_struct.assume_init()
};
unsafe { poly.set_fmpz_poly_struct(flint_struct) };
assert_eq!(PolyOverZ::default(), poly);
}
}