memx 0.2.0

memory functions like libc memcmp(), memchr(), memmem(), memcpy(), memset()
Documentation
use super::{__m128i, __m256i};
use super::{_b16_eq, _b16_from_b32, _b16_value, _b32_eq, _b32_value};
use crate::utils::B1Dbl;

#[derive(Debug, Copy, Clone)]
pub(crate) struct MMB16Dbl {
    pub v1: __m128i,
    pub v2: __m128i,
}
impl MMB16Dbl {
    #[inline(always)]
    pub fn new(b1: u8, b2: u8) -> Self {
        Self {
            v1: unsafe { _b16_value(b1) },
            v2: unsafe { _b16_value(b2) },
        }
    }
}
impl PartialEq for MMB16Dbl {
    fn eq(&self, other: &Self) -> bool {
        let a = unsafe { _b16_eq(self.v1, other.v1) };
        let b = unsafe { _b16_eq(self.v2, other.v2) };
        a && b
    }
}

impl From<B1Dbl> for MMB16Dbl {
    fn from(cc: B1Dbl) -> Self {
        Self::new(cc.v1, cc.v2)
    }
}

#[derive(Debug, Copy, Clone)]
pub(crate) struct MMB32Dbl {
    pub v1: __m256i,
    pub v2: __m256i,
}
impl MMB32Dbl {
    #[inline(always)]
    pub fn new(b1: u8, b2: u8) -> Self {
        Self {
            v1: unsafe { _b32_value(b1) },
            v2: unsafe { _b32_value(b2) },
        }
    }
}
impl PartialEq for MMB32Dbl {
    fn eq(&self, other: &Self) -> bool {
        let a = unsafe { _b32_eq(self.v1, other.v1) };
        let b = unsafe { _b32_eq(self.v2, other.v2) };
        a && b
    }
}

impl From<B1Dbl> for MMB32Dbl {
    fn from(cc: B1Dbl) -> Self {
        Self::new(cc.v1, cc.v2)
    }
}

impl From<MMB32Dbl> for MMB16Dbl {
    fn from(cc: MMB32Dbl) -> Self {
        Self {
            v1: unsafe { _b16_from_b32(cc.v1) },
            v2: unsafe { _b16_from_b32(cc.v2) },
        }
    }
}

#[cfg(test)]
mod mini {
    #![allow(clippy::clone_on_copy)]
    use super::super::super::cpuid;
    use super::*;
    //
    #[test]
    fn t_b32() {
        if !cpuid::has_avx2() {
            return;
        }
        let a = MMB32Dbl::new(b'A', b'B');
        let b = a.clone();
        let c = a;
        assert_eq!(a, b);
        assert_eq!(a, c);
        assert_eq!(
            format!("{a:?}"),
            "MMB32Dbl { v1: __m256i(4702111234474983745, 4702111234474983745, 4702111234474983745, 4702111234474983745), v2: __m256i(4774451407313060418, 4774451407313060418, 4774451407313060418, 4774451407313060418) }"
        );
    }
    #[test]
    fn t_b16() {
        let a = MMB16Dbl::new(b'A', b'B');
        let b = a.clone();
        let c = a;
        assert_eq!(a, b);
        assert_eq!(a, c);
        assert_eq!(
            format!("{a:?}"),
            "MMB16Dbl { v1: __m128i(4702111234474983745, 4702111234474983745), v2: __m128i(4774451407313060418, 4774451407313060418) }"
        );
    }
    #[test]
    fn t_into() {
        if !cpuid::has_avx2() {
            return;
        }
        let a_b32 = MMB32Dbl::new(b'A', b'B');
        let a_b16: MMB16Dbl = a_b32.into();
        assert_eq!(a_b32, MMB32Dbl::new(b'A', b'B'));
        assert_eq!(a_b16, MMB16Dbl::new(b'A', b'B'));
    }
}