summaryrefslogtreecommitdiff
path: root/audio/src/data.rs
diff options
context:
space:
mode:
authorFreya Murphy <freya@freyacat.org>2025-11-22 13:29:10 -0500
committerFreya Murphy <freya@freyacat.org>2025-11-22 13:29:10 -0500
commit2274d33e469aca544a7aeb899a10769b973ae374 (patch)
tree7ff10964234fd5e8917624508e249265a3d0b19c /audio/src/data.rs
parentaudio: move 'asm' files out of data segment (diff)
downloadDungeonCrawl-2274d33e469aca544a7aeb899a10769b973ae374.tar.gz
DungeonCrawl-2274d33e469aca544a7aeb899a10769b973ae374.tar.bz2
DungeonCrawl-2274d33e469aca544a7aeb899a10769b973ae374.zip
audio: refactor into seperate crate
Diffstat (limited to 'audio/src/data.rs')
-rw-r--r--audio/src/data.rs30
1 files changed, 30 insertions, 0 deletions
diff --git a/audio/src/data.rs b/audio/src/data.rs
new file mode 100644
index 0000000..2d1bdc5
--- /dev/null
+++ b/audio/src/data.rs
@@ -0,0 +1,30 @@
+use crate::program::Program;
+use std::fs;
+
+macro_rules! load_asm {
+ ($path:tt) => {{
+ if cfg!(any(feature = "static", target_arch = "wasm32")) {
+ let src = include_str!(concat!("../../", $path));
+ Program::parse(src, true)?
+ } else {
+ let src = fs::read_to_string($path)?;
+ Program::parse(&src, true)?
+ }
+ }};
+ ($first:tt, $($arg:tt)*) => {
+ load_asm!($first)$(.merge(load_asm!($arg)))*
+ };
+}
+
+pub struct Data {
+ pub megalovania: Program,
+}
+impl Data {
+ pub fn load() -> crate::Result<Self> {
+ let megalovania = load_asm!(
+ "assets/asm/megalovania_melody.asm",
+ "assets/asm/megalovania_base.asm"
+ );
+ Ok(Self { megalovania })
+ }
+}