Invert &Options to Option<&T> (#10315)

Elide the reference for `Copy` type (`usize`)
Use the canonical deref where possible.
* `&Box` -> `&`
* `&String` -> `&str`
* `&PathBuf` -> `&Path`

Skips the ctrl-C handler for now.
This commit is contained in:
Stefan Holderbach 2023-09-13 01:00:58 +02:00 committed by GitHub
parent 3e14dc3eb8
commit a14e9e0a2e
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
24 changed files with 87 additions and 83 deletions

View file

@ -125,7 +125,7 @@ pub fn parse_sql_expr(expr: &SqlExpr) -> Result<Expr> {
}) })
} }
fn apply_window_spec(expr: Expr, window_type: &Option<WindowType>) -> Result<Expr> { fn apply_window_spec(expr: Expr, window_type: Option<&WindowType>) -> Result<Expr> {
Ok(match &window_type { Ok(match &window_type {
Some(wtype) => match wtype { Some(wtype) => match wtype {
WindowType::WindowSpec(window_spec) => { WindowType::WindowSpec(window_spec) => {
@ -168,13 +168,13 @@ fn parse_sql_function(sql_function: &SQLFunction) -> Result<Expr> {
sql_function.distinct, sql_function.distinct,
) { ) {
("sum", [FunctionArgExpr::Expr(expr)], false) => { ("sum", [FunctionArgExpr::Expr(expr)], false) => {
apply_window_spec(parse_sql_expr(expr)?, &sql_function.over)?.sum() apply_window_spec(parse_sql_expr(expr)?, sql_function.over.as_ref())?.sum()
} }
("count", [FunctionArgExpr::Expr(expr)], false) => { ("count", [FunctionArgExpr::Expr(expr)], false) => {
apply_window_spec(parse_sql_expr(expr)?, &sql_function.over)?.count() apply_window_spec(parse_sql_expr(expr)?, sql_function.over.as_ref())?.count()
} }
("count", [FunctionArgExpr::Expr(expr)], true) => { ("count", [FunctionArgExpr::Expr(expr)], true) => {
apply_window_spec(parse_sql_expr(expr)?, &sql_function.over)?.n_unique() apply_window_spec(parse_sql_expr(expr)?, sql_function.over.as_ref())?.n_unique()
} }
// Special case for wildcard args to count function. // Special case for wildcard args to count function.
("count", [FunctionArgExpr::Wildcard], false) => lit(1i32).count(), ("count", [FunctionArgExpr::Wildcard], false) => lit(1i32).count(),

View file

@ -44,7 +44,7 @@ enum InputNumType {
SignedEight, SignedEight,
} }
fn get_number_bytes(number_bytes: &Option<Spanned<String>>) -> NumberBytes { fn get_number_bytes(number_bytes: Option<&Spanned<String>>) -> NumberBytes {
match number_bytes.as_ref() { match number_bytes.as_ref() {
None => NumberBytes::Eight, None => NumberBytes::Eight,
Some(size) => match size.item.as_str() { Some(size) => match size.item.as_str() {

View file

@ -57,7 +57,7 @@ impl Command for BitsNot {
let signed = call.has_flag("signed"); let signed = call.has_flag("signed");
let number_bytes: Option<Spanned<String>> = let number_bytes: Option<Spanned<String>> =
call.get_flag(engine_state, stack, "number-bytes")?; call.get_flag(engine_state, stack, "number-bytes")?;
let bytes_len = get_number_bytes(&number_bytes); let bytes_len = get_number_bytes(number_bytes.as_ref());
if let NumberBytes::Invalid = bytes_len { if let NumberBytes::Invalid = bytes_len {
if let Some(val) = number_bytes { if let Some(val) = number_bytes {
return Err(ShellError::UnsupportedInput( return Err(ShellError::UnsupportedInput(

View file

@ -60,7 +60,7 @@ impl Command for BitsRol {
let signed = call.has_flag("signed"); let signed = call.has_flag("signed");
let number_bytes: Option<Spanned<String>> = let number_bytes: Option<Spanned<String>> =
call.get_flag(engine_state, stack, "number-bytes")?; call.get_flag(engine_state, stack, "number-bytes")?;
let bytes_len = get_number_bytes(&number_bytes); let bytes_len = get_number_bytes(number_bytes.as_ref());
if let NumberBytes::Invalid = bytes_len { if let NumberBytes::Invalid = bytes_len {
if let Some(val) = number_bytes { if let Some(val) = number_bytes {
return Err(ShellError::UnsupportedInput( return Err(ShellError::UnsupportedInput(

View file

@ -60,7 +60,7 @@ impl Command for BitsRor {
let signed = call.has_flag("signed"); let signed = call.has_flag("signed");
let number_bytes: Option<Spanned<String>> = let number_bytes: Option<Spanned<String>> =
call.get_flag(engine_state, stack, "number-bytes")?; call.get_flag(engine_state, stack, "number-bytes")?;
let bytes_len = get_number_bytes(&number_bytes); let bytes_len = get_number_bytes(number_bytes.as_ref());
if let NumberBytes::Invalid = bytes_len { if let NumberBytes::Invalid = bytes_len {
if let Some(val) = number_bytes { if let Some(val) = number_bytes {
return Err(ShellError::UnsupportedInput( return Err(ShellError::UnsupportedInput(

View file

@ -60,7 +60,7 @@ impl Command for BitsShl {
let signed = call.has_flag("signed"); let signed = call.has_flag("signed");
let number_bytes: Option<Spanned<String>> = let number_bytes: Option<Spanned<String>> =
call.get_flag(engine_state, stack, "number-bytes")?; call.get_flag(engine_state, stack, "number-bytes")?;
let bytes_len = get_number_bytes(&number_bytes); let bytes_len = get_number_bytes(number_bytes.as_ref());
if let NumberBytes::Invalid = bytes_len { if let NumberBytes::Invalid = bytes_len {
if let Some(val) = number_bytes { if let Some(val) = number_bytes {
return Err(ShellError::UnsupportedInput( return Err(ShellError::UnsupportedInput(

View file

@ -60,7 +60,7 @@ impl Command for BitsShr {
let signed = call.has_flag("signed"); let signed = call.has_flag("signed");
let number_bytes: Option<Spanned<String>> = let number_bytes: Option<Spanned<String>> =
call.get_flag(engine_state, stack, "number-bytes")?; call.get_flag(engine_state, stack, "number-bytes")?;
let bytes_len = get_number_bytes(&number_bytes); let bytes_len = get_number_bytes(number_bytes.as_ref());
if let NumberBytes::Invalid = bytes_len { if let NumberBytes::Invalid = bytes_len {
if let Some(val) = number_bytes { if let Some(val) = number_bytes {
return Err(ShellError::UnsupportedInput( return Err(ShellError::UnsupportedInput(

View file

@ -48,7 +48,7 @@ enum HorizontalDirection {
fn horizontal_rotate_value( fn horizontal_rotate_value(
value: Value, value: Value,
by: &Option<usize>, by: Option<usize>,
cells_only: bool, cells_only: bool,
direction: &HorizontalDirection, direction: &HorizontalDirection,
) -> Result<Value, ShellError> { ) -> Result<Value, ShellError> {

View file

@ -106,7 +106,7 @@ impl Command for RollLeft {
let cells_only = call.has_flag("cells-only"); let cells_only = call.has_flag("cells-only");
let value = input.into_value(call.head); let value = input.into_value(call.head);
let rotated_value = let rotated_value =
horizontal_rotate_value(value, &by, cells_only, &HorizontalDirection::Left)?; horizontal_rotate_value(value, by, cells_only, &HorizontalDirection::Left)?;
Ok(rotated_value.into_pipeline_data().set_metadata(metadata)) Ok(rotated_value.into_pipeline_data().set_metadata(metadata))
} }

View file

@ -106,7 +106,7 @@ impl Command for RollRight {
let cells_only = call.has_flag("cells-only"); let cells_only = call.has_flag("cells-only");
let value = input.into_value(call.head); let value = input.into_value(call.head);
let rotated_value = let rotated_value =
horizontal_rotate_value(value, &by, cells_only, &HorizontalDirection::Right)?; horizontal_rotate_value(value, by, cells_only, &HorizontalDirection::Right)?;
Ok(rotated_value.into_pipeline_data().set_metadata(metadata)) Ok(rotated_value.into_pipeline_data().set_metadata(metadata))
} }

View file

@ -164,7 +164,7 @@ impl Command for ToHtml {
fn get_theme_from_asset_file( fn get_theme_from_asset_file(
is_dark: bool, is_dark: bool,
theme: &Option<Spanned<String>>, theme: Option<&Spanned<String>>,
) -> Result<HashMap<&'static str, String>, ShellError> { ) -> Result<HashMap<&'static str, String>, ShellError> {
let theme_name = match theme { let theme_name = match theme {
Some(s) => &s.item, Some(s) => &s.item,
@ -301,7 +301,7 @@ fn to_html(
None => head, None => head,
}; };
let color_hm = get_theme_from_asset_file(dark, &theme); let color_hm = get_theme_from_asset_file(dark, theme.as_ref());
let color_hm = match color_hm { let color_hm = match color_hm {
Ok(c) => c, Ok(c) => c,
_ => { _ => {

View file

@ -98,12 +98,12 @@ fn operate(
if column_paths.is_empty() { if column_paths.is_empty() {
input.map( input.map(
move |v| process_value(&v, &text), move |v| process_value(&v, text.as_deref()),
engine_state.ctrlc.clone(), engine_state.ctrlc.clone(),
) )
} else { } else {
input.map( input.map(
move |v| process_each_path(v, &column_paths, &text, command_span), move |v| process_each_path(v, &column_paths, text.as_deref(), command_span),
engine_state.ctrlc.clone(), engine_state.ctrlc.clone(),
) )
} }
@ -112,7 +112,7 @@ fn operate(
fn process_each_path( fn process_each_path(
mut value: Value, mut value: Value,
column_paths: &[CellPath], column_paths: &[CellPath],
text: &Option<String>, text: Option<&str>,
command_span: Span, command_span: Span,
) -> Value { ) -> Value {
for path in column_paths { for path in column_paths {
@ -124,11 +124,11 @@ fn process_each_path(
value value
} }
fn process_value(value: &Value, text: &Option<String>) -> Value { fn process_value(value: &Value, text: Option<&str>) -> Value {
let span = value.span(); let span = value.span();
match value { match value {
Value::String { val, .. } => { Value::String { val, .. } => {
let text = text.as_deref().unwrap_or(val.as_str()); let text = text.unwrap_or(val.as_str());
let result = add_osc_link(text, val.as_str()); let result = add_osc_link(text, val.as_str());
Value::string(result, span) Value::string(result, span)
} }

View file

@ -54,23 +54,33 @@ impl Command for Metadata {
} => { } => {
let origin = stack.get_var_with_origin(*var_id, *span)?; let origin = stack.get_var_with_origin(*var_id, *span)?;
Ok(build_metadata_record(&origin, &input.metadata(), head) Ok(
.into_pipeline_data()) build_metadata_record(&origin, input.metadata().as_deref(), head)
.into_pipeline_data(),
)
} }
_ => { _ => {
let val: Value = call.req(engine_state, stack, 0)?; let val: Value = call.req(engine_state, stack, 0)?;
Ok(build_metadata_record(&val, &input.metadata(), head) Ok(
.into_pipeline_data()) build_metadata_record(&val, input.metadata().as_deref(), head)
.into_pipeline_data(),
)
} }
} }
} else { } else {
let val: Value = call.req(engine_state, stack, 0)?; let val: Value = call.req(engine_state, stack, 0)?;
Ok(build_metadata_record(&val, &input.metadata(), head).into_pipeline_data()) Ok(
build_metadata_record(&val, input.metadata().as_deref(), head)
.into_pipeline_data(),
)
} }
} }
Some(_) => { Some(_) => {
let val: Value = call.req(engine_state, stack, 0)?; let val: Value = call.req(engine_state, stack, 0)?;
Ok(build_metadata_record(&val, &input.metadata(), head).into_pipeline_data()) Ok(
build_metadata_record(&val, input.metadata().as_deref(), head)
.into_pipeline_data(),
)
} }
None => { None => {
let mut record = Record::new(); let mut record = Record::new();
@ -109,11 +119,7 @@ impl Command for Metadata {
} }
} }
fn build_metadata_record( fn build_metadata_record(arg: &Value, metadata: Option<&PipelineMetadata>, head: Span) -> Value {
arg: &Value,
metadata: &Option<Box<PipelineMetadata>>,
head: Span,
) -> Value {
let mut record = Record::new(); let mut record = Record::new();
let span = arg.span(); let span = arg.span();
@ -128,7 +134,7 @@ fn build_metadata_record(
), ),
); );
if let Some(x) = metadata.as_deref() { if let Some(x) = metadata {
match x { match x {
PipelineMetadata { PipelineMetadata {
data_source: DataSource::Ls, data_source: DataSource::Ls,

View file

@ -87,7 +87,7 @@ impl Command for Save {
match input { match input {
PipelineData::ExternalStream { stdout: None, .. } => { PipelineData::ExternalStream { stdout: None, .. } => {
// Open files to possibly truncate them // Open files to possibly truncate them
let _ = get_files(&path, &stderr_path, append, force)?; let _ = get_files(&path, stderr_path.as_ref(), append, force)?;
Ok(PipelineData::empty()) Ok(PipelineData::empty())
} }
PipelineData::ExternalStream { PipelineData::ExternalStream {
@ -95,7 +95,7 @@ impl Command for Save {
stderr, stderr,
.. ..
} => { } => {
let (file, stderr_file) = get_files(&path, &stderr_path, append, force)?; let (file, stderr_file) = get_files(&path, stderr_path.as_ref(), append, force)?;
// delegate a thread to redirect stderr to result. // delegate a thread to redirect stderr to result.
let handler = stderr.map(|stderr_stream| match stderr_file { let handler = stderr.map(|stderr_stream| match stderr_file {
@ -127,7 +127,7 @@ impl Command for Save {
PipelineData::ListStream(ls, _) PipelineData::ListStream(ls, _)
if raw || prepare_path(&path, append, force)?.0.extension().is_none() => if raw || prepare_path(&path, append, force)?.0.extension().is_none() =>
{ {
let (mut file, _) = get_files(&path, &stderr_path, append, force)?; let (mut file, _) = get_files(&path, stderr_path.as_ref(), append, force)?;
for val in ls { for val in ls {
file.write_all(&value_to_bytes(val)?) file.write_all(&value_to_bytes(val)?)
.map_err(|err| ShellError::IOError(err.to_string()))?; .map_err(|err| ShellError::IOError(err.to_string()))?;
@ -143,7 +143,7 @@ impl Command for Save {
input_to_bytes(input, Path::new(&path.item), raw, engine_state, stack, span)?; input_to_bytes(input, Path::new(&path.item), raw, engine_state, stack, span)?;
// Only open file after successful conversion // Only open file after successful conversion
let (mut file, _) = get_files(&path, &stderr_path, append, force)?; let (mut file, _) = get_files(&path, stderr_path.as_ref(), append, force)?;
file.write_all(&bytes) file.write_all(&bytes)
.map_err(|err| ShellError::IOError(err.to_string()))?; .map_err(|err| ShellError::IOError(err.to_string()))?;
@ -317,7 +317,7 @@ fn open_file(path: &Path, span: Span, append: bool) -> Result<File, ShellError>
/// Get output file and optional stderr file /// Get output file and optional stderr file
fn get_files( fn get_files(
path: &Spanned<PathBuf>, path: &Spanned<PathBuf>,
stderr_path: &Option<Spanned<PathBuf>>, stderr_path: Option<&Spanned<PathBuf>>,
append: bool, append: bool,
force: bool, force: bool,
) -> Result<(File, Option<File>), ShellError> { ) -> Result<(File, Option<File>), ShellError> {

View file

@ -130,7 +130,7 @@ pub fn split_by(
item: v.as_string()?, item: v.as_string()?,
span: name, span: name,
}); });
Ok(split(&splitter, input, name)?) Ok(split(splitter.as_ref(), input, name)?)
} }
// This uses the same format as the 'requires a column name' error in sort_utils.rs // This uses the same format as the 'requires a column name' error in sort_utils.rs
None => Err(ShellError::GenericError( None => Err(ShellError::GenericError(
@ -144,7 +144,7 @@ pub fn split_by(
} }
pub fn split( pub fn split(
column_name: &Option<Spanned<String>>, column_name: Option<&Spanned<String>>,
values: PipelineData, values: PipelineData,
span: Span, span: Span,
) -> Result<PipelineData, ShellError> { ) -> Result<PipelineData, ShellError> {
@ -156,24 +156,21 @@ pub fn split(
match grouper { match grouper {
Grouper::ByColumn(Some(column_name)) => { Grouper::ByColumn(Some(column_name)) => {
let block = let block = move |_, row: &Value| match row.get_data_by_key(&column_name.item) {
Box::new( Some(group_key) => Ok(group_key.as_string()?),
move |_, row: &Value| match row.get_data_by_key(&column_name.item) { None => Err(ShellError::CantFindColumn {
Some(group_key) => Ok(group_key.as_string()?), col_name: column_name.item.to_string(),
None => Err(ShellError::CantFindColumn { span: column_name.span,
col_name: column_name.item.to_string(), src_span: row.span(),
span: column_name.span, }),
src_span: row.span(), };
}),
},
);
data_split(values, &Some(block), span) data_split(values, Some(&block), span)
} }
Grouper::ByColumn(None) => { Grouper::ByColumn(None) => {
let block = Box::new(move |_, row: &Value| row.as_string()); let block = move |_, row: &Value| row.as_string();
data_split(values, &Some(block), span) data_split(values, Some(&block), span)
} }
} }
} }
@ -181,7 +178,7 @@ pub fn split(
#[allow(clippy::type_complexity)] #[allow(clippy::type_complexity)]
fn data_group( fn data_group(
values: &Value, values: &Value,
grouper: &Option<Box<dyn Fn(usize, &Value) -> Result<String, ShellError> + Send>>, grouper: Option<&dyn Fn(usize, &Value) -> Result<String, ShellError>>,
span: Span, span: Span,
) -> Result<Value, ShellError> { ) -> Result<Value, ShellError> {
let mut groups: IndexMap<String, Vec<Value>> = IndexMap::new(); let mut groups: IndexMap<String, Vec<Value>> = IndexMap::new();
@ -209,7 +206,7 @@ fn data_group(
#[allow(clippy::type_complexity)] #[allow(clippy::type_complexity)]
pub fn data_split( pub fn data_split(
value: PipelineData, value: PipelineData,
splitter: &Option<Box<dyn Fn(usize, &Value) -> Result<String, ShellError> + Send>>, splitter: Option<&dyn Fn(usize, &Value) -> Result<String, ShellError>>,
span: Span, span: Span,
) -> Result<PipelineData, ShellError> { ) -> Result<PipelineData, ShellError> {
let mut splits = indexmap::IndexMap::new(); let mut splits = indexmap::IndexMap::new();

View file

@ -234,7 +234,7 @@ fn sort_attributes(val: Value) -> Value {
fn generate_key(item: &ValueCounter) -> Result<String, ShellError> { fn generate_key(item: &ValueCounter) -> Result<String, ShellError> {
let value = sort_attributes(item.val_to_compare.clone()); //otherwise, keys could be different for Records let value = sort_attributes(item.val_to_compare.clone()); //otherwise, keys could be different for Records
value_to_string(&value, Span::unknown(), 0, &None) value_to_string(&value, Span::unknown(), 0, None)
} }
fn generate_results_with_count(head: Span, uniq_values: Vec<ValueCounter>) -> Vec<Value> { fn generate_results_with_count(head: Span, uniq_values: Vec<ValueCounter>) -> Vec<Value> {

View file

@ -61,15 +61,15 @@ impl Command for ToNuon {
let value = input.into_value(span); let value = input.into_value(span);
let nuon_result = if raw { let nuon_result = if raw {
value_to_string(&value, span, 0, &None) value_to_string(&value, span, 0, None)
} else if use_tabs { } else if use_tabs {
let tab_count: usize = call.get_flag(engine_state, stack, "tabs")?.unwrap_or(1); let tab_count: usize = call.get_flag(engine_state, stack, "tabs")?.unwrap_or(1);
value_to_string(&value, span, 0, &Some("\t".repeat(tab_count))) value_to_string(&value, span, 0, Some(&"\t".repeat(tab_count)))
} else if use_indent { } else if use_indent {
let indent: usize = call.get_flag(engine_state, stack, "indent")?.unwrap_or(2); let indent: usize = call.get_flag(engine_state, stack, "indent")?.unwrap_or(2);
value_to_string(&value, span, 0, &Some(" ".repeat(indent))) value_to_string(&value, span, 0, Some(&" ".repeat(indent)))
} else { } else {
value_to_string(&value, span, 0, &None) value_to_string(&value, span, 0, None)
}; };
match nuon_result { match nuon_result {
@ -119,7 +119,7 @@ pub fn value_to_string(
v: &Value, v: &Value,
span: Span, span: Span,
depth: usize, depth: usize,
indent: &Option<String>, indent: Option<&str>,
) -> Result<String, ShellError> { ) -> Result<String, ShellError> {
let (nl, sep) = get_true_separators(indent); let (nl, sep) = get_true_separators(indent);
let idt = get_true_indentation(depth, indent); let idt = get_true_indentation(depth, indent);
@ -290,14 +290,14 @@ pub fn value_to_string(
} }
} }
fn get_true_indentation(depth: usize, indent: &Option<String>) -> String { fn get_true_indentation(depth: usize, indent: Option<&str>) -> String {
match indent { match indent {
Some(i) => i.repeat(depth), Some(i) => i.repeat(depth),
None => "".to_string(), None => "".to_string(),
} }
} }
fn get_true_separators(indent: &Option<String>) -> (String, String) { fn get_true_separators(indent: Option<&str>) -> (String, String) {
match indent { match indent {
Some(_) => ("\n".to_string(), "".to_string()), Some(_) => ("\n".to_string(), "".to_string()),
None => ("".to_string(), " ".to_string()), None => ("".to_string(), " ".to_string()),
@ -308,7 +308,7 @@ fn value_to_string_without_quotes(
v: &Value, v: &Value,
span: Span, span: Span,
depth: usize, depth: usize,
indent: &Option<String>, indent: Option<&str>,
) -> Result<String, ShellError> { ) -> Result<String, ShellError> {
match v { match v {
Value::String { val, .. } => Ok({ Value::String { val, .. } => Ok({

View file

@ -3595,13 +3595,14 @@ pub fn parse_register(working_set: &mut StateWorkingSet, spans: &[Span]) -> Pipe
let signatures = signature.map_or_else( let signatures = signature.map_or_else(
|| { || {
let signatures = get_signature(&path, &shell, &current_envs).map_err(|err| { let signatures =
ParseError::LabeledError( get_signature(&path, shell.as_deref(), &current_envs).map_err(|err| {
"Error getting signatures".into(), ParseError::LabeledError(
err.to_string(), "Error getting signatures".into(),
spans[0], err.to_string(),
) spans[0],
}); )
});
if signatures.is_ok() { if signatures.is_ok() {
// mark plugins file as dirty only when the user is registering plugins // mark plugins file as dirty only when the user is registering plugins

View file

@ -66,7 +66,7 @@ impl Command for PluginDeclaration {
// Decode information from plugin // Decode information from plugin
// Create PipelineData // Create PipelineData
let source_file = Path::new(&self.filename); let source_file = Path::new(&self.filename);
let mut plugin_cmd = create_command(source_file, &self.shell); let mut plugin_cmd = create_command(source_file, self.shell.as_deref());
// We need the current environment variables for `python` based plugins // We need the current environment variables for `python` based plugins
// Or we'll likely have a problem when a plugin is implemented in a virtual Python environment. // Or we'll likely have a problem when a plugin is implemented in a virtual Python environment.
let current_envs = nu_engine::env::env_to_strings(engine_state, stack).unwrap_or_default(); let current_envs = nu_engine::env::env_to_strings(engine_state, stack).unwrap_or_default();
@ -175,7 +175,7 @@ impl Command for PluginDeclaration {
pipeline_data pipeline_data
} }
fn is_plugin(&self) -> Option<(&PathBuf, &Option<PathBuf>)> { fn is_plugin(&self) -> Option<(&Path, Option<&Path>)> {
Some((&self.filename, &self.shell)) Some((&self.filename, self.shell.as_deref()))
} }
} }

View file

@ -8,7 +8,7 @@ use crate::EncodingType;
use std::env; use std::env;
use std::fmt::Write; use std::fmt::Write;
use std::io::{BufReader, ErrorKind, Read, Write as WriteTrait}; use std::io::{BufReader, ErrorKind, Read, Write as WriteTrait};
use std::path::{Path, PathBuf}; use std::path::Path;
use std::process::{Child, ChildStdout, Command as CommandSys, Stdio}; use std::process::{Child, ChildStdout, Command as CommandSys, Stdio};
use nu_protocol::{CustomValue, PluginSignature, ShellError, Span, Value}; use nu_protocol::{CustomValue, PluginSignature, ShellError, Span, Value};
@ -48,7 +48,7 @@ pub trait PluginEncoder: Clone {
) -> Result<PluginResponse, ShellError>; ) -> Result<PluginResponse, ShellError>;
} }
pub(crate) fn create_command(path: &Path, shell: &Option<PathBuf>) -> CommandSys { pub(crate) fn create_command(path: &Path, shell: Option<&Path>) -> CommandSys {
let mut process = match (path.extension(), shell) { let mut process = match (path.extension(), shell) {
(_, Some(shell)) => { (_, Some(shell)) => {
let mut process = std::process::Command::new(shell); let mut process = std::process::Command::new(shell);
@ -124,7 +124,7 @@ pub(crate) fn call_plugin(
#[doc(hidden)] // Note: not for plugin authors / only used in nu-parser #[doc(hidden)] // Note: not for plugin authors / only used in nu-parser
pub fn get_signature( pub fn get_signature(
path: &Path, path: &Path,
shell: &Option<PathBuf>, shell: Option<&Path>,
current_envs: &HashMap<String, String>, current_envs: &HashMap<String, String>,
) -> Result<Vec<PluginSignature>, ShellError> { ) -> Result<Vec<PluginSignature>, ShellError> {
let mut plugin_cmd = create_command(path, shell); let mut plugin_cmd = create_command(path, shell);

View file

@ -45,7 +45,7 @@ impl CustomValue for PluginCustomValue {
&self, &self,
span: nu_protocol::Span, span: nu_protocol::Span,
) -> Result<nu_protocol::Value, nu_protocol::ShellError> { ) -> Result<nu_protocol::Value, nu_protocol::ShellError> {
let mut plugin_cmd = create_command(&self.filename, &self.shell); let mut plugin_cmd = create_command(&self.filename, self.shell.as_deref());
let mut child = plugin_cmd.spawn().map_err(|err| { let mut child = plugin_cmd.spawn().map_err(|err| {
ShellError::GenericError( ShellError::GenericError(

View file

@ -1,4 +1,4 @@
use std::path::PathBuf; use std::path::Path;
use crate::{ast::Call, Alias, BlockId, Example, PipelineData, ShellError, Signature}; use crate::{ast::Call, Alias, BlockId, Example, PipelineData, ShellError, Signature};
@ -92,7 +92,7 @@ pub trait Command: Send + Sync + CommandClone {
} }
// Is a plugin command (returns plugin's path, type of shell if the declaration is a plugin) // Is a plugin command (returns plugin's path, type of shell if the declaration is a plugin)
fn is_plugin(&self) -> Option<(&PathBuf, &Option<PathBuf>)> { fn is_plugin(&self) -> Option<(&Path, Option<&Path>)> {
None None
} }

View file

@ -210,7 +210,7 @@ pub(crate) fn set_config_path(
cwd: &Path, cwd: &Path,
default_config_name: &str, default_config_name: &str,
key: &str, key: &str,
config_file: &Option<Spanned<String>>, config_file: Option<&Spanned<String>>,
) { ) {
let config_path = match config_file { let config_path = match config_file {
Some(s) => canonicalize_with(&s.item, cwd).ok(), Some(s) => canonicalize_with(&s.item, cwd).ok(),

View file

@ -129,7 +129,7 @@ fn main() -> Result<()> {
&init_cwd, &init_cwd,
"config.nu", "config.nu",
"config-path", "config-path",
&parsed_nu_cli_args.config_file, parsed_nu_cli_args.config_file.as_ref(),
); );
set_config_path( set_config_path(
@ -137,7 +137,7 @@ fn main() -> Result<()> {
&init_cwd, &init_cwd,
"env.nu", "env.nu",
"env-path", "env-path",
&parsed_nu_cli_args.env_file, parsed_nu_cli_args.env_file.as_ref(),
); );
perf( perf(
"set_config_path", "set_config_path",