aboutsummaryrefslogtreecommitdiff
path: root/src/bool/coresimd/bvec4a.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/bool/coresimd/bvec4a.rs')
-rw-r--r--src/bool/coresimd/bvec4a.rs28
1 files changed, 26 insertions, 2 deletions
diff --git a/src/bool/coresimd/bvec4a.rs b/src/bool/coresimd/bvec4a.rs
index 381ee0b..123a003 100644
--- a/src/bool/coresimd/bvec4a.rs
+++ b/src/bool/coresimd/bvec4a.rs
@@ -6,6 +6,7 @@ use core::ops::*;
use core::simd::*;
+#[repr(C)]
union UnionCast {
a: [u32; 4],
v: BVec4A,
@@ -13,8 +14,7 @@ union UnionCast {
/// A 4-dimensional SIMD vector mask.
///
-/// This type is 16 byte aligned and is backed by a SIMD vector. If SIMD is not available
-/// `BVec4A` will be a type alias for `BVec4`.
+/// This type is 16 byte aligned.
#[derive(Clone, Copy)]
#[repr(transparent)]
pub struct BVec4A(pub(crate) mask32x4);
@@ -30,6 +30,7 @@ impl BVec4A {
/// Creates a new vector mask.
#[inline(always)]
+ #[must_use]
pub const fn new(x: bool, y: bool, z: bool, w: bool) -> Self {
unsafe {
UnionCast {
@@ -46,6 +47,7 @@ impl BVec4A {
/// Creates a vector with all elements set to `v`.
#[inline]
+ #[must_use]
pub const fn splat(v: bool) -> Self {
Self::new(v, v, v, v)
}
@@ -55,23 +57,44 @@ impl BVec4A {
/// 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() 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() == 0xf
}
+ /// Tests the value at `index`.
+ ///
+ /// Panics if `index` is greater than 3.
+ #[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 3.
+ #[inline]
+ pub fn set(&mut self, index: usize, value: bool) {
+ self.0.set(index, value)
+ }
+
#[inline]
+ #[must_use]
fn into_bool_array(self) -> [bool; 4] {
let bitmask = self.bitmask();
[
@@ -83,6 +106,7 @@ impl BVec4A {
}
#[inline]
+ #[must_use]
fn into_u32_array(self) -> [u32; 4] {
let bitmask = self.bitmask();
[