]> git.lizzy.rs Git - enumset.git/blobdiff - enumset/src/repr.rs
Tag very simple functions with `#[inline(always)]` to improve speed on non-LTO builds.
[enumset.git] / enumset / src / repr.rs
index 5fc2cd0e54f6259af43e6f44b7b3d36a2a8ca707..7dfa89bcf651b1cc807e016e61aafafa5576e854 100644 (file)
@@ -67,57 +67,91 @@ macro_rules! prim {
         impl EnumSetTypeRepr for $name {
             const WIDTH: u32 = $width;
 
+            #[inline(always)]
             fn is_empty(&self) -> bool { *self == 0 }
+            #[inline(always)]
             fn empty() -> Self { 0 }
 
+            #[inline(always)]
             fn add_bit(&mut self, bit: u32) {
                 *self |= 1 << bit as $name;
             }
+            #[inline(always)]
             fn remove_bit(&mut self, bit: u32) {
                 *self &= !(1 << bit as $name);
             }
+            #[inline(always)]
             fn has_bit(&self, bit: u32) -> bool {
                 (self & (1 << bit as $name)) != 0
             }
 
+            #[inline(always)]
             fn count_ones(&self) -> u32 { (*self).count_ones() }
+            #[inline(always)]
             fn leading_zeros(&self) -> u32 { (*self).leading_zeros() }
+            #[inline(always)]
             fn trailing_zeros(&self) -> u32 { (*self).trailing_zeros() }
 
+            #[inline(always)]
             fn and_not(&self, other: Self) -> Self { (*self) & !other }
 
+            #[inline(always)]
             fn count_remaining_ones(&self, cursor: u32) -> usize {
                 let left_mask =
                     !((1 as $name).checked_shl(cursor).unwrap_or(0).wrapping_sub(1));
                 (*self & left_mask).count_ones() as usize
             }
 
+            #[inline(always)]
             fn from_u8(v: u8) -> Self { v as $name }
+            #[inline(always)]
             fn from_u16(v: u16) -> Self { v as $name }
+            #[inline(always)]
             fn from_u32(v: u32) -> Self { v as $name }
+            #[inline(always)]
             fn from_u64(v: u64) -> Self { v as $name }
+            #[inline(always)]
             fn from_u128(v: u128) -> Self { v as $name }
+            #[inline(always)]
             fn from_usize(v: usize) -> Self { v as $name }
 
+            #[inline(always)]
             fn to_u8(&self) -> u8 { (*self) as u8 }
+            #[inline(always)]
             fn to_u16(&self) -> u16 { (*self) as u16 }
+            #[inline(always)]
             fn to_u32(&self) -> u32 { (*self) as u32 }
+            #[inline(always)]
             fn to_u64(&self) -> u64 { (*self) as u64 }
+            #[inline(always)]
             fn to_u128(&self) -> u128 { (*self) as u128 }
+            #[inline(always)]
             fn to_usize(&self) -> usize { (*self) as usize }
 
+            #[inline(always)]
             fn from_u8_opt(v: u8) -> Option<Self> { v.try_into().ok() }
+            #[inline(always)]
             fn from_u16_opt(v: u16) -> Option<Self> { v.try_into().ok() }
+            #[inline(always)]
             fn from_u32_opt(v: u32) -> Option<Self> { v.try_into().ok() }
+            #[inline(always)]
             fn from_u64_opt(v: u64) -> Option<Self> { v.try_into().ok() }
+            #[inline(always)]
             fn from_u128_opt(v: u128) -> Option<Self> { v.try_into().ok() }
+            #[inline(always)]
             fn from_usize_opt(v: usize) -> Option<Self> { v.try_into().ok() }
 
+            #[inline(always)]
             fn to_u8_opt(&self) -> Option<u8> { (*self).try_into().ok() }
+            #[inline(always)]
             fn to_u16_opt(&self) -> Option<u16> { (*self).try_into().ok() }
+            #[inline(always)]
             fn to_u32_opt(&self) -> Option<u32> { (*self).try_into().ok() }
+            #[inline(always)]
             fn to_u64_opt(&self) -> Option<u64> { (*self).try_into().ok() }
+            #[inline(always)]
             fn to_u128_opt(&self) -> Option<u128> { (*self).try_into().ok() }
+            #[inline(always)]
             fn to_usize_opt(&self) -> Option<usize> { (*self).try_into().ok() }
         }
     }