Fix engine state reference passed to menus
This commit is contained in:
parent
78089b96dc
commit
d8f682113e
|
@ -95,6 +95,7 @@ pub(crate) fn add_menus(
|
||||||
];
|
];
|
||||||
|
|
||||||
let mut engine_state = (*engine_state_ref).clone();
|
let mut engine_state = (*engine_state_ref).clone();
|
||||||
|
let mut menu_eval_results = vec![];
|
||||||
|
|
||||||
for (name, definition) in default_menus {
|
for (name, definition) in default_menus {
|
||||||
if !config
|
if !config
|
||||||
|
@ -118,13 +119,27 @@ pub(crate) fn add_menus(
|
||||||
|
|
||||||
let mut temp_stack = Stack::new().capture();
|
let mut temp_stack = Stack::new().capture();
|
||||||
let input = PipelineData::Empty;
|
let input = PipelineData::Empty;
|
||||||
let res = eval_block::<WithoutDebug>(&engine_state, &mut temp_stack, &block, input)?;
|
menu_eval_results.push(eval_block::<WithoutDebug>(
|
||||||
|
&engine_state,
|
||||||
|
&mut temp_stack,
|
||||||
|
&block,
|
||||||
|
input,
|
||||||
|
)?);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if let PipelineData::Value(value, None) = res {
|
let new_engine_state_ref = Arc::new(engine_state);
|
||||||
for menu in create_menus(&value)? {
|
|
||||||
line_editor =
|
for res in menu_eval_results.into_iter() {
|
||||||
add_menu(line_editor, &menu, engine_state_ref.clone(), stack, config)?;
|
if let PipelineData::Value(value, None) = res {
|
||||||
}
|
for menu in create_menus(&value)? {
|
||||||
|
line_editor = add_menu(
|
||||||
|
line_editor,
|
||||||
|
&menu,
|
||||||
|
new_engine_state_ref.clone(),
|
||||||
|
stack,
|
||||||
|
config,
|
||||||
|
)?;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user