mirror of
https://codeberg.org/unspeaker/tek.git
synced 2025-12-07 04:06:45 +01:00
wip: refactor pt.23: 47 errors
This commit is contained in:
parent
e7e57cea1e
commit
ff4698d046
3 changed files with 31 additions and 83 deletions
|
|
@ -18,24 +18,3 @@ impl<'a, T: ArrangerModelApi + Send + Sync> Audio for ArrangerRefAudio<'a, T> {
|
|||
Control::Continue
|
||||
}
|
||||
}
|
||||
|
||||
//pub struct ArrangerAudio(pub Arc<RwLock<ArrangerModel>>);
|
||||
|
||||
//impl Audio for ArrangerAudio {
|
||||
//#[inline] fn process (&mut self, client: &Client, scope: &ProcessScope) -> Control {
|
||||
//ArrangerRefAudio(&mut*self.0.write().unwrap()).process(client, scope)
|
||||
//}
|
||||
//}
|
||||
|
||||
//pub struct ArrangerRefAudio<'a>(pub &'a mut ArrangerModel);
|
||||
|
||||
//impl<'a> Audio for ArrangerRefAudio<'a> {
|
||||
//#[inline] fn process (&mut self, client: &Client, scope: &ProcessScope) -> Control {
|
||||
//for track in self.0.tracks.iter_mut() {
|
||||
//if MIDIPlayerAudio::from(&mut track.player).process(client, scope) == Control::Quit {
|
||||
//return Control::Quit
|
||||
//}
|
||||
//}
|
||||
//Control::Continue
|
||||
//}
|
||||
//}
|
||||
|
|
|
|||
|
|
@ -12,35 +12,18 @@ pub type ArrangerApp = AppContainer<
|
|||
impl TryFrom<&Arc<RwLock<JackClient>>> for ArrangerApp {
|
||||
type Error = Box<dyn std::error::Error>;
|
||||
fn try_from (jack: &Arc<RwLock<JackClient>>) -> Usually<Self> {
|
||||
let clock = Arc::new(Clock::from(Instant::default()));
|
||||
|
||||
let transport = Arc::new(RwLock::new(tek_api::Transport {
|
||||
metronome: false,
|
||||
transport: jack.read().unwrap().transport(),
|
||||
jack: jack.clone(),
|
||||
clock: clock.clone()
|
||||
}));
|
||||
|
||||
let phrases = Arc::new(RwLock::new(PhrasePool { phrases: vec![] }));
|
||||
|
||||
let model = Arc::new(RwLock::new(Arranger {
|
||||
arrangement: Arc::new(RwLock::new(ArrangerModel {
|
||||
let model = Arc::new(RwLock::new(ArrangerModel {
|
||||
name: Arc::new(RwLock::new(String::new())),
|
||||
phrases: vec![],
|
||||
scenes: vec![],
|
||||
tracks: vec![],
|
||||
transport: TransportModel {
|
||||
metronome: false,
|
||||
transport: jack.read().unwrap().transport(),
|
||||
clock: Arc::new(Clock::from(Instant::default())),
|
||||
jack: jack.clone(),
|
||||
clock: clock.clone(),
|
||||
name: Arc::new(RwLock::new(String::new())),
|
||||
phrases: phrases.clone(), // FIXME
|
||||
tracks: vec![],
|
||||
scenes: vec![],
|
||||
})),
|
||||
sequencer: Arc::new(RwLock::new(SequencerModel {
|
||||
transport: transport.clone(),
|
||||
phrases: phrases.clone(),
|
||||
player: Arc::new(RwLock::new(MIDIPlayer::new(jack, &clock, "preview")?)),
|
||||
})),
|
||||
transport: transport.clone(),
|
||||
phrases: phrases.clone(),
|
||||
},
|
||||
}));
|
||||
|
||||
Ok(Self::new(
|
||||
&model,
|
||||
ArrangerView::from(&model),
|
||||
|
|
@ -51,15 +34,8 @@ impl TryFrom<&Arc<RwLock<JackClient>>> for ArrangerApp {
|
|||
}
|
||||
}
|
||||
|
||||
pub struct Arranger {
|
||||
pub arrangement: Arc<RwLock<ArrangerModel>>,
|
||||
pub sequencer: Arc<RwLock<SequencerModel>>,
|
||||
pub transport: Arc<RwLock<tek_api::Transport>>,
|
||||
pub phrases: Arc<RwLock<PhrasePool>>,
|
||||
}
|
||||
|
||||
impl<E: Engine> From<&Arc<RwLock<Arranger>>> for ArrangerView<E> {
|
||||
fn from (model: &Arc<RwLock<Arranger>>) -> Self {
|
||||
impl<E: Engine> From<&Arc<RwLock<ArrangerModel>>> for ArrangerView<E> {
|
||||
fn from (model: &Arc<RwLock<ArrangerModel>>) -> Self {
|
||||
let mut view = Self {
|
||||
model: model.clone(),
|
||||
sequencer: SequencerView::from(&model.read().unwrap().sequencer),
|
||||
|
|
@ -78,7 +54,7 @@ impl<E: Engine> From<&Arc<RwLock<Arranger>>> for ArrangerView<E> {
|
|||
|
||||
/// Root level object for standalone `tek_arranger`
|
||||
pub struct ArrangerView<E: Engine> {
|
||||
pub model: Arc<RwLock<Arranger>>,
|
||||
pub model: ArrangerModel,
|
||||
/// Sequencer component
|
||||
pub sequencer: SequencerView<E>,
|
||||
/// Height of arrangement
|
||||
|
|
@ -124,13 +100,13 @@ impl<E: Engine> Audio for ArrangerView<E> {
|
|||
#[inline] fn process (&mut self, _: &Client, _: &ProcessScope) -> Control {
|
||||
// FIXME: one of these per playing track
|
||||
if let ArrangerFocus::Clip(t, s) = self.selected {
|
||||
let phrase = self.model.scenes.get(s).map(|scene|scene.clips.get(t));
|
||||
let phrase = self.model.scenes().get(s).map(|scene|scene.clips.get(t));
|
||||
if let Some(Some(Some(phrase))) = phrase {
|
||||
if let Some(track) = self.model.tracks.get(t) {
|
||||
if let Some(track) = self.model.tracks().get(t) {
|
||||
if let Some((ref started_at, Some(ref playing))) = track.player.phrase {
|
||||
let phrase = phrase.read().unwrap();
|
||||
if *playing.read().unwrap() == *phrase {
|
||||
let pulse = self.sequencer.transport.model.clock.current.pulse.get();
|
||||
let pulse = self.sequencer.transport.model.clock().current.pulse.get();
|
||||
let start = started_at.pulse.get();
|
||||
let now = (pulse - start) % phrase.length as f64;
|
||||
self.sequencer.editor.now.set(now);
|
||||
|
|
@ -192,17 +168,15 @@ impl<E: Engine> ArrangerView<E> {
|
|||
|
||||
/// Focus the editor with the current phrase
|
||||
pub fn show_phrase (&mut self) {
|
||||
let arrangement = self.model.read().unwrap().arrangement.read().unwrap();
|
||||
self.sequencer.editor.show(self.selected_phrase().as_ref());
|
||||
}
|
||||
|
||||
pub fn activate (&mut self) {
|
||||
let arrangement = self.model.read().unwrap().arrangement.read().unwrap();
|
||||
match self.selected {
|
||||
ArrangerFocus::Scene(s) => {
|
||||
for (t, track) in self.model.tracks.iter_mut().enumerate() {
|
||||
for (t, track) in self.model.tracks_mut().iter_mut().enumerate() {
|
||||
let player = &mut track.player;
|
||||
let clip = self.model.scenes[s].clips[t].as_ref();
|
||||
let clip = self.model.scenes()[s].clips[t].as_ref();
|
||||
if player.phrase.is_some() || clip.is_some() {
|
||||
player.enqueue_next(clip);
|
||||
}
|
||||
|
|
@ -214,25 +188,23 @@ impl<E: Engine> ArrangerView<E> {
|
|||
//}
|
||||
},
|
||||
ArrangerFocus::Clip(t, s) => {
|
||||
let clip = self.model.scenes[s].clips[t].as_ref();
|
||||
self.model.tracks[t].player.enqueue_next(clip);
|
||||
let clip = self.model.scenes()[s].clips[t].as_ref();
|
||||
self.model.tracks_mut()[t].player.enqueue_next(clip);
|
||||
},
|
||||
_ => {}
|
||||
}
|
||||
}
|
||||
|
||||
pub fn is_first_row (&self) -> bool {
|
||||
let arrangement = self.model.read().unwrap().arrangement.read().unwrap();
|
||||
let selected = self.selected;
|
||||
selected.is_mix() || selected.is_track()
|
||||
}
|
||||
|
||||
pub fn is_last_row (&self) -> bool {
|
||||
let arrangement = self.model.read().unwrap().arrangement.read().unwrap();
|
||||
let selected = self.selected;
|
||||
(self.model.scenes.len() == 0 && (selected.is_mix() || selected.is_track())) || match selected {
|
||||
ArrangerFocus::Scene(s) => s == self.model.scenes.len() - 1,
|
||||
ArrangerFocus::Clip(_, s) => s == self.model.scenes.len() - 1,
|
||||
(self.model.scenes().len() == 0 && (selected.is_mix() || selected.is_track())) || match selected {
|
||||
ArrangerFocus::Scene(s) => s == self.model.scenes().len() - 1,
|
||||
ArrangerFocus::Clip(_, s) => s == self.model.scenes().len() - 1,
|
||||
_ => false
|
||||
}
|
||||
}
|
||||
|
|
@ -244,29 +216,28 @@ impl<E: Engine> ArrangerView<E> {
|
|||
}
|
||||
|
||||
pub fn randomize_color (&mut self) {
|
||||
let arrangement = self.model.read().unwrap().arrangement.read().unwrap();
|
||||
match self.selected {
|
||||
ArrangerFocus::Mix => {
|
||||
self.color = ItemColor::random_dark()
|
||||
},
|
||||
ArrangerFocus::Track(t) => {
|
||||
self.model.tracks[t].color = ItemColor::random()
|
||||
self.model.tracks_mu()[t].color = ItemColor::random()
|
||||
},
|
||||
ArrangerFocus::Scene(s) => {
|
||||
self.model.scenes[s].color = ItemColor::random()
|
||||
self.model.scenes_mut()[s].color = ItemColor::random()
|
||||
},
|
||||
ArrangerFocus::Clip(t, s) => {
|
||||
if let Some(phrase) = &self.model.scenes[s].clips[t] {
|
||||
if let Some(phrase) = &self.model.scenes_mut()[s].clips[t] {
|
||||
phrase.write().unwrap().color = ItemColorTriplet::random();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
pub fn selected_scene (&self) -> Option<&ArrangerScene> {
|
||||
self.selected.scene().map(|s|self.model.scenes.get(s)).flatten()
|
||||
self.selected.scene().map(|s|self.model.scenes().get(s)).flatten()
|
||||
}
|
||||
pub fn selected_scene_mut (&mut self) -> Option<&mut ArrangerScene> {
|
||||
self.selected.scene().map(|s|self.model.scenes.get_mut(s)).flatten()
|
||||
self.selected.scene().map(|s|self.model.scenes_mut().get_mut(s)).flatten()
|
||||
}
|
||||
pub fn selected_phrase (&self) -> Option<Arc<RwLock<Phrase>>> {
|
||||
self.selected_scene()?.clips.get(self.selected.track()?)?.clone()
|
||||
|
|
|
|||
|
|
@ -1,5 +1,4 @@
|
|||
use crate::*;
|
||||
use tek_api::Transport;
|
||||
|
||||
pub type TransportApp = AppContainer<
|
||||
Tui,
|
||||
|
|
@ -13,13 +12,12 @@ pub type TransportApp = AppContainer<
|
|||
impl TryFrom<&Arc<RwLock<JackClient>>> for TransportApp {
|
||||
type Error = Box<dyn std::error::Error>;
|
||||
fn try_from (jack: &Arc<RwLock<JackClient>>) -> Usually<Self> {
|
||||
let model = Arc::new(RwLock::new(Transport {
|
||||
let model = Arc::new(RwLock::new(TransportModel {
|
||||
metronome: false,
|
||||
transport: jack.read().unwrap().transport(),
|
||||
jack: jack.clone(),
|
||||
clock: Arc::new(Clock::from(Instant::default()))
|
||||
}));
|
||||
|
||||
Ok(Self::new(
|
||||
&model,
|
||||
TransportView::from(&model),
|
||||
|
|
@ -33,8 +31,8 @@ impl TryFrom<&Arc<RwLock<JackClient>>> for TransportApp {
|
|||
/// Stores and displays time-related info.
|
||||
#[derive(Debug)]
|
||||
pub struct TransportView<E: Engine> {
|
||||
_engine: PhantomData<E>,
|
||||
pub model: Arc<RwLock<Transport>>,
|
||||
_engine: PhantomData<E>,
|
||||
pub model: TransportModel,
|
||||
pub focus: TransportViewFocus,
|
||||
pub focused: bool,
|
||||
pub size: Measure<E>,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue