extern crate sdl2; mod font; pub mod generated; mod interpolation; mod render; pub mod vendored; use std::io::{BufWriter, Write}; use std::time::{Duration, SystemTime}; use sdl2::{event::Event, keyboard::Keycode}; #[cfg(all(not(feature = "notimeout"), not(feature = "32k")))] const TIMEOUT_DEATH: f64 = render::JUST_DVD + 20.0; use sdl2::audio::{AudioCallback, AudioSpecDesired}; use vendored::micromod::MmC2r; struct Music<'a> { mm: MmC2r<'a>, } impl<'a> AudioCallback for Music<'a> { type Channel = f32; fn callback(&mut self, out_f: &mut [f32]) { let len = out_f.len(); println!("{len}"); let mut out = [0; 32768]; if !self.mm.get_audio(&mut out, len as isize) { return; } for i in 0..len { out_f[i] = f32::from(out[i]) / f32::from(0x7FFF as i16); } } } pub fn main() { let sdl_context = sdl2::init().unwrap(); let audio_subsystem = sdl_context.audio().unwrap(); let desired_spec = AudioSpecDesired { freq: Some(48_000), channels: Some(1), samples: Some(8192 as u16), }; let device = audio_subsystem .open_playback(None, &desired_spec, |spec| { // initialize the audio callback Music { mm: MmC2r::new(include_bytes!("../uwudhd.mod"), spec.freq as isize).unwrap(), } }) .unwrap(); // Start playback device.resume(); let video_subsystem = sdl_context.video().unwrap(); let mut builder = video_subsystem.window("Cosin25 Invite", 512, 256); builder.position_centered(); #[cfg(feature = "resizable")] builder.resizable(); let window = &mut builder.build().unwrap(); let mut canvas = window.clone().into_canvas().build().unwrap(); let texture_creator = canvas.texture_creator(); render::render(&mut canvas, &texture_creator, 0.001); canvas.present(); let mut event_pump = sdl_context.event_pump().unwrap(); let start_time = SystemTime::now(); 'running: loop { let time = SystemTime::now() .duration_since(start_time) .expect("Time went back between frames"); let time = f64::from(time.as_millis() as u32) / 1000.0; #[cfg(all(not(feature = "notimeout"), not(feature = "32k")))] if time > TIMEOUT_DEATH { break 'running; } render::render(&mut canvas, &texture_creator, time); for event in event_pump.poll_iter() { match event { Event::Quit { .. } | Event::KeyDown { keycode: Some(Keycode::Escape), .. } => break 'running, _ => {} } } // The rest of the game loop goes here... canvas.present(); ::std::thread::sleep(Duration::new(0, 1_000_000_000u32 / 12000)); } }