mirror of
https://github.com/italicsjenga/gba.git
synced 2025-01-11 11:31:31 +11:00
This commit is contained in:
parent
9bca85264f
commit
703c837a21
|
@ -13,14 +13,17 @@ pub(crate) use const_new;
|
||||||
/// Sets up a bitfield integer
|
/// Sets up a bitfield integer
|
||||||
macro_rules! bitfield_int {
|
macro_rules! bitfield_int {
|
||||||
($inner:ty; $low:literal ..= $high:literal : $nt:ident, $get:ident, $with:ident, $set:ident) => {
|
($inner:ty; $low:literal ..= $high:literal : $nt:ident, $get:ident, $with:ident, $set:ident) => {
|
||||||
|
#[inline]
|
||||||
pub const fn $get(self) -> $nt {
|
pub const fn $get(self) -> $nt {
|
||||||
const MASK: $inner = ((1 << $high) - 1) << $low;
|
const MASK: $inner = ((1 << $high) - 1) << $low;
|
||||||
((self.0 & MASK) >> $low) as $nt
|
((self.0 & MASK) >> $low) as $nt
|
||||||
}
|
}
|
||||||
|
#[inline]
|
||||||
pub const fn $with(self, $get: $nt) -> Self {
|
pub const fn $with(self, $get: $nt) -> Self {
|
||||||
const MASK: $inner = ((1 << $high) - 1) << $low;
|
const MASK: $inner = ((1 << $high) - 1) << $low;
|
||||||
Self(self.0 ^ ((self.0 ^ ($get as $inner)) & MASK))
|
Self(self.0 ^ ((self.0 ^ ($get as $inner)) & MASK))
|
||||||
}
|
}
|
||||||
|
#[inline]
|
||||||
pub fn $set(&mut self, $get: $nt) {
|
pub fn $set(&mut self, $get: $nt) {
|
||||||
*self = self.$with($get);
|
*self = self.$with($get);
|
||||||
}
|
}
|
||||||
|
@ -31,14 +34,17 @@ pub(crate) use bitfield_int;
|
||||||
/// Sets up a bitfield int wrapped newtype
|
/// Sets up a bitfield int wrapped newtype
|
||||||
macro_rules! bitfield_newtype {
|
macro_rules! bitfield_newtype {
|
||||||
($inner:ty; $low:literal ..= $high:literal : $nt:ident, $get:ident, $with:ident, $set:ident) => {
|
($inner:ty; $low:literal ..= $high:literal : $nt:ident, $get:ident, $with:ident, $set:ident) => {
|
||||||
|
#[inline]
|
||||||
pub const fn $get(self) -> $nt {
|
pub const fn $get(self) -> $nt {
|
||||||
const MASK: $inner = ((1 << $high) - 1) << $low;
|
const MASK: $inner = ((1 << $high) - 1) << $low;
|
||||||
$nt(self.0 & MASK)
|
$nt(self.0 & MASK)
|
||||||
}
|
}
|
||||||
|
#[inline]
|
||||||
pub const fn $with(self, $get: $nt) -> Self {
|
pub const fn $with(self, $get: $nt) -> Self {
|
||||||
const MASK: $inner = ((1 << $high) - 1) << $low;
|
const MASK: $inner = ((1 << $high) - 1) << $low;
|
||||||
Self(self.0 ^ ((self.0 ^ $get.0) & MASK))
|
Self(self.0 ^ ((self.0 ^ $get.0) & MASK))
|
||||||
}
|
}
|
||||||
|
#[inline]
|
||||||
pub fn $set(&mut self, $get: $nt) {
|
pub fn $set(&mut self, $get: $nt) {
|
||||||
*self = self.$with($get);
|
*self = self.$with($get);
|
||||||
}
|
}
|
||||||
|
@ -50,14 +56,17 @@ pub(crate) use bitfield_newtype;
|
||||||
macro_rules! bitfield_enum {
|
macro_rules! bitfield_enum {
|
||||||
($inner:ty; $low:literal ..= $high:literal : $nt:ident, $get:ident, $with:ident, $set:ident) => {
|
($inner:ty; $low:literal ..= $high:literal : $nt:ident, $get:ident, $with:ident, $set:ident) => {
|
||||||
// TODO: make this const when we have const transmute
|
// TODO: make this const when we have const transmute
|
||||||
|
#[inline]
|
||||||
pub fn $get(self) -> $nt {
|
pub fn $get(self) -> $nt {
|
||||||
const MASK: $inner = ((1 << $high) - 1) << $low;
|
const MASK: $inner = ((1 << $high) - 1) << $low;
|
||||||
unsafe { core::mem::transmute(self.0 & MASK) }
|
unsafe { core::mem::transmute(self.0 & MASK) }
|
||||||
}
|
}
|
||||||
|
#[inline]
|
||||||
pub const fn $with(self, $get: $nt) -> Self {
|
pub const fn $with(self, $get: $nt) -> Self {
|
||||||
const MASK: $inner = ((1 << $high) - 1) << $low;
|
const MASK: $inner = ((1 << $high) - 1) << $low;
|
||||||
Self(self.0 ^ ((self.0 ^ $get as $inner) & MASK))
|
Self(self.0 ^ ((self.0 ^ $get as $inner) & MASK))
|
||||||
}
|
}
|
||||||
|
#[inline]
|
||||||
pub fn $set(&mut self, $get: $nt) {
|
pub fn $set(&mut self, $get: $nt) {
|
||||||
*self = self.$with($get);
|
*self = self.$with($get);
|
||||||
}
|
}
|
||||||
|
@ -68,12 +77,15 @@ pub(crate) use bitfield_enum;
|
||||||
/// Sets up a bitfield bool
|
/// Sets up a bitfield bool
|
||||||
macro_rules! bitfield_bool {
|
macro_rules! bitfield_bool {
|
||||||
($inner:ty; $bit:literal, $get:ident, $with:ident, $set:ident) => {
|
($inner:ty; $bit:literal, $get:ident, $with:ident, $set:ident) => {
|
||||||
|
#[inline]
|
||||||
pub const fn $get(self) -> bool {
|
pub const fn $get(self) -> bool {
|
||||||
(self.0 & (1 << $bit)) != 0
|
(self.0 & (1 << $bit)) != 0
|
||||||
}
|
}
|
||||||
|
#[inline]
|
||||||
pub const fn $with(self, $get: bool) -> Self {
|
pub const fn $with(self, $get: bool) -> Self {
|
||||||
Self(self.0 ^ ((($get as $inner).wrapping_neg() ^ self.0) & (1 << $bit)))
|
Self(self.0 ^ ((($get as $inner).wrapping_neg() ^ self.0) & (1 << $bit)))
|
||||||
}
|
}
|
||||||
|
#[inline]
|
||||||
pub fn $set(&mut self, $get: bool) {
|
pub fn $set(&mut self, $get: bool) {
|
||||||
*self = self.$with($get);
|
*self = self.$with($get);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue