mirror of
https://codeberg.org/unspeaker/tek.git
synced 2025-12-06 03:36:41 +01:00
wip: successfully registers transport callback
This commit is contained in:
parent
d926422c67
commit
ae69e87dc9
3 changed files with 16 additions and 7 deletions
10
Cargo.toml
10
Cargo.toml
|
|
@ -4,11 +4,10 @@ edition = "2021"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
#no_deadlocks = "1.3.2"
|
|
||||||
#vst3 = "0.1.0"
|
|
||||||
atomic_float = "1.0.0"
|
atomic_float = "1.0.0"
|
||||||
backtrace = "0.3.72"
|
backtrace = "0.3.72"
|
||||||
better-panic = "0.3.0"
|
better-panic = "0.3.0"
|
||||||
|
clap = { version = "4.5.4", features = [ "derive" ] }
|
||||||
clojure-reader = "0.1.0"
|
clojure-reader = "0.1.0"
|
||||||
crossterm = "0.27"
|
crossterm = "0.27"
|
||||||
jack = { path = "./rust-jack" }
|
jack = { path = "./rust-jack" }
|
||||||
|
|
@ -19,14 +18,15 @@ palette = { version = "0.7.6", features = [ "random" ] }
|
||||||
quanta = "0.12.3"
|
quanta = "0.12.3"
|
||||||
rand = "0.8.5"
|
rand = "0.8.5"
|
||||||
ratatui = { version = "0.26.3", features = [ "unstable-widget-ref", "underline-color" ] }
|
ratatui = { version = "0.26.3", features = [ "unstable-widget-ref", "underline-color" ] }
|
||||||
#suil-rs = { path = "../suil" }
|
|
||||||
symphonia = { version = "0.5.4", features = [ "all" ] }
|
symphonia = { version = "0.5.4", features = [ "all" ] }
|
||||||
toml = "0.8.12"
|
toml = "0.8.12"
|
||||||
uuid = { version = "1.10.0", features = [ "v4" ] }
|
uuid = { version = "1.10.0", features = [ "v4" ] }
|
||||||
#vst = "0.4.0"
|
|
||||||
wavers = "1.4.3"
|
wavers = "1.4.3"
|
||||||
|
#no_deadlocks = "1.3.2"
|
||||||
|
#suil-rs = { path = "../suil" }
|
||||||
|
#vst = "0.4.0"
|
||||||
|
#vst3 = "0.1.0"
|
||||||
#winit = { version = "0.30.4", features = [ "x11" ] }
|
#winit = { version = "0.30.4", features = [ "x11" ] }
|
||||||
clap = { version = "4.5.4", features = [ "derive" ] }
|
|
||||||
|
|
||||||
[[bin]]
|
[[bin]]
|
||||||
name = "tek_arranger"
|
name = "tek_arranger"
|
||||||
|
|
|
||||||
|
|
@ -9,6 +9,9 @@ pub struct GrooveboxCli {
|
||||||
/// Whether to include a transport toolbar (default: true)
|
/// Whether to include a transport toolbar (default: true)
|
||||||
#[arg(short, long, default_value_t = true)]
|
#[arg(short, long, default_value_t = true)]
|
||||||
transport: bool,
|
transport: bool,
|
||||||
|
/// Whether to attempt to become transport master
|
||||||
|
#[arg(short, long, default_value_t = true)]
|
||||||
|
sync: bool,
|
||||||
/// MIDI outs to connect to MIDI input
|
/// MIDI outs to connect to MIDI input
|
||||||
#[arg(short='i', long)]
|
#[arg(short='i', long)]
|
||||||
midi_from: Vec<String>,
|
midi_from: Vec<String>,
|
||||||
|
|
@ -31,7 +34,7 @@ pub struct GrooveboxCli {
|
||||||
impl GrooveboxCli {
|
impl GrooveboxCli {
|
||||||
fn run (&self) -> Usually<()> {
|
fn run (&self) -> Usually<()> {
|
||||||
Tui::run(JackClient::new("tek_groovebox")?.activate_with(|jack|{
|
Tui::run(JackClient::new("tek_groovebox")?.activate_with(|jack|{
|
||||||
let app = tek::GrooveboxTui::try_from(jack)?;
|
let app = tek::GrooveboxTui::try_from(jack)?;
|
||||||
jack.read().unwrap().client().connect_ports(&app.player.midi_outs[0], &app.sampler.midi_in)?;
|
jack.read().unwrap().client().connect_ports(&app.player.midi_outs[0], &app.sampler.midi_in)?;
|
||||||
jack.connect_midi_from(&app.player.midi_ins[0], &self.midi_from)?;
|
jack.connect_midi_from(&app.player.midi_ins[0], &self.midi_from)?;
|
||||||
jack.connect_midi_from(&app.sampler.midi_in, &self.midi_from)?;
|
jack.connect_midi_from(&app.sampler.midi_in, &self.midi_from)?;
|
||||||
|
|
@ -40,6 +43,12 @@ impl GrooveboxCli {
|
||||||
jack.connect_audio_from(&app.sampler.audio_ins[1], &self.r_from)?;
|
jack.connect_audio_from(&app.sampler.audio_ins[1], &self.r_from)?;
|
||||||
jack.connect_audio_to(&app.sampler.audio_outs[0], &self.l_to)?;
|
jack.connect_audio_to(&app.sampler.audio_outs[0], &self.l_to)?;
|
||||||
jack.connect_audio_to(&app.sampler.audio_outs[1], &self.r_to)?;
|
jack.connect_audio_to(&app.sampler.audio_outs[1], &self.r_to)?;
|
||||||
|
if self.sync {
|
||||||
|
jack.read().unwrap().client().register_timebase_callback(false, |bbt, state, nframes, new_pos|{
|
||||||
|
println!("\r{state:?} {nframes} {new_pos}");
|
||||||
|
// TODO
|
||||||
|
})?
|
||||||
|
}
|
||||||
Ok(app)
|
Ok(app)
|
||||||
})?)?;
|
})?)?;
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|
|
||||||
|
|
@ -1 +1 @@
|
||||||
Subproject commit 5256af1ddea221dd78f22e48c0a72a3842cad26d
|
Subproject commit 5a913d4c97b18d51bd8175d1bcb55c1b0fd52cb1
|
||||||
Loading…
Add table
Add a link
Reference in a new issue