summaryrefslogtreecommitdiff
path: root/src/lib.rs
diff options
context:
space:
mode:
authorBen Bridle <bridle.benjamin@gmail.com>2025-07-03 14:53:16 +1200
committerBen Bridle <bridle.benjamin@gmail.com>2025-07-03 14:53:16 +1200
commit701448be2c3c58e30960d46f090bf08adfc02832 (patch)
tree409be74cdbb4bf311cb98fbee14f67fcd9c680d0 /src/lib.rs
downloadbedrock-core-701448be2c3c58e30960d46f090bf08adfc02832.zip
Initial commit
Diffstat (limited to 'src/lib.rs')
-rw-r--r--src/lib.rs29
1 files changed, 29 insertions, 0 deletions
diff --git a/src/lib.rs b/src/lib.rs
new file mode 100644
index 0000000..6324e3b
--- /dev/null
+++ b/src/lib.rs
@@ -0,0 +1,29 @@
+mod components;
+mod core;
+mod emulator;
+mod signal;
+
+pub use components::*;
+pub use core::*;
+pub use emulator::*;
+pub use signal::*;
+
+
+pub mod macros {
+ #[macro_export] macro_rules! read_hh { ($v:expr) => { ($v>>24) as u8 }; }
+ #[macro_export] macro_rules! read_hl { ($v:expr) => { ($v>>16) as u8 }; }
+ #[macro_export] macro_rules! read_lh { ($v:expr) => { ($v>>8) as u8 }; }
+ #[macro_export] macro_rules! read_ll { ($v:expr) => { $v as u8 }; }
+ #[macro_export] macro_rules! read_h { ($v:expr) => { ($v>>8) as u8 }; }
+ #[macro_export] macro_rules! read_l { ($v:expr) => { $v as u8 }; }
+ #[macro_export] macro_rules! read_b { ($v:expr) => { 0u8.wrapping_sub($v as u8) }; }
+
+ #[macro_export] macro_rules! write_hh { ($v:expr, $high:expr) => { $v = $v & 0x00ffffff | (($high as u32) << 24) }; }
+ #[macro_export] macro_rules! write_hl { ($v:expr, $low:expr) => { $v = $v & 0xff00ffff | (($low as u32) << 16) }; }
+ #[macro_export] macro_rules! write_lh { ($v:expr, $high:expr) => { $v = $v & 0xffff00ff | (($high as u32) << 8) }; }
+ #[macro_export] macro_rules! write_ll { ($v:expr, $low:expr) => { $v = $v & 0xffffff00 | ($low as u32) }; }
+ #[macro_export] macro_rules! write_h { ($v:expr, $high:expr) => { $v = $v & 0x00ff | (($high as u16) << 8) }; }
+ #[macro_export] macro_rules! write_l { ($v:expr, $low:expr) => { $v = $v & 0xff00 | ($low as u16) }; }
+
+ #[macro_export] macro_rules! test_bit { ($v:expr, $mask:expr) => { $v & $mask != 0 }; }
+}