mirror of
https://github.com/RustPython/Parser.git
synced 2025-07-22 20:45:28 +00:00
added lex error: DuplicateArguments
This commit is contained in:
parent
5380b85579
commit
15ab44384c
3 changed files with 68 additions and 24 deletions
|
@ -21,6 +21,7 @@ pub enum LexicalErrorType {
|
|||
TabError,
|
||||
TabsAfterSpaces,
|
||||
DefaultArgumentError,
|
||||
DuplicateArgumentError,
|
||||
PositionalArgumentError,
|
||||
UnpackedArgumentError,
|
||||
DuplicateKeywordArgumentError,
|
||||
|
@ -50,6 +51,9 @@ impl fmt::Display for LexicalErrorType {
|
|||
LexicalErrorType::DefaultArgumentError => {
|
||||
write!(f, "non-default argument follows default argument")
|
||||
}
|
||||
LexicalErrorType::DuplicateArgumentError => {
|
||||
write!(f, "duplicate argument in function definition")
|
||||
}
|
||||
LexicalErrorType::DuplicateKeywordArgumentError => {
|
||||
write!(f, "keyword argument repeated")
|
||||
}
|
||||
|
|
|
@ -10,6 +10,39 @@ pub struct ArgumentList {
|
|||
type ParameterDefs = (Vec<ast::Arg>, Vec<ast::Arg>, Vec<ast::Expr>);
|
||||
type ParameterDef = (ast::Arg, Option<ast::Expr>);
|
||||
|
||||
pub fn validate_arguments(
|
||||
arguments: ast::Arguments
|
||||
) -> Result<ast::Arguments, LexicalError> {
|
||||
let mut all_args: Vec<&ast::Located<ast::ArgData>> = vec![];
|
||||
|
||||
all_args.extend(arguments.posonlyargs.iter());
|
||||
all_args.extend(arguments.args.iter());
|
||||
|
||||
if let Some(a) = &arguments.vararg {
|
||||
all_args.push(a);
|
||||
}
|
||||
|
||||
all_args.extend(arguments.kwonlyargs.iter());
|
||||
|
||||
if let Some(a) = &arguments.kwarg {
|
||||
all_args.push(a);
|
||||
}
|
||||
|
||||
let mut all_arg_names =
|
||||
FxHashSet::with_hasher(Default::default());
|
||||
for arg in all_args {
|
||||
let arg_name = arg.node.arg.clone();
|
||||
if !all_arg_names.insert(arg_name) {
|
||||
return Err(LexicalError {
|
||||
error: LexicalErrorType::DuplicateArgumentError,
|
||||
location: arg.location,
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
return Ok(arguments);
|
||||
}
|
||||
|
||||
pub fn parse_params(
|
||||
params: (Vec<ParameterDef>, Vec<ParameterDef>),
|
||||
) -> Result<ParameterDefs, LexicalError> {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue