include!("./lib.rs"); pub fn main () -> Usually<()> { GrooveboxCli::parse().run() } #[derive(Debug, Parser)] #[command(version, about, long_about = None)] pub struct GrooveboxCli { /// Name of JACK client #[arg(short, long)] name: Option, /// Whether to include a transport toolbar (default: true) #[arg(short, long, default_value_t = true)] transport: bool, /// Whether to attempt to become transport master #[arg(short='S', long, default_value_t = false)] sync_lead: bool, /// Whether to attempt to become transport master #[arg(short='s', long, default_value_t = true)] sync_follow: bool, /// MIDI outs to connect to MIDI input #[arg(short='i', long)] midi_from: Vec, /// MIDI ins to connect from MIDI output #[arg(short='o', long)] midi_to: Vec, /// Audio outs to connect to left input #[arg(short='l', long)] l_from: Vec, /// Audio outs to connect to right input #[arg(short='r', long)] r_from: Vec, /// Audio ins to connect from left output #[arg(short='L', long)] l_to: Vec, /// Audio ins to connect from right output #[arg(short='R', long)] r_to: Vec, } impl GrooveboxCli { fn run (&self) -> Usually<()> { Tui::run(JackConnection::new("tek_groovebox")?.activate_with(|jack|{ let app = tek::GrooveboxTui::new( jack, &self.midi_from.as_slice(), &self.midi_to.as_slice(), &[&self.l_from.as_slice(), &self.r_from.as_slice()], &[&self.l_to.as_slice(), &self.r_to.as_slice()], )?; if self.sync_lead { jack.read().unwrap().client().register_timebase_callback(false, |mut state|{ app.clock().playhead.update_from_sample(state.position.frame() as f64); state.position.bbt = Some(app.clock().bbt()); state.position })? } else if self.sync_follow { jack.read().unwrap().client().register_timebase_callback(false, |state|{ app.clock().playhead.update_from_sample(state.position.frame() as f64); state.position })? } Ok(app) })?)?; Ok(()) } } #[test] fn verify_groovebox_cli () { use clap::CommandFactory; GrooveboxCli::command().debug_assert(); }