aboutsummaryrefslogtreecommitdiff
path: root/src/bool/coresimd/bvec3a.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/bool/coresimd/bvec3a.rs')
-rw-r--r--src/bool/coresimd/bvec3a.rs28
1 files changed, 26 insertions, 2 deletions
diff --git a/src/bool/coresimd/bvec3a.rs b/src/bool/coresimd/bvec3a.rs
index 79f3a57..5167672 100644
--- a/src/bool/coresimd/bvec3a.rs
+++ b/src/bool/coresimd/bvec3a.rs
@@ -6,6 +6,7 @@ use core::ops::*;
use core::simd::*;
+#[repr(C)]
union UnionCast {
a: [u32; 4],
v: BVec3A,
@@ -13,8 +14,7 @@ union UnionCast {
/// A 3-dimensional SIMD vector mask.
///
-/// This type is 16 byte aligned and is backed by a SIMD vector. If SIMD is not available
-/// `BVec3A` will be a type alias for `BVec3`.
+/// This type is 16 byte aligned.
#[derive(Clone, Copy)]
#[repr(transparent)]
pub struct BVec3A(pub(crate) mask32x4);
@@ -30,6 +30,7 @@ impl BVec3A {
/// Creates a new vector mask.
#[inline(always)]
+ #[must_use]
pub const fn new(x: bool, y: bool, z: bool) -> Self {
unsafe {
UnionCast {
@@ -41,6 +42,7 @@ impl BVec3A {
/// Creates a vector with all elements set to `v`.
#[inline]
+ #[must_use]
pub const fn splat(v: bool) -> Self {
Self::new(v, v, v)
}
@@ -50,29 +52,51 @@ impl BVec3A {
/// A true element results in a `1` bit and a false element in a `0` bit. Element `x` goes
/// into the first lowest bit, element `y` into the second, etc.
#[inline]
+ #[must_use]
pub fn bitmask(self) -> u32 {
(self.0.to_bitmask() & 0x7) as u32
}
/// Returns true if any of the elements are true, false otherwise.
#[inline]
+ #[must_use]
pub fn any(self) -> bool {
self.bitmask() != 0
}
/// Returns true if all the elements are true, false otherwise.
#[inline]
+ #[must_use]
pub fn all(self) -> bool {
self.bitmask() == 0x7
}
+ /// Tests the value at `index`.
+ ///
+ /// Panics if `index` is greater than 2.
+ #[inline]
+ #[must_use]
+ pub fn test(&self, index: usize) -> bool {
+ self.0.test(index)
+ }
+
+ /// Sets the element at `index`.
+ ///
+ /// Panics if `index` is greater than 2.
+ #[inline]
+ pub fn set(&mut self, index: usize, value: bool) {
+ self.0.set(index, value)
+ }
+
#[inline]
+ #[must_use]
fn into_bool_array(self) -> [bool; 3] {
let bitmask = self.bitmask();
[(bitmask & 1) != 0, (bitmask & 2) != 0, (bitmask & 4) != 0]
}
#[inline]
+ #[must_use]
fn into_u32_array(self) -> [u32; 3] {
let bitmask = self.bitmask();
[