update Justfile

This commit is contained in:
🪞👃🪞 2024-12-28 15:32:53 +01:00
parent 88ed2c160c
commit bcdb5f51f5
4 changed files with 70 additions and 21 deletions

View file

@ -63,19 +63,32 @@ groovebox:
groovebox-release: groovebox-release:
reset reset
cargo run --release --bin tek_groovebox cargo run --release --bin tek_groovebox
groovebox-release-ext:
reset
cargo run --release --bin tek_groovebox -- -n tek \
-i "Midi-Bridge:nanoKEY Studio 1:(capture_0) nanoKEY Studio nanoKEY Studio _" \
-o "Midi-Bridge:Komplete Audio 6 0:(playback_0) Komplete Audio 6 MIDI 1" \
-l "Komplete Audio 6 Pro:capture_AUX1" \
-r "Komplete Audio 6 Pro:capture_AUX1" \
-L "Komplete Audio 6 Pro:playback_AUX1" \
-R "Komplete Audio 6 Pro:playback_AUX1"
sequencer: sequencer:
reset reset
cargo run --bin tek_sequencer cargo run --bin tek_sequencer
sequencer-ext: sequencer-ext:
reset reset
cargo run --bin tek_sequencer -- -i "Midi-Bridge:nanoKEY Studio 2:(capture_0) nanoKEY Studio nanoKEY Studio _" -o "Midi-Bridge:Komplete Audio 6 1:(playback_0) Komplete Audio 6 MIDI 1" cargo run --bin tek_sequencer -- \
-i "Midi-Bridge:nanoKEY Studio 1:(capture_0) nanoKEY Studio nanoKEY Studio _" \
-o "Midi-Bridge:Komplete Audio 6 0:(playback_0) Komplete Audio 6 MIDI 1"
sequencer-release: sequencer-release:
reset reset
cargo run --release --bin tek_sequencer cargo run --release --bin tek_sequencer
sequencer-release-ext: sequencer-release-ext:
reset reset
cargo run --release --bin tek_sequencer -- -i "Midi-Bridge:nanoKEY Studio 2:(capture_0) nanoKEY Studio nanoKEY Studio _" -o "Midi-Bridge:Komplete Audio 6 1:(playback_0) Komplete Audio 6 MIDI 1" cargo run --release --bin tek_sequencer -- \
-i "Midi-Bridge:nanoKEY Studio 1:(capture_0) nanoKEY Studio nanoKEY Studio _" \
-o "Midi-Bridge:Komplete Audio 6 0:(playback_0) Komplete Audio 6 MIDI 1"
mixer: mixer:
reset reset

View file

@ -6,31 +6,46 @@ pub struct GrooveboxCli {
/// Name of JACK client /// Name of JACK client
#[arg(short, long)] #[arg(short, long)]
name: Option<String>, name: Option<String>,
/// 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,
/// MIDI outs to connect to MIDI input
/// MIDI outs to connect to (multiple accepted)
#[arg(short='i', long)] #[arg(short='i', long)]
midi_from: Vec<String>, midi_from: Vec<String>,
/// MIDI ins to connect from MIDI output
/// MIDI ins to connect to (multiple accepted)
#[arg(short='o', long)] #[arg(short='o', long)]
midi_to: Vec<String>, midi_to: Vec<String>,
/// Audio outs to connect to left input
/// Audio ins to connect to (multiple accepted) #[arg(short='l', long)]
#[arg(short='I', long)] l_from: Vec<String>,
audio_from: Vec<String>, /// Audio outs to connect to right input
#[arg(short='r', long)]
/// Audio outs to connect to (multiple accepted) r_from: Vec<String>,
#[arg(short='O', long)] /// Audio ins to connect from left output
audio_to: Vec<String>, #[arg(short='L', long)]
l_to: Vec<String>,
/// Audio ins to connect from right output
#[arg(short='R', long)]
r_to: Vec<String>,
} }
impl GrooveboxCli { impl GrooveboxCli {
fn run (&self) -> Usually<()> { fn run (&self) -> Usually<()> {
Tui::run(JackClient::new("tek_groovebox")? Tui::run(JackClient::new("tek_groovebox")?.activate_with(|jack|{
.activate_with(|jack|tek::GrooveboxTui::try_from(jack))?)?; let app = tek::GrooveboxTui::try_from(jack)?;
let jack = jack.read().unwrap();
jack.client().connect_ports(&app.player.midi_outs[0], &app.sampler.midi_in)?;
connect_from(&jack, &app.player.midi_ins[0], &self.midi_from)?;
connect_to(&jack, &app.player.midi_outs[0], &self.midi_to)?;
connect_audio_from(&jack, &app.sampler.audio_ins[0], &self.l_from)?;
connect_audio_from(&jack, &app.sampler.audio_ins[1], &self.r_from)?;
connect_audio_to(&jack, &app.sampler.audio_outs[0], &self.l_to)?;
connect_audio_to(&jack, &app.sampler.audio_outs[1], &self.r_to)?;
Ok(app)
})?)?;
Ok(()) Ok(())
} }
} }

View file

@ -11,15 +11,12 @@ pub struct SequencerCli {
/// Name of JACK client /// Name of JACK client
#[arg(short, long)] #[arg(short, long)]
name: Option<String>, name: Option<String>,
/// 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,
/// MIDI outs to connect to (multiple instances accepted) /// MIDI outs to connect to (multiple instances accepted)
#[arg(short='i', long)] #[arg(short='i', long)]
midi_from: Vec<String>, midi_from: Vec<String>,
/// MIDI ins to connect to (multiple instances accepted) /// MIDI ins to connect to (multiple instances accepted)
#[arg(short='o', long)] #[arg(short='o', long)]
midi_to: Vec<String>, midi_to: Vec<String>,

View file

@ -25,3 +25,27 @@ fn connect_to (jack: &JackClient, output: &Port<MidiOut>, ports: &[String]) -> U
} }
Ok(()) Ok(())
} }
#[allow(unused)]
fn connect_audio_from (jack: &JackClient, input: &Port<AudioIn>, ports: &[String]) -> Usually<()> {
for port in ports.iter() {
if let Some(port) = jack.port_by_name(port).as_ref() {
jack.client().connect_ports(port, input)?;
} else {
panic!("Missing MIDI output: {port}. Use jack_lsp to list all port names.");
}
}
Ok(())
}
#[allow(unused)]
fn connect_audio_to (jack: &JackClient, output: &Port<AudioOut>, ports: &[String]) -> Usually<()> {
for port in ports.iter() {
if let Some(port) = jack.port_by_name(port).as_ref() {
jack.client().connect_ports(output, port)?;
} else {
panic!("Missing MIDI input: {port}. Use jack_lsp to list all port names.");
}
}
Ok(())
}