Files
composer/src/main.rs
2026-03-11 16:00:41 -06:00

58 lines
1.5 KiB
Rust

use itertools::Itertools;
mod flags;
mod play;
mod seq;
mod syn;
mod tone;
fn main() {
let flags = flags::Flags::new();
if flags.debug {
eprintln!("{:?}", flags);
}
let mut syn_seq = seq::new_syn(syn::Syn::new(
flags.debug,
flags.sound_font,
flags.sample_rate,
));
let mut i = 0;
for p in flags.play.iter() {
for p in play::new(p.clone()) {
syn_seq.append(i as i32, p);
i += 1;
}
}
play(syn_seq, flags.sample_rate, flags.bpm);
}
fn play(mut s: seq::SynSeq, sample_rate: usize, bpm: usize) {
let samples_per_beat = sample_rate / bpm * 60;
let params = tinyaudio::prelude::OutputDeviceParameters {
channels_count: 2,
sample_rate: sample_rate,
channel_sample_count: samples_per_beat,
};
let beats = s.beats() + 3;
let duration = 60 * beats / bpm;
let sample_count = (params.channel_sample_count) as usize;
let mut left: Vec<f32> = vec![0_f32; sample_count];
let mut right: Vec<f32> = vec![0_f32; sample_count];
let _device = tinyaudio::prelude::run_output_device(params, {
move |data| {
s.render(&mut left[..], &mut right[..]); // put in a state of rendering the next loop of these notes
for (i, value) in left.iter().interleave(right.iter()).enumerate() {
data[i] = *value;
}
}
})
.unwrap();
// Wait it out
std::thread::sleep(std::time::Duration::from_secs(duration as u64));
}