1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
use crate::algorithms::factorization::is_prime as is_prime_algo;
pub trait Primality {
fn is_irreducible(&self) -> bool;
fn is_prime(&self) -> bool;
}
macro_rules! impl_primality {
($($set:ty)*) => {
$(
impl Primality for $set {
#[inline]
fn is_irreducible(&self) -> bool {
unimplemented!()
}
#[inline]
fn is_prime(&self) -> bool {
is_prime_algo(*self as u64)
}
}
)*
}
}
impl_primality!(u8 u16 u32 u64 u128 usize i8 i16 i32 i64 i128 isize f32 f64);