Remove rest_args() from evaluated CommandArgs (#3449)

It was too error prone when positional arguments were used with the rest
arguments. Now, you need to explicitly state from which position you
want to count the rest args (e.g., `rest(0)`).
This commit is contained in:
Jakub Žádník 2021-05-20 01:26:23 +03:00 committed by GitHub
parent e2973d2176
commit 3075e2cfbf
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
23 changed files with 22 additions and 26 deletions

View file

@ -40,7 +40,7 @@ impl WholeStreamCommand for SubCommand {
fn operate(args: CommandArgs) -> Result<OutputStream, ShellError> {
let args = args.evaluate_once()?;
let column_paths: Vec<_> = args.rest_args()?;
let column_paths: Vec<_> = args.rest(0)?;
let result: Vec<Value> = args
.input

View file

@ -43,7 +43,7 @@ impl WholeStreamCommand for PathBasename {
let tag = args.call_info.name_tag.clone();
let args = args.evaluate_once()?;
let cmd_args = Arc::new(PathBasenameArguments {
rest: args.rest_args()?,
rest: args.rest(0)?,
replace: args.get_flag("replace")?,
});

View file

@ -50,7 +50,7 @@ impl WholeStreamCommand for PathDirname {
let tag = args.call_info.name_tag.clone();
let args = args.evaluate_once()?;
let cmd_args = Arc::new(PathDirnameArguments {
rest: args.rest_args()?,
rest: args.rest(0)?,
replace: args.get_flag("replace")?,
num_levels: args.get_flag("num-levels")?,
});

View file

@ -35,7 +35,7 @@ impl WholeStreamCommand for PathExists {
let tag = args.call_info.name_tag.clone();
let args = args.evaluate_once()?;
let cmd_args = Arc::new(PathExistsArguments {
rest: args.rest_args()?,
rest: args.rest(0)?,
});
Ok(operate(args.input, &action, tag.span, cmd_args))

View file

@ -35,7 +35,7 @@ impl WholeStreamCommand for PathExpand {
let tag = args.call_info.name_tag.clone();
let args = args.evaluate_once()?;
let cmd_args = Arc::new(PathExpandArguments {
rest: args.rest_args()?,
rest: args.rest(0)?,
});
Ok(operate(args.input, &action, tag.span, cmd_args))

View file

@ -48,7 +48,7 @@ the output of 'path parse' and 'path split' subcommands."#
let tag = args.call_info.name_tag.clone();
let args = args.evaluate_once()?;
let cmd_args = Arc::new(PathJoinArguments {
rest: args.rest_args()?,
rest: args.rest(0)?,
append: args.get_flag("append")?,
});

View file

@ -50,7 +50,7 @@ On Windows, an extra 'prefix' column is added."#
let tag = args.call_info.name_tag.clone();
let args = args.evaluate_once()?;
let cmd_args = Arc::new(PathParseArguments {
rest: args.rest_args()?,
rest: args.rest(0)?,
extension: args.get_flag("extension")?,
});

View file

@ -35,7 +35,7 @@ impl WholeStreamCommand for PathSplit {
let tag = args.call_info.name_tag.clone();
let args = args.evaluate_once()?;
let cmd_args = Arc::new(PathSplitArguments {
rest: args.rest_args()?,
rest: args.rest(0)?,
});
Ok(operate_split(args.input, &action, tag.span, cmd_args))

View file

@ -36,7 +36,7 @@ impl WholeStreamCommand for PathType {
let tag = args.call_info.name_tag.clone();
let args = args.evaluate_once()?;
let cmd_args = Arc::new(PathTypeArguments {
rest: args.rest_args()?,
rest: args.rest(0)?,
});
Ok(operate(args.input, &action, tag.span, cmd_args))

View file

@ -46,7 +46,7 @@ impl WholeStreamCommand for SubCommand {
fn operate(args: CommandArgs) -> Result<ActionStream, ShellError> {
let (options, input) = args.extract(|params| {
Ok(Arguments {
column_paths: params.rest_args()?,
column_paths: params.rest(0)?,
})
})?;

View file

@ -26,7 +26,7 @@ where
{
let (options, input) = args.extract(|params| {
Ok(Arguments {
column_paths: params.rest_args()?,
column_paths: params.rest(0)?,
})
})?;

View file

@ -46,7 +46,7 @@ impl WholeStreamCommand for SubCommand {
fn operate(args: CommandArgs) -> Result<ActionStream, ShellError> {
let (options, input) = args.extract(|params| {
Ok(Arguments {
column_paths: params.rest_args()?,
column_paths: params.rest(0)?,
})
})?;

View file

@ -73,7 +73,7 @@ fn operate(args: CommandArgs) -> Result<ActionStream, ShellError> {
Ok(Arguments {
decimals: params.get_flag("decimals")?,
group_digits: false,
column_paths: params.rest_args()?,
column_paths: params.rest(0)?,
})
})?;

View file

@ -54,7 +54,7 @@ impl WholeStreamCommand for SubCommand {
fn operate(args: CommandArgs) -> Result<ActionStream, ShellError> {
let (options, input) = args.extract(|params| {
Ok(Arguments {
column_paths: params.rest_args()?,
column_paths: params.rest(0)?,
})
})?;

View file

@ -81,7 +81,7 @@ fn operate(args: CommandArgs) -> Result<ActionStream, ShellError> {
Ok(Arc::new(Arguments {
length: params.req_named("length")?,
character: params.req_named("character")?,
column_paths: params.rest_args()?,
column_paths: params.rest(0)?,
}))
})?;

View file

@ -44,7 +44,7 @@ impl WholeStreamCommand for SubCommand {
fn operate(args: CommandArgs) -> Result<ActionStream, ShellError> {
let (options, input) = args.extract(|params| {
Ok(Arguments {
column_paths: params.rest_args()?,
column_paths: params.rest(0)?,
})
})?;

View file

@ -81,7 +81,7 @@ fn operate(args: CommandArgs) -> Result<ActionStream, ShellError> {
Ok(Arc::new(Arguments {
length: params.req_named("length")?,
character: params.req_named("character")?,
column_paths: params.rest_args()?,
column_paths: params.rest(0)?,
}))
})?;

View file

@ -128,7 +128,7 @@ struct DatetimeFormat(String);
fn operate(args: CommandArgs) -> Result<ActionStream, ShellError> {
let (options, input) = args.extract(|params| {
let (column_paths, _) = arguments(&mut params.rest_args()?)?;
let (column_paths, _) = arguments(&mut params.rest(0)?)?;
Ok(Arguments {
timezone: params.get_flag("timezone")?,

View file

@ -49,7 +49,7 @@ impl WholeStreamCommand for SubCommand {
fn operate(args: CommandArgs) -> Result<ActionStream, ShellError> {
let (options, input) = args.extract(|params| {
Ok(Arguments {
column_paths: params.rest_args()?,
column_paths: params.rest(0)?,
})
})?;

View file

@ -66,7 +66,7 @@ impl WholeStreamCommand for SubCommand {
fn operate(args: CommandArgs) -> Result<ActionStream, ShellError> {
let (options, input) = args.extract(|params| {
let (column_paths, _) = arguments(&mut params.rest_args()?)?;
let (column_paths, _) = arguments(&mut params.rest(0)?)?;
Ok(Arguments {
radix: params.get_flag("radix")?,

View file

@ -26,7 +26,7 @@ where
let (options, input) = args.extract(|params| {
Ok(Arc::new(Arguments {
character: params.get_flag("char")?,
column_paths: params.rest_args()?,
column_paths: params.rest(0)?,
}))
})?;

View file

@ -46,7 +46,7 @@ impl WholeStreamCommand for SubCommand {
fn operate(args: CommandArgs) -> Result<ActionStream, ShellError> {
let (options, input) = args.extract(|params| {
Ok(Arguments {
column_paths: params.rest_args()?,
column_paths: params.rest(0)?,
})
})?;

View file

@ -201,10 +201,6 @@ impl EvaluatedCommandArgsWithoutInput {
}
}
pub fn rest_args<T: FromValue>(&self) -> Result<Vec<T>, ShellError> {
self.rest(0)
}
pub fn rest<T: FromValue>(&self, starting_pos: usize) -> Result<Vec<T>, ShellError> {
let mut output = vec![];