1
0
mirror of https://github.com/nushell/nushell.git synced 2025-01-06 06:19:52 +01:00

let prompt env vars take strings ()

* let prompt env vars take strings

* clippy

* clippy
This commit is contained in:
JT 2022-01-20 21:22:03 -05:00 committed by GitHub
parent 91883bd572
commit ac07d93b02
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1,8 +1,9 @@
use nu_cli::NushellPrompt;
use nu_engine::eval_block;
use nu_parser::parse;
use nu_protocol::{
engine::{EngineState, Stack},
Config, PipelineData, Span,
engine::{EngineState, Stack, StateWorkingSet},
Config, PipelineData, Span, Value,
};
use reedline::Prompt;
@ -55,8 +56,8 @@ fn get_prompt_string(
) -> Option<String> {
stack
.get_env_var(engine_state, prompt)
.and_then(|v| v.as_block().ok())
.and_then(|block_id| {
.and_then(|v| match v {
Value::Block { val: block_id, .. } => {
let block = engine_state.get_block(block_id);
eval_block(
engine_state,
@ -65,6 +66,19 @@ fn get_prompt_string(
PipelineData::new(Span::new(0, 0)), // Don't try this at home, 0 span is ignored
)
.ok()
}
Value::String { val: source, .. } => {
let mut working_set = StateWorkingSet::new(engine_state);
let (block, _) = parse(&mut working_set, None, source.as_bytes(), true);
eval_block(
engine_state,
stack,
&block,
PipelineData::new(Span::new(0, 0)), // Don't try this at home, 0 span is ignored
)
.ok()
}
_ => None,
})
.and_then(|pipeline_data| pipeline_data.collect_string("", config).ok())
}