Feat: optimizations
This commit is contained in:
@@ -75,7 +75,6 @@ fn render_top_layout(
|
||||
idx += 1;
|
||||
}
|
||||
if has_preview {
|
||||
let user_words: HashSet<String> = app.dict.lock().keys().cloned().collect();
|
||||
let has_prelude = !app.project_state.project.prelude.trim().is_empty()
|
||||
|| !app.project_state.project.banks[app.editor_ctx.bank]
|
||||
.prelude
|
||||
@@ -84,10 +83,10 @@ fn render_top_layout(
|
||||
if has_prelude {
|
||||
let [script_area, prelude_area] =
|
||||
Layout::horizontal([Constraint::Fill(1), Constraint::Fill(1)]).areas(areas[idx]);
|
||||
render_script_preview(frame, app, snapshot, &user_words, script_area);
|
||||
render_prelude_preview(frame, app, &user_words, prelude_area);
|
||||
render_script_preview(frame, app, snapshot, &app.dict_keys, script_area);
|
||||
render_prelude_preview(frame, app, &app.dict_keys, prelude_area);
|
||||
} else {
|
||||
render_script_preview(frame, app, snapshot, &user_words, areas[idx]);
|
||||
render_script_preview(frame, app, snapshot, &app.dict_keys, areas[idx]);
|
||||
}
|
||||
idx += 1;
|
||||
}
|
||||
@@ -186,19 +185,12 @@ fn render_viz_area(
|
||||
Orientation::Horizontal
|
||||
};
|
||||
|
||||
let user_words_once: Option<HashSet<String>> = if panels.iter().any(|p| matches!(p, VizPanel::Preview)) {
|
||||
Some(app.dict.lock().keys().cloned().collect())
|
||||
} else {
|
||||
None
|
||||
};
|
||||
|
||||
for (panel, panel_area) in panels.iter().zip(areas.iter()) {
|
||||
match panel {
|
||||
VizPanel::Scope => render_scope(frame, app, *panel_area, orientation),
|
||||
VizPanel::Spectrum => render_spectrum(frame, app, *panel_area),
|
||||
VizPanel::Lissajous => render_lissajous(frame, app, *panel_area),
|
||||
VizPanel::Preview => {
|
||||
let user_words = user_words_once.as_ref().expect("user_words initialized");
|
||||
let has_prelude = !app.project_state.project.prelude.trim().is_empty()
|
||||
|| !app.project_state.project.banks[app.editor_ctx.bank]
|
||||
.prelude
|
||||
@@ -212,10 +204,10 @@ fn render_viz_area(
|
||||
Layout::horizontal([Constraint::Fill(1), Constraint::Fill(1)])
|
||||
.areas(*panel_area)
|
||||
};
|
||||
render_script_preview(frame, app, snapshot, user_words, script_area);
|
||||
render_prelude_preview(frame, app, user_words, prelude_area);
|
||||
render_script_preview(frame, app, snapshot, &app.dict_keys, script_area);
|
||||
render_prelude_preview(frame, app, &app.dict_keys, prelude_area);
|
||||
} else {
|
||||
render_script_preview(frame, app, snapshot, user_words, *panel_area);
|
||||
render_script_preview(frame, app, snapshot, &app.dict_keys, *panel_area);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -675,8 +675,7 @@ fn render_modal(
|
||||
.render_centered(frame, term)
|
||||
}
|
||||
Modal::Editor => {
|
||||
let user_words: HashSet<String> = app.dict.lock().keys().cloned().collect();
|
||||
render_modal_editor(frame, app, snapshot, &user_words, term)
|
||||
render_modal_editor(frame, app, snapshot, &app.dict_keys, term)
|
||||
}
|
||||
Modal::PatternProps {
|
||||
bank,
|
||||
|
||||
@@ -1,5 +1,3 @@
|
||||
use std::collections::HashSet;
|
||||
|
||||
use ratatui::layout::{Alignment, Constraint, Layout, Rect};
|
||||
use ratatui::style::Style;
|
||||
use ratatui::widgets::{Block, Borders, Paragraph};
|
||||
@@ -47,7 +45,7 @@ fn render_editor(frame: &mut Frame, app: &App, snapshot: &SequencerSnapshot, are
|
||||
let editor_area = Rect::new(inner.x, inner.y, inner.width, editor_height);
|
||||
let hint_area = Rect::new(inner.x, inner.y + editor_height, inner.width, 1);
|
||||
|
||||
let user_words: HashSet<String> = app.dict.lock().keys().cloned().collect();
|
||||
let user_words = &app.dict_keys;
|
||||
|
||||
let trace = if app.ui.runtime_highlight && app.playback.playing {
|
||||
snapshot.script_trace()
|
||||
@@ -77,7 +75,7 @@ fn render_editor(frame: &mut Frame, app: &App, snapshot: &SequencerSnapshot, are
|
||||
),
|
||||
None => (Vec::new(), Vec::new(), Vec::new()),
|
||||
};
|
||||
highlight::highlight_line_with_runtime(line, &exec, &sel, &res, &user_words)
|
||||
highlight::highlight_line_with_runtime(line, &exec, &sel, &res, user_words)
|
||||
};
|
||||
|
||||
app.script_editor.editor.render(frame, editor_area, &highlighter);
|
||||
@@ -142,7 +140,6 @@ fn render_sidebar(frame: &mut Frame, app: &App, area: Rect) {
|
||||
idx += 1;
|
||||
}
|
||||
if has_prelude {
|
||||
let user_words: HashSet<String> = app.dict.lock().keys().cloned().collect();
|
||||
super::main_view::render_prelude_preview(frame, app, &user_words, areas[idx]);
|
||||
super::main_view::render_prelude_preview(frame, app, &app.dict_keys, areas[idx]);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user