mirror of
https://codeberg.org/unspeaker/tek.git
synced 2025-12-07 04:06:45 +01:00
remove ArrangerMode and Arranger::new
This commit is contained in:
parent
7ddb95d521
commit
2e81549747
4 changed files with 58 additions and 87 deletions
30
Justfile
30
Justfile
|
|
@ -1,6 +1,21 @@
|
||||||
default:
|
default:
|
||||||
bacon -sj test
|
bacon -sj test
|
||||||
|
|
||||||
|
edn:
|
||||||
|
reset
|
||||||
|
cargo run --example edn
|
||||||
|
|
||||||
|
test:
|
||||||
|
reset
|
||||||
|
cd engine && cargo test && cd ..
|
||||||
|
cd layout && cargo test && cd ..
|
||||||
|
cd edn && cargo test && cd ..
|
||||||
|
cd tui && cargo test && cd ..
|
||||||
|
cargo test
|
||||||
|
|
||||||
|
cloc:
|
||||||
|
for src in {cli,edn/src,input/src,jack/src,midi/src,output/src,tek/src,time/src,tui/src}; do echo $src; cloc $src; done
|
||||||
|
|
||||||
status:
|
status:
|
||||||
cargo c
|
cargo c
|
||||||
cloc --by-file src/
|
cloc --by-file src/
|
||||||
|
|
@ -99,18 +114,3 @@ sampler:
|
||||||
{{debug}} sampler
|
{{debug}} sampler
|
||||||
plugin:
|
plugin:
|
||||||
{{debug}} plugin
|
{{debug}} plugin
|
||||||
|
|
||||||
edn:
|
|
||||||
reset
|
|
||||||
cargo run --example edn
|
|
||||||
|
|
||||||
test:
|
|
||||||
reset
|
|
||||||
cd engine && cargo test && cd ..
|
|
||||||
cd layout && cargo test && cd ..
|
|
||||||
cd edn && cargo test && cd ..
|
|
||||||
cd tui && cargo test && cd ..
|
|
||||||
cargo test
|
|
||||||
|
|
||||||
cloc:
|
|
||||||
for src in {cli/src,edn/src,examples,input/src,jack/src,midi/src,output/src,time/src,tui/src,src}; do echo $src; cloc $src; done
|
|
||||||
|
|
|
||||||
51
cli/tek.rs
51
cli/tek.rs
|
|
@ -75,32 +75,38 @@ pub fn main () -> Usually<()> {
|
||||||
let left_tos = PortConnection::collect(&cli.left_to, empty, empty);
|
let left_tos = PortConnection::collect(&cli.left_to, empty, empty);
|
||||||
let right_froms = PortConnection::collect(&cli.right_from, empty, empty);
|
let right_froms = PortConnection::collect(&cli.right_from, empty, empty);
|
||||||
let right_tos = PortConnection::collect(&cli.right_to, empty, empty);
|
let right_tos = PortConnection::collect(&cli.right_to, empty, empty);
|
||||||
|
let perf = PerfModel::default();
|
||||||
|
let size = Measure::new();
|
||||||
|
let default_clip = ||{
|
||||||
|
let len = 384usize;
|
||||||
|
let color = ItemColor::random().into();
|
||||||
|
Arc::new(RwLock::new(MidiClip::new("Clip", true, len, None, Some(color))))
|
||||||
|
};
|
||||||
Ok(match cli.mode {
|
Ok(match cli.mode {
|
||||||
|
|
||||||
TekMode::Clock => engine.run(&jack.activate_with(|jack|Ok(TransportTui {
|
TekMode::Clock => engine.run(&jack.activate_with(|jack|Ok(TransportTui {
|
||||||
|
jack: jack.clone(),
|
||||||
clock: Clock::from(jack),
|
clock: Clock::from(jack),
|
||||||
jack: jack.clone()
|
|
||||||
}))?)?,
|
}))?)?,
|
||||||
|
|
||||||
TekMode::Sequencer => engine.run(&jack.activate_with(|jack|Ok({
|
TekMode::Sequencer => engine.run(&jack.activate_with(|jack|Ok({
|
||||||
let length = 384;
|
let clip = default_clip();
|
||||||
let color = Some(ItemColor::random().into());
|
|
||||||
let clip = Arc::new(RwLock::new(MidiClip::new("Clip", true, length, None, color)));
|
|
||||||
let player = MidiPlayer::new(&jack, name, Some(&clip), &midi_froms, &midi_tos)?;
|
let player = MidiPlayer::new(&jack, name, Some(&clip), &midi_froms, &midi_tos)?;
|
||||||
Sequencer {
|
Sequencer {
|
||||||
_jack: jack.clone(),
|
_jack: jack.clone(),
|
||||||
clock: player.clock.clone(),
|
clock: player.clock.clone(),
|
||||||
|
|
||||||
player,
|
player,
|
||||||
editor: MidiEditor::from(&clip),
|
editor: MidiEditor::from(&clip),
|
||||||
pool: PoolModel::from(&clip),
|
pool: PoolModel::from(&clip),
|
||||||
compact: true,
|
compact: true,
|
||||||
transport: true,
|
transport: true,
|
||||||
selectors: true,
|
selectors: true,
|
||||||
size: Measure::new(),
|
|
||||||
midi_buf: vec![vec![];65536],
|
midi_buf: vec![vec![];65536],
|
||||||
note_buf: vec![],
|
note_buf: vec![],
|
||||||
perf: PerfModel::default(),
|
|
||||||
status: true,
|
status: true,
|
||||||
|
perf,
|
||||||
|
size,
|
||||||
}
|
}
|
||||||
}))?)?,
|
}))?)?,
|
||||||
|
|
||||||
|
|
@ -109,35 +115,34 @@ pub fn main () -> Usually<()> {
|
||||||
cursor: (0, 0),
|
cursor: (0, 0),
|
||||||
editing: None,
|
editing: None,
|
||||||
mode: None,
|
mode: None,
|
||||||
size: Measure::new(),
|
|
||||||
note_lo: 36.into(),
|
note_lo: 36.into(),
|
||||||
note_pt: 36.into(),
|
note_pt: 36.into(),
|
||||||
color: ItemPalette::from(Color::Rgb(64, 128, 32)),
|
color: ItemPalette::from(Color::Rgb(64, 128, 32)),
|
||||||
state: Sampler::new(jack, &"sampler", &midi_froms,
|
state: Sampler::new(jack, &"sampler", &midi_froms,
|
||||||
&[&left_froms, &right_froms], &[&left_tos, &right_tos])?,
|
&[&left_froms, &right_froms], &[&left_tos, &right_tos])?,
|
||||||
|
size,
|
||||||
}
|
}
|
||||||
))?)?,
|
))?)?,
|
||||||
|
|
||||||
TekMode::Groovebox => engine.run(&jack.activate_with(|jack|Ok({
|
TekMode::Groovebox => engine.run(&jack.activate_with(|jack|Ok({
|
||||||
let length = 384;
|
let clip = default_clip();
|
||||||
let color = Some(ItemColor::random().into());
|
|
||||||
let clip = Arc::new(RwLock::new(MidiClip::new("Clip", true, length, None, color)));
|
|
||||||
let player = MidiPlayer::new(jack, &"sequencer", Some(&clip), &midi_froms, &midi_tos)?;
|
let player = MidiPlayer::new(jack, &"sequencer", Some(&clip), &midi_froms, &midi_tos)?;
|
||||||
let sampler = Sampler::new(jack, &"sampler", &midi_froms,
|
let sampler = Sampler::new(jack, &"sampler", &midi_froms,
|
||||||
&[&left_froms, &right_froms], &[&left_tos, &right_tos])?;
|
&[&left_froms, &right_froms], &[&left_tos, &right_tos])?;
|
||||||
jack.read().unwrap().client().connect_ports(&player.midi_outs[0].port, &sampler.midi_in.port)?;
|
jack.read().unwrap().client().connect_ports(&player.midi_outs[0].port, &sampler.midi_in.port)?;
|
||||||
let app = Groovebox {
|
let app = Groovebox {
|
||||||
|
_jack: jack.clone(),
|
||||||
|
|
||||||
player,
|
player,
|
||||||
sampler,
|
sampler,
|
||||||
pool: PoolModel::from(&clip),
|
pool: PoolModel::from(&clip),
|
||||||
editor: MidiEditor::from(&clip),
|
editor: MidiEditor::from(&clip),
|
||||||
compact: true,
|
compact: true,
|
||||||
status: true,
|
status: true,
|
||||||
size: Measure::new(),
|
|
||||||
midi_buf: vec![vec![];65536],
|
midi_buf: vec![vec![];65536],
|
||||||
note_buf: vec![],
|
note_buf: vec![],
|
||||||
perf: PerfModel::default(),
|
perf,
|
||||||
_jack: jack.clone(),
|
size,
|
||||||
};
|
};
|
||||||
if let Some(bpm) = cli.bpm {
|
if let Some(bpm) = cli.bpm {
|
||||||
app.clock().timebase.bpm.set(bpm);
|
app.clock().timebase.bpm.set(bpm);
|
||||||
|
|
@ -159,7 +164,25 @@ pub fn main () -> Usually<()> {
|
||||||
|
|
||||||
TekMode::Arranger { scenes, tracks, track_width, .. } =>
|
TekMode::Arranger { scenes, tracks, track_width, .. } =>
|
||||||
engine.run(&jack.activate_with(|jack|Ok({
|
engine.run(&jack.activate_with(|jack|Ok({
|
||||||
let mut app = Arranger::new(jack);
|
let clock = Clock::from(jack);
|
||||||
|
let clip = default_clip();
|
||||||
|
let mut app = Arranger {
|
||||||
|
jack: jack.clone(),
|
||||||
|
clock,
|
||||||
|
|
||||||
|
pool: (&clip).into(),
|
||||||
|
editor: (&clip).into(),
|
||||||
|
selected: ArrangerSelection::Clip(0, 0),
|
||||||
|
scenes: vec![],
|
||||||
|
tracks: vec![],
|
||||||
|
color: ItemPalette::random(),
|
||||||
|
splits: [12, 20],
|
||||||
|
midi_buf: vec![vec![];65536],
|
||||||
|
note_buf: vec![],
|
||||||
|
compact: true,
|
||||||
|
perf,
|
||||||
|
size,
|
||||||
|
};
|
||||||
app.tracks_add(tracks, track_width, &midi_froms, &midi_tos)?;
|
app.tracks_add(tracks, track_width, &midi_froms, &midi_tos)?;
|
||||||
app.scenes_add(scenes)?;
|
app.scenes_add(scenes)?;
|
||||||
app
|
app
|
||||||
|
|
|
||||||
|
|
@ -1,23 +1,21 @@
|
||||||
use crate::*;
|
use crate::*;
|
||||||
|
|
||||||
mod arranger_command; pub(crate) use self::arranger_command::*;
|
mod arranger_command; pub use self::arranger_command::*;
|
||||||
mod arranger_scene; pub(crate) use self::arranger_scene::*;
|
mod arranger_scene; pub use self::arranger_scene::*;
|
||||||
mod arranger_select; pub(crate) use self::arranger_select::*;
|
mod arranger_select; pub use self::arranger_select::*;
|
||||||
mod arranger_track; pub(crate) use self::arranger_track::*;
|
mod arranger_track; pub use self::arranger_track::*;
|
||||||
mod arranger_tui; pub(crate) use self::arranger_tui::*;
|
mod arranger_tui; pub use self::arranger_tui::*;
|
||||||
mod arranger_mode; pub(crate) use self::arranger_mode::*;
|
|
||||||
mod arranger_h;
|
mod arranger_h;
|
||||||
|
|
||||||
/// Root view for standalone `tek_arranger`
|
/// Root view for standalone `tek_arranger`
|
||||||
pub struct Arranger {
|
pub struct Arranger {
|
||||||
jack: Arc<RwLock<JackConnection>>,
|
pub jack: Arc<RwLock<JackConnection>>,
|
||||||
pub clock: Clock,
|
pub clock: Clock,
|
||||||
pub pool: PoolModel,
|
pub pool: PoolModel,
|
||||||
pub tracks: Vec<ArrangerTrack>,
|
pub tracks: Vec<ArrangerTrack>,
|
||||||
pub scenes: Vec<ArrangerScene>,
|
pub scenes: Vec<ArrangerScene>,
|
||||||
pub splits: [u16;2],
|
pub splits: [u16;2],
|
||||||
pub selected: ArrangerSelection,
|
pub selected: ArrangerSelection,
|
||||||
pub mode: ArrangerMode,
|
|
||||||
pub color: ItemPalette,
|
pub color: ItemPalette,
|
||||||
pub size: Measure<TuiOut>,
|
pub size: Measure<TuiOut>,
|
||||||
pub note_buf: Vec<u8>,
|
pub note_buf: Vec<u8>,
|
||||||
|
|
@ -67,30 +65,6 @@ has_phrases!(|self: Arranger|self.pool.phrases);
|
||||||
has_editor!(|self: Arranger|self.editor);
|
has_editor!(|self: Arranger|self.editor);
|
||||||
handle!(TuiIn: |self: Arranger, input|ArrangerCommand::execute_with_state(self, input.event()));
|
handle!(TuiIn: |self: Arranger, input|ArrangerCommand::execute_with_state(self, input.event()));
|
||||||
impl Arranger {
|
impl Arranger {
|
||||||
pub fn new (jack: &Arc<RwLock<JackConnection>>) -> Self {
|
|
||||||
let clock = Clock::from(jack);
|
|
||||||
let phrase = Arc::new(RwLock::new(MidiClip::new(
|
|
||||||
"Clip", true, 4 * clock.timebase.ppq.get() as usize,
|
|
||||||
None, Some(ItemColor::random().into())
|
|
||||||
)));
|
|
||||||
Self {
|
|
||||||
clock,
|
|
||||||
pool: (&phrase).into(),
|
|
||||||
editor: (&phrase).into(),
|
|
||||||
selected: ArrangerSelection::Clip(0, 0),
|
|
||||||
scenes: vec![],
|
|
||||||
tracks: vec![],
|
|
||||||
color: ItemPalette::random(),
|
|
||||||
mode: ArrangerMode::V(1),
|
|
||||||
size: Measure::new(),
|
|
||||||
splits: [12, 20],
|
|
||||||
midi_buf: vec![vec![];65536],
|
|
||||||
note_buf: vec![],
|
|
||||||
perf: PerfModel::default(),
|
|
||||||
jack: jack.clone(),
|
|
||||||
compact: true,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pub fn selected (&self) -> ArrangerSelection {
|
pub fn selected (&self) -> ArrangerSelection {
|
||||||
self.selected
|
self.selected
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,26 +0,0 @@
|
||||||
use crate::*;
|
|
||||||
/// Display mode of arranger
|
|
||||||
#[derive(Clone, PartialEq)]
|
|
||||||
pub enum ArrangerMode {
|
|
||||||
/// Tracks are columns
|
|
||||||
V(usize),
|
|
||||||
/// Tracks are rows
|
|
||||||
H,
|
|
||||||
}
|
|
||||||
impl<E: Output> Content<E> for ArrangerMode {}
|
|
||||||
/// Arranger display mode can be cycled
|
|
||||||
impl ArrangerMode {
|
|
||||||
/// Cycle arranger display mode
|
|
||||||
pub fn next (&mut self) {
|
|
||||||
*self = match self {
|
|
||||||
Self::H => Self::V(1),
|
|
||||||
Self::V(1) => Self::V(2),
|
|
||||||
Self::V(2) => Self::V(2),
|
|
||||||
Self::V(0) => Self::H,
|
|
||||||
Self::V(_) => Self::V(0),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fn any_size <E: Output> (_: E::Size) -> Perhaps<E::Size>{
|
|
||||||
Ok(Some([0.into(),0.into()].into()))
|
|
||||||
}
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue