mirror of
https://github.com/nushell/nushell
synced 2025-01-14 14:14:13 +00:00
Fix ignored clippy lints (#12160)
# Description Fixes some ignored clippy lints. # User-Facing Changes Changes some signatures and return types to `&dyn Command` instead of `&Box<dyn Command`, but I believe this is only an internal change.
This commit is contained in:
parent
77379d7b3d
commit
26786a759e
20 changed files with 93 additions and 112 deletions
|
@ -48,7 +48,6 @@ pub fn build_table(value: Value, description: String, termsize: usize) -> String
|
||||||
|
|
||||||
add_padding_to_widths(&mut widths);
|
add_padding_to_widths(&mut widths);
|
||||||
|
|
||||||
#[allow(clippy::manual_clamp)]
|
|
||||||
let width = val_table_width.max(desc_table_width).min(termsize);
|
let width = val_table_width.max(desc_table_width).min(termsize);
|
||||||
|
|
||||||
let mut desc_table = Table::from_iter([[String::from("description"), desc]]);
|
let mut desc_table = Table::from_iter([[String::from("description"), desc]]);
|
||||||
|
|
|
@ -39,7 +39,6 @@ pub fn try_interaction(
|
||||||
(interaction, confirmed)
|
(interaction, confirmed)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(dead_code)]
|
|
||||||
fn get_interactive_confirmation(prompt: String) -> Result<bool, Box<dyn Error>> {
|
fn get_interactive_confirmation(prompt: String) -> Result<bool, Box<dyn Error>> {
|
||||||
let input = Input::new()
|
let input = Input::new()
|
||||||
.with_prompt(prompt)
|
.with_prompt(prompt)
|
||||||
|
|
|
@ -66,7 +66,6 @@ impl Command for Reverse {
|
||||||
) -> Result<PipelineData, ShellError> {
|
) -> Result<PipelineData, ShellError> {
|
||||||
let metadata = input.metadata();
|
let metadata = input.metadata();
|
||||||
|
|
||||||
#[allow(clippy::needless_collect)]
|
|
||||||
let v: Vec<_> = input.into_iter_strict(call.head)?.collect();
|
let v: Vec<_> = input.into_iter_strict(call.head)?.collect();
|
||||||
let iter = v.into_iter().rev();
|
let iter = v.into_iter().rev();
|
||||||
Ok(iter.into_pipeline_data_with_metadata(metadata, engine_state.ctrlc.clone()))
|
Ok(iter.into_pipeline_data_with_metadata(metadata, engine_state.ctrlc.clone()))
|
||||||
|
|
|
@ -41,9 +41,7 @@ pub fn boolean_fold(
|
||||||
|
|
||||||
let ctrlc = engine_state.ctrlc.clone();
|
let ctrlc = engine_state.ctrlc.clone();
|
||||||
|
|
||||||
// TODO: This Clippy lint is incorrectly triggered in our CI for come reason
|
let eval_block = get_eval_block(engine_state);
|
||||||
#[allow(clippy::needless_borrow)]
|
|
||||||
let eval_block = get_eval_block(&engine_state);
|
|
||||||
|
|
||||||
for value in input.into_interruptible_iter(ctrlc) {
|
for value in input.into_interruptible_iter(ctrlc) {
|
||||||
// with_env() is used here to ensure that each iteration uses
|
// with_env() is used here to ensure that each iteration uses
|
||||||
|
|
|
@ -7,7 +7,6 @@ use nu_protocol::{
|
||||||
record, span, Category, IntoInterruptiblePipelineData, IntoPipelineData, PipelineData,
|
record, span, Category, IntoInterruptiblePipelineData, IntoPipelineData, PipelineData,
|
||||||
ShellError, Signature, Span, Spanned, SyntaxShape, Type, Value,
|
ShellError, Signature, Span, Spanned, SyntaxShape, Type, Value,
|
||||||
};
|
};
|
||||||
use std::borrow::Borrow;
|
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct HelpCommands;
|
pub struct HelpCommands;
|
||||||
|
@ -127,7 +126,7 @@ fn build_help_commands(engine_state: &EngineState, span: Span) -> Vec<Value> {
|
||||||
|
|
||||||
for (_, decl_id) in commands {
|
for (_, decl_id) in commands {
|
||||||
let decl = engine_state.get_decl(decl_id);
|
let decl = engine_state.get_decl(decl_id);
|
||||||
let sig = decl.signature().update_from_command(decl.borrow());
|
let sig = decl.signature().update_from_command(decl);
|
||||||
|
|
||||||
let key = sig.name;
|
let key = sig.name;
|
||||||
let usage = sig.usage;
|
let usage = sig.usage;
|
||||||
|
|
|
@ -421,7 +421,6 @@ pub struct RequestFlags {
|
||||||
pub full: bool,
|
pub full: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(clippy::needless_return)]
|
|
||||||
fn transform_response_using_content_type(
|
fn transform_response_using_content_type(
|
||||||
engine_state: &EngineState,
|
engine_state: &EngineState,
|
||||||
stack: &mut Stack,
|
stack: &mut Stack,
|
||||||
|
@ -464,9 +463,9 @@ fn transform_response_using_content_type(
|
||||||
|
|
||||||
let output = response_to_buffer(resp, engine_state, span);
|
let output = response_to_buffer(resp, engine_state, span);
|
||||||
if flags.raw {
|
if flags.raw {
|
||||||
return Ok(output);
|
Ok(output)
|
||||||
} else if let Some(ext) = ext {
|
} else if let Some(ext) = ext {
|
||||||
return match engine_state.find_decl(format!("from {ext}").as_bytes(), &[]) {
|
match engine_state.find_decl(format!("from {ext}").as_bytes(), &[]) {
|
||||||
Some(converter_id) => engine_state.get_decl(converter_id).run(
|
Some(converter_id) => engine_state.get_decl(converter_id).run(
|
||||||
engine_state,
|
engine_state,
|
||||||
stack,
|
stack,
|
||||||
|
@ -474,10 +473,10 @@ fn transform_response_using_content_type(
|
||||||
output,
|
output,
|
||||||
),
|
),
|
||||||
None => Ok(output),
|
None => Ok(output),
|
||||||
};
|
}
|
||||||
} else {
|
} else {
|
||||||
return Ok(output);
|
Ok(output)
|
||||||
};
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn check_response_redirection(
|
pub fn check_response_redirection(
|
||||||
|
|
|
@ -109,7 +109,6 @@ fn detect_columns(
|
||||||
let config = engine_state.get_config();
|
let config = engine_state.get_config();
|
||||||
let input = input.collect_string("", config)?;
|
let input = input.collect_string("", config)?;
|
||||||
|
|
||||||
#[allow(clippy::needless_collect)]
|
|
||||||
let input: Vec<_> = input
|
let input: Vec<_> = input
|
||||||
.lines()
|
.lines()
|
||||||
.skip(num_rows_to_skip.unwrap_or_default())
|
.skip(num_rows_to_skip.unwrap_or_default())
|
||||||
|
|
|
@ -989,7 +989,6 @@ enum TableView {
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(clippy::manual_filter)]
|
|
||||||
fn maybe_strip_color(output: String, config: &Config) -> String {
|
fn maybe_strip_color(output: String, config: &Config) -> String {
|
||||||
// the terminal is for when people do ls from vim, there should be no coloring there
|
// the terminal is for when people do ls from vim, there should be no coloring there
|
||||||
if !config.use_ansi_coloring || !std::io::stdout().is_terminal() {
|
if !config.use_ansi_coloring || !std::io::stdout().is_terminal() {
|
||||||
|
|
|
@ -2346,7 +2346,6 @@ fn join_lines(lines: impl IntoIterator<Item = impl AsRef<str>>) -> String {
|
||||||
}
|
}
|
||||||
|
|
||||||
// util function to easier copy && paste
|
// util function to easier copy && paste
|
||||||
#[allow(dead_code)]
|
|
||||||
fn _print_lines(s: &str, w: usize) {
|
fn _print_lines(s: &str, w: usize) {
|
||||||
eprintln!("{:#?}", _split_str_by_width(s, w));
|
eprintln!("{:#?}", _split_str_by_width(s, w));
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
use nu_test_support::nu;
|
use nu_test_support::nu;
|
||||||
#[allow(unused_imports)]
|
#[cfg(feature = "sqlite")]
|
||||||
use nu_test_support::pipeline;
|
use nu_test_support::pipeline;
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
|
|
@ -183,7 +183,6 @@ fn from_csv_text_with_tab_separator_to_table() {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[allow(clippy::needless_raw_string_hashes)]
|
|
||||||
fn from_csv_text_with_comments_to_table() {
|
fn from_csv_text_with_comments_to_table() {
|
||||||
Playground::setup("filter_from_csv_test_5", |dirs, sandbox| {
|
Playground::setup("filter_from_csv_test_5", |dirs, sandbox| {
|
||||||
sandbox.with_files(vec![FileWithContentToBeTrimmed(
|
sandbox.with_files(vec![FileWithContentToBeTrimmed(
|
||||||
|
|
|
@ -106,7 +106,6 @@ fn from_tsv_text_to_table() {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
#[allow(clippy::needless_raw_string_hashes)]
|
|
||||||
fn from_tsv_text_with_comments_to_table() {
|
fn from_tsv_text_with_comments_to_table() {
|
||||||
Playground::setup("filter_from_tsv_test_2", |dirs, sandbox| {
|
Playground::setup("filter_from_tsv_test_2", |dirs, sandbox| {
|
||||||
sandbox.with_files(vec![FileWithContentToBeTrimmed(
|
sandbox.with_files(vec![FileWithContentToBeTrimmed(
|
||||||
|
|
|
@ -19,11 +19,9 @@ const ENV_PATH_NAME: &str = "PATH";
|
||||||
|
|
||||||
const ENV_CONVERSIONS: &str = "ENV_CONVERSIONS";
|
const ENV_CONVERSIONS: &str = "ENV_CONVERSIONS";
|
||||||
|
|
||||||
#[allow(dead_code)]
|
|
||||||
enum ConversionResult {
|
enum ConversionResult {
|
||||||
Ok(Value),
|
Ok(Value),
|
||||||
ConversionError(ShellError), // Failure during the conversion itself
|
ConversionError(ShellError), // Failure during the conversion itself
|
||||||
GeneralError(ShellError), // Other error not directly connected to running the conversion
|
|
||||||
CellPathError, // Error looking up the ENV_VAR.to_/from_string fields in $env.ENV_CONVERSIONS
|
CellPathError, // Error looking up the ENV_VAR.to_/from_string fields in $env.ENV_CONVERSIONS
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -46,7 +44,6 @@ pub fn convert_env_values(engine_state: &mut EngineState, stack: &Stack) -> Opti
|
||||||
let _ = new_scope.insert(name.to_string(), v);
|
let _ = new_scope.insert(name.to_string(), v);
|
||||||
}
|
}
|
||||||
ConversionResult::ConversionError(e) => error = error.or(Some(e)),
|
ConversionResult::ConversionError(e) => error = error.or(Some(e)),
|
||||||
ConversionResult::GeneralError(_) => continue,
|
|
||||||
ConversionResult::CellPathError => {
|
ConversionResult::CellPathError => {
|
||||||
let _ = new_scope.insert(name.to_string(), val.clone());
|
let _ = new_scope.insert(name.to_string(), val.clone());
|
||||||
}
|
}
|
||||||
|
@ -101,7 +98,6 @@ pub fn env_to_string(
|
||||||
match get_converted_value(engine_state, stack, env_name, value, "to_string") {
|
match get_converted_value(engine_state, stack, env_name, value, "to_string") {
|
||||||
ConversionResult::Ok(v) => Ok(v.coerce_into_string()?),
|
ConversionResult::Ok(v) => Ok(v.coerce_into_string()?),
|
||||||
ConversionResult::ConversionError(e) => Err(e),
|
ConversionResult::ConversionError(e) => Err(e),
|
||||||
ConversionResult::GeneralError(e) => Err(e),
|
|
||||||
ConversionResult::CellPathError => match value.coerce_string() {
|
ConversionResult::CellPathError => match value.coerce_string() {
|
||||||
Ok(s) => Ok(s),
|
Ok(s) => Ok(s),
|
||||||
Err(_) => {
|
Err(_) => {
|
||||||
|
|
|
@ -148,7 +148,6 @@ impl<'a> Pager<'a> {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
#[allow(dead_code)]
|
|
||||||
pub enum Transition {
|
pub enum Transition {
|
||||||
Ok,
|
Ok,
|
||||||
Exit,
|
Exit,
|
||||||
|
|
|
@ -73,6 +73,7 @@ extern crate doc_comment;
|
||||||
doctest!("../README.md");
|
doctest!("../README.md");
|
||||||
|
|
||||||
use std::cmp;
|
use std::cmp;
|
||||||
|
use std::cmp::Ordering;
|
||||||
use std::error::Error;
|
use std::error::Error;
|
||||||
use std::fmt;
|
use std::fmt;
|
||||||
use std::fs;
|
use std::fs;
|
||||||
|
@ -346,7 +347,6 @@ impl Error for GlobError {
|
||||||
self.error.description()
|
self.error.description()
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(unknown_lints, bare_trait_objects)]
|
|
||||||
fn cause(&self) -> Option<&dyn Error> {
|
fn cause(&self) -> Option<&dyn Error> {
|
||||||
Some(&self.error)
|
Some(&self.error)
|
||||||
}
|
}
|
||||||
|
@ -505,7 +505,6 @@ impl Iterator for Paths {
|
||||||
|
|
||||||
/// A pattern parsing error.
|
/// A pattern parsing error.
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
#[allow(missing_copy_implementations)]
|
|
||||||
pub struct PatternError {
|
pub struct PatternError {
|
||||||
/// The approximate character index of where the error occurred.
|
/// The approximate character index of where the error occurred.
|
||||||
pub pos: usize,
|
pub pos: usize,
|
||||||
|
@ -630,53 +629,58 @@ impl Pattern {
|
||||||
|
|
||||||
let count = i - old;
|
let count = i - old;
|
||||||
|
|
||||||
#[allow(clippy::comparison_chain)]
|
match count.cmp(&2) {
|
||||||
if count > 2 {
|
Ordering::Greater => {
|
||||||
return Err(PatternError {
|
return Err(PatternError {
|
||||||
pos: old + 2,
|
pos: old + 2,
|
||||||
msg: ERROR_WILDCARDS,
|
msg: ERROR_WILDCARDS,
|
||||||
});
|
});
|
||||||
} else if count == 2 {
|
}
|
||||||
// ** can only be an entire path component
|
Ordering::Equal => {
|
||||||
// i.e. a/**/b is valid, but a**/b or a/**b is not
|
// ** can only be an entire path component
|
||||||
// invalid matches are treated literally
|
// i.e. a/**/b is valid, but a**/b or a/**b is not
|
||||||
let is_valid = if i == 2 || path::is_separator(chars[i - count - 1]) {
|
// invalid matches are treated literally
|
||||||
// it ends in a '/'
|
let is_valid = if i == 2 || path::is_separator(chars[i - count - 1]) {
|
||||||
if i < chars.len() && path::is_separator(chars[i]) {
|
// it ends in a '/'
|
||||||
i += 1;
|
if i < chars.len() && path::is_separator(chars[i]) {
|
||||||
true
|
i += 1;
|
||||||
// or the pattern ends here
|
true
|
||||||
// this enables the existing globbing mechanism
|
// or the pattern ends here
|
||||||
} else if i == chars.len() {
|
// this enables the existing globbing mechanism
|
||||||
true
|
} else if i == chars.len() {
|
||||||
// `**` ends in non-separator
|
true
|
||||||
|
// `**` ends in non-separator
|
||||||
|
} else {
|
||||||
|
return Err(PatternError {
|
||||||
|
pos: i,
|
||||||
|
msg: ERROR_RECURSIVE_WILDCARDS,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
// `**` begins with non-separator
|
||||||
} else {
|
} else {
|
||||||
return Err(PatternError {
|
return Err(PatternError {
|
||||||
pos: i,
|
pos: old - 1,
|
||||||
msg: ERROR_RECURSIVE_WILDCARDS,
|
msg: ERROR_RECURSIVE_WILDCARDS,
|
||||||
});
|
});
|
||||||
}
|
};
|
||||||
// `**` begins with non-separator
|
|
||||||
} else {
|
|
||||||
return Err(PatternError {
|
|
||||||
pos: old - 1,
|
|
||||||
msg: ERROR_RECURSIVE_WILDCARDS,
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
if is_valid {
|
if is_valid {
|
||||||
// collapse consecutive AnyRecursiveSequence to a
|
// collapse consecutive AnyRecursiveSequence to a
|
||||||
// single one
|
// single one
|
||||||
|
|
||||||
let tokens_len = tokens.len();
|
let tokens_len = tokens.len();
|
||||||
|
|
||||||
if !(tokens_len > 1 && tokens[tokens_len - 1] == AnyRecursiveSequence) {
|
if !(tokens_len > 1
|
||||||
is_recursive = true;
|
&& tokens[tokens_len - 1] == AnyRecursiveSequence)
|
||||||
tokens.push(AnyRecursiveSequence);
|
{
|
||||||
|
is_recursive = true;
|
||||||
|
tokens.push(AnyRecursiveSequence);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
Ordering::Less => {
|
||||||
tokens.push(AnySequence);
|
tokens.push(AnySequence);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
'[' => {
|
'[' => {
|
||||||
|
@ -1051,7 +1055,6 @@ fn chars_eq(a: char, b: char, case_sensitive: bool) -> bool {
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Configuration options to modify the behaviour of `Pattern::matches_with(..)`.
|
/// Configuration options to modify the behaviour of `Pattern::matches_with(..)`.
|
||||||
#[allow(missing_copy_implementations)]
|
|
||||||
#[derive(Debug, Copy, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
#[derive(Debug, Copy, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
||||||
pub struct MatchOptions {
|
pub struct MatchOptions {
|
||||||
/// Whether or not patterns should be matched in a case-sensitive manner.
|
/// Whether or not patterns should be matched in a case-sensitive manner.
|
||||||
|
|
|
@ -577,9 +577,8 @@ fn first_kw_idx(
|
||||||
..
|
..
|
||||||
}) = signature.get_positional(idx)
|
}) = signature.get_positional(idx)
|
||||||
{
|
{
|
||||||
#[allow(clippy::needless_range_loop)]
|
for (span_idx, &span) in spans.iter().enumerate().skip(spans_idx) {
|
||||||
for span_idx in spans_idx..spans.len() {
|
let contents = working_set.get_span_contents(span);
|
||||||
let contents = working_set.get_span_contents(spans[span_idx]);
|
|
||||||
|
|
||||||
if contents == kw {
|
if contents == kw {
|
||||||
return (Some(idx), span_idx);
|
return (Some(idx), span_idx);
|
||||||
|
@ -3201,12 +3200,11 @@ pub fn parse_signature(working_set: &mut StateWorkingSet, span: Span) -> Express
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn parse_signature_helper(working_set: &mut StateWorkingSet, span: Span) -> Box<Signature> {
|
pub fn parse_signature_helper(working_set: &mut StateWorkingSet, span: Span) -> Box<Signature> {
|
||||||
#[allow(clippy::enum_variant_names)]
|
|
||||||
enum ParseMode {
|
enum ParseMode {
|
||||||
ArgMode,
|
Arg,
|
||||||
AfterCommaArgMode,
|
AfterCommaArg,
|
||||||
TypeMode,
|
Type,
|
||||||
DefaultValueMode,
|
DefaultValue,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
|
@ -3237,7 +3235,7 @@ pub fn parse_signature_helper(working_set: &mut StateWorkingSet, span: Span) ->
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut args: Vec<Arg> = vec![];
|
let mut args: Vec<Arg> = vec![];
|
||||||
let mut parse_mode = ParseMode::ArgMode;
|
let mut parse_mode = ParseMode::Arg;
|
||||||
|
|
||||||
for token in &output {
|
for token in &output {
|
||||||
match token {
|
match token {
|
||||||
|
@ -3251,13 +3249,13 @@ pub fn parse_signature_helper(working_set: &mut StateWorkingSet, span: Span) ->
|
||||||
// The : symbol separates types
|
// The : symbol separates types
|
||||||
if contents == b":" {
|
if contents == b":" {
|
||||||
match parse_mode {
|
match parse_mode {
|
||||||
ParseMode::ArgMode => {
|
ParseMode::Arg => {
|
||||||
parse_mode = ParseMode::TypeMode;
|
parse_mode = ParseMode::Type;
|
||||||
}
|
}
|
||||||
ParseMode::AfterCommaArgMode => {
|
ParseMode::AfterCommaArg => {
|
||||||
working_set.error(ParseError::Expected("parameter or flag", span));
|
working_set.error(ParseError::Expected("parameter or flag", span));
|
||||||
}
|
}
|
||||||
ParseMode::TypeMode | ParseMode::DefaultValueMode => {
|
ParseMode::Type | ParseMode::DefaultValue => {
|
||||||
// We're seeing two types for the same thing for some reason, error
|
// We're seeing two types for the same thing for some reason, error
|
||||||
working_set.error(ParseError::Expected("type", span));
|
working_set.error(ParseError::Expected("type", span));
|
||||||
}
|
}
|
||||||
|
@ -3266,13 +3264,13 @@ pub fn parse_signature_helper(working_set: &mut StateWorkingSet, span: Span) ->
|
||||||
// The = symbol separates a variable from its default value
|
// The = symbol separates a variable from its default value
|
||||||
else if contents == b"=" {
|
else if contents == b"=" {
|
||||||
match parse_mode {
|
match parse_mode {
|
||||||
ParseMode::TypeMode | ParseMode::ArgMode => {
|
ParseMode::Type | ParseMode::Arg => {
|
||||||
parse_mode = ParseMode::DefaultValueMode;
|
parse_mode = ParseMode::DefaultValue;
|
||||||
}
|
}
|
||||||
ParseMode::AfterCommaArgMode => {
|
ParseMode::AfterCommaArg => {
|
||||||
working_set.error(ParseError::Expected("parameter or flag", span));
|
working_set.error(ParseError::Expected("parameter or flag", span));
|
||||||
}
|
}
|
||||||
ParseMode::DefaultValueMode => {
|
ParseMode::DefaultValue => {
|
||||||
// We're seeing two default values for some reason, error
|
// We're seeing two default values for some reason, error
|
||||||
working_set.error(ParseError::Expected("default value", span));
|
working_set.error(ParseError::Expected("default value", span));
|
||||||
}
|
}
|
||||||
|
@ -3281,20 +3279,20 @@ pub fn parse_signature_helper(working_set: &mut StateWorkingSet, span: Span) ->
|
||||||
// The , symbol separates params only
|
// The , symbol separates params only
|
||||||
else if contents == b"," {
|
else if contents == b"," {
|
||||||
match parse_mode {
|
match parse_mode {
|
||||||
ParseMode::ArgMode => parse_mode = ParseMode::AfterCommaArgMode,
|
ParseMode::Arg => parse_mode = ParseMode::AfterCommaArg,
|
||||||
ParseMode::AfterCommaArgMode => {
|
ParseMode::AfterCommaArg => {
|
||||||
working_set.error(ParseError::Expected("parameter or flag", span));
|
working_set.error(ParseError::Expected("parameter or flag", span));
|
||||||
}
|
}
|
||||||
ParseMode::TypeMode => {
|
ParseMode::Type => {
|
||||||
working_set.error(ParseError::Expected("type", span));
|
working_set.error(ParseError::Expected("type", span));
|
||||||
}
|
}
|
||||||
ParseMode::DefaultValueMode => {
|
ParseMode::DefaultValue => {
|
||||||
working_set.error(ParseError::Expected("default value", span));
|
working_set.error(ParseError::Expected("default value", span));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
match parse_mode {
|
match parse_mode {
|
||||||
ParseMode::ArgMode | ParseMode::AfterCommaArgMode => {
|
ParseMode::Arg | ParseMode::AfterCommaArg => {
|
||||||
// Long flag with optional short form following with no whitespace, e.g. --output, --age(-a)
|
// Long flag with optional short form following with no whitespace, e.g. --output, --age(-a)
|
||||||
if contents.starts_with(b"--") && contents.len() > 2 {
|
if contents.starts_with(b"--") && contents.len() > 2 {
|
||||||
// Split the long flag from the short flag with the ( character as delimiter.
|
// Split the long flag from the short flag with the ( character as delimiter.
|
||||||
|
@ -3400,7 +3398,7 @@ pub fn parse_signature_helper(working_set: &mut StateWorkingSet, span: Span) ->
|
||||||
working_set.error(ParseError::Expected("short flag", span));
|
working_set.error(ParseError::Expected("short flag", span));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
parse_mode = ParseMode::ArgMode;
|
parse_mode = ParseMode::Arg;
|
||||||
}
|
}
|
||||||
// Mandatory short flag, e.g. -e (must be one character)
|
// Mandatory short flag, e.g. -e (must be one character)
|
||||||
else if contents.starts_with(b"-") && contents.len() > 1 {
|
else if contents.starts_with(b"-") && contents.len() > 1 {
|
||||||
|
@ -3438,12 +3436,12 @@ pub fn parse_signature_helper(working_set: &mut StateWorkingSet, span: Span) ->
|
||||||
},
|
},
|
||||||
type_annotated: false,
|
type_annotated: false,
|
||||||
});
|
});
|
||||||
parse_mode = ParseMode::ArgMode;
|
parse_mode = ParseMode::Arg;
|
||||||
}
|
}
|
||||||
// Short flag alias for long flag, e.g. --b (-a)
|
// Short flag alias for long flag, e.g. --b (-a)
|
||||||
// This is the same as the short flag in --b(-a)
|
// This is the same as the short flag in --b(-a)
|
||||||
else if contents.starts_with(b"(-") {
|
else if contents.starts_with(b"(-") {
|
||||||
if matches!(parse_mode, ParseMode::AfterCommaArgMode) {
|
if matches!(parse_mode, ParseMode::AfterCommaArg) {
|
||||||
working_set
|
working_set
|
||||||
.error(ParseError::Expected("parameter or flag", span));
|
.error(ParseError::Expected("parameter or flag", span));
|
||||||
}
|
}
|
||||||
|
@ -3506,7 +3504,7 @@ pub fn parse_signature_helper(working_set: &mut StateWorkingSet, span: Span) ->
|
||||||
required: false,
|
required: false,
|
||||||
type_annotated: false,
|
type_annotated: false,
|
||||||
});
|
});
|
||||||
parse_mode = ParseMode::ArgMode;
|
parse_mode = ParseMode::Arg;
|
||||||
}
|
}
|
||||||
// Rest param
|
// Rest param
|
||||||
else if let Some(contents) = contents.strip_prefix(b"...") {
|
else if let Some(contents) = contents.strip_prefix(b"...") {
|
||||||
|
@ -3530,7 +3528,7 @@ pub fn parse_signature_helper(working_set: &mut StateWorkingSet, span: Span) ->
|
||||||
var_id: Some(var_id),
|
var_id: Some(var_id),
|
||||||
default_value: None,
|
default_value: None,
|
||||||
}));
|
}));
|
||||||
parse_mode = ParseMode::ArgMode;
|
parse_mode = ParseMode::Arg;
|
||||||
}
|
}
|
||||||
// Normal param
|
// Normal param
|
||||||
else {
|
else {
|
||||||
|
@ -3559,10 +3557,10 @@ pub fn parse_signature_helper(working_set: &mut StateWorkingSet, span: Span) ->
|
||||||
required: true,
|
required: true,
|
||||||
type_annotated: false,
|
type_annotated: false,
|
||||||
});
|
});
|
||||||
parse_mode = ParseMode::ArgMode;
|
parse_mode = ParseMode::Arg;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ParseMode::TypeMode => {
|
ParseMode::Type => {
|
||||||
if let Some(last) = args.last_mut() {
|
if let Some(last) = args.last_mut() {
|
||||||
let syntax_shape = parse_shape_name(
|
let syntax_shape = parse_shape_name(
|
||||||
working_set,
|
working_set,
|
||||||
|
@ -3604,9 +3602,9 @@ pub fn parse_signature_helper(working_set: &mut StateWorkingSet, span: Span) ->
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
parse_mode = ParseMode::ArgMode;
|
parse_mode = ParseMode::Arg;
|
||||||
}
|
}
|
||||||
ParseMode::DefaultValueMode => {
|
ParseMode::DefaultValue => {
|
||||||
if let Some(last) = args.last_mut() {
|
if let Some(last) = args.last_mut() {
|
||||||
let expression = parse_value(working_set, span, &SyntaxShape::Any);
|
let expression = parse_value(working_set, span, &SyntaxShape::Any);
|
||||||
|
|
||||||
|
@ -3727,7 +3725,7 @@ pub fn parse_signature_helper(working_set: &mut StateWorkingSet, span: Span) ->
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
parse_mode = ParseMode::ArgMode;
|
parse_mode = ParseMode::Arg;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -86,13 +86,12 @@ fn test_int(
|
||||||
},
|
},
|
||||||
) = &expressions.elements[0]
|
) = &expressions.elements[0]
|
||||||
{
|
{
|
||||||
compare_rhs_binaryOp(test_tag, &expected_val, observed_val);
|
compare_rhs_binary_op(test_tag, &expected_val, observed_val);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(non_snake_case)]
|
fn compare_rhs_binary_op(
|
||||||
fn compare_rhs_binaryOp(
|
|
||||||
test_tag: &str,
|
test_tag: &str,
|
||||||
expected: &Expr, // the rhs expr we hope to see (::Int, ::Float, not ::B)
|
expected: &Expr, // the rhs expr we hope to see (::Int, ::Float, not ::B)
|
||||||
observed: &Expr, // the Expr actually provided: can be ::Int, ::Float, ::String,
|
observed: &Expr, // the Expr actually provided: can be ::Int, ::Float, ::String,
|
||||||
|
|
|
@ -12,7 +12,6 @@ use crate::{
|
||||||
ShellError, Signature, Span, Type, VarId, VirtualPathId,
|
ShellError, Signature, Span, Type, VarId, VirtualPathId,
|
||||||
};
|
};
|
||||||
use crate::{Category, Value};
|
use crate::{Category, Value};
|
||||||
use std::borrow::Borrow;
|
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
use std::num::NonZeroUsize;
|
use std::num::NonZeroUsize;
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
|
@ -788,11 +787,11 @@ impl EngineState {
|
||||||
self.vars[var_id].const_val = Some(val);
|
self.vars[var_id].const_val = Some(val);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(clippy::borrowed_box)]
|
pub fn get_decl(&self, decl_id: DeclId) -> &dyn Command {
|
||||||
pub fn get_decl(&self, decl_id: DeclId) -> &Box<dyn Command> {
|
|
||||||
self.decls
|
self.decls
|
||||||
.get(decl_id)
|
.get(decl_id)
|
||||||
.expect("internal error: missing declaration")
|
.expect("internal error: missing declaration")
|
||||||
|
.as_ref()
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Get all commands within scope, sorted by the commands' names
|
/// Get all commands within scope, sorted by the commands' names
|
||||||
|
@ -823,8 +822,7 @@ impl EngineState {
|
||||||
decls.into_iter()
|
decls.into_iter()
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(clippy::borrowed_box)]
|
pub fn get_signature(&self, decl: &dyn Command) -> Signature {
|
||||||
pub fn get_signature(&self, decl: &Box<dyn Command>) -> Signature {
|
|
||||||
if let Some(block_id) = decl.get_block_id() {
|
if let Some(block_id) = decl.get_block_id() {
|
||||||
*self.blocks[block_id].signature.clone()
|
*self.blocks[block_id].signature.clone()
|
||||||
} else {
|
} else {
|
||||||
|
@ -838,7 +836,7 @@ impl EngineState {
|
||||||
.map(|(_, id)| {
|
.map(|(_, id)| {
|
||||||
let decl = self.get_decl(id);
|
let decl = self.get_decl(id);
|
||||||
|
|
||||||
self.get_signature(decl).update_from_command(decl.borrow())
|
self.get_signature(decl).update_from_command(decl)
|
||||||
})
|
})
|
||||||
.collect()
|
.collect()
|
||||||
}
|
}
|
||||||
|
@ -856,7 +854,7 @@ impl EngineState {
|
||||||
.map(|(_, id)| {
|
.map(|(_, id)| {
|
||||||
let decl = self.get_decl(id);
|
let decl = self.get_decl(id);
|
||||||
|
|
||||||
let signature = self.get_signature(decl).update_from_command(decl.borrow());
|
let signature = self.get_signature(decl).update_from_command(decl);
|
||||||
|
|
||||||
(
|
(
|
||||||
signature,
|
signature,
|
||||||
|
|
|
@ -685,8 +685,7 @@ impl<'a> StateWorkingSet<'a> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(clippy::borrowed_box)]
|
pub fn get_decl(&self, decl_id: DeclId) -> &dyn Command {
|
||||||
pub fn get_decl(&self, decl_id: DeclId) -> &Box<dyn Command> {
|
|
||||||
let num_permanent_decls = self.permanent_state.num_decls();
|
let num_permanent_decls = self.permanent_state.num_decls();
|
||||||
if decl_id < num_permanent_decls {
|
if decl_id < num_permanent_decls {
|
||||||
self.permanent_state.get_decl(decl_id)
|
self.permanent_state.get_decl(decl_id)
|
||||||
|
@ -695,6 +694,7 @@ impl<'a> StateWorkingSet<'a> {
|
||||||
.decls
|
.decls
|
||||||
.get(decl_id - num_permanent_decls)
|
.get(decl_id - num_permanent_decls)
|
||||||
.expect("internal error: missing declaration")
|
.expect("internal error: missing declaration")
|
||||||
|
.as_ref()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
use crate::Value;
|
use crate::Value;
|
||||||
#[allow(unused_imports)]
|
#[cfg(feature = "plugin")]
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
|
|
Loading…
Reference in a new issue