forked from mirrors/jj
revset: add constructor for InvalidFunctionArguments error
Inlined some of the make_error() closures instead. I'll make string pattern handler preserve the source error object.
This commit is contained in:
parent
339b199ee3
commit
c4d48c5139
1 changed files with 39 additions and 44 deletions
|
@ -209,6 +209,20 @@ impl RevsetParseError {
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn invalid_arguments(
|
||||||
|
name: impl Into<String>,
|
||||||
|
message: impl Into<String>,
|
||||||
|
span: pest::Span<'_>,
|
||||||
|
) -> Self {
|
||||||
|
Self::with_span(
|
||||||
|
RevsetParseErrorKind::InvalidFunctionArguments {
|
||||||
|
name: name.into(),
|
||||||
|
message: message.into(),
|
||||||
|
},
|
||||||
|
span,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
pub fn kind(&self) -> &RevsetParseErrorKind {
|
pub fn kind(&self) -> &RevsetParseErrorKind {
|
||||||
&self.kind
|
&self.kind
|
||||||
}
|
}
|
||||||
|
@ -1257,24 +1271,16 @@ static BUILTIN_FUNCTION_MAP: Lazy<HashMap<&'static str, RevsetFunction>> = Lazy:
|
||||||
let needle = parse_function_argument_to_string(name, arg, state)?;
|
let needle = parse_function_argument_to_string(name, arg, state)?;
|
||||||
let path = RepoPathBuf::parse_fs_path(ctx.cwd, ctx.workspace_root, needle)
|
let path = RepoPathBuf::parse_fs_path(ctx.cwd, ctx.workspace_root, needle)
|
||||||
.map_err(|e| {
|
.map_err(|e| {
|
||||||
RevsetParseError::with_span(
|
RevsetParseError::invalid_arguments(name, "Invalid file pattern", span)
|
||||||
RevsetParseErrorKind::InvalidFunctionArguments {
|
.with_source(e)
|
||||||
name: name.to_owned(),
|
|
||||||
message: "Invalid file pattern".to_owned(),
|
|
||||||
},
|
|
||||||
span,
|
|
||||||
)
|
|
||||||
.with_source(e)
|
|
||||||
})?;
|
})?;
|
||||||
Ok(path)
|
Ok(path)
|
||||||
})
|
})
|
||||||
.try_collect()?;
|
.try_collect()?;
|
||||||
if paths.is_empty() {
|
if paths.is_empty() {
|
||||||
Err(RevsetParseError::with_span(
|
Err(RevsetParseError::invalid_arguments(
|
||||||
RevsetParseErrorKind::InvalidFunctionArguments {
|
name,
|
||||||
name: name.to_owned(),
|
"Expected at least 1 argument",
|
||||||
message: "Expected at least 1 argument".to_string(),
|
|
||||||
},
|
|
||||||
arguments_span,
|
arguments_span,
|
||||||
))
|
))
|
||||||
} else {
|
} else {
|
||||||
|
@ -1349,22 +1355,13 @@ fn expect_named_arguments_vec<'i>(
|
||||||
) -> Result<(Vec<Pair<'i, Rule>>, Vec<OptionalArg<'i>>), RevsetParseError> {
|
) -> Result<(Vec<Pair<'i, Rule>>, Vec<OptionalArg<'i>>), RevsetParseError> {
|
||||||
assert!(argument_names.len() <= max_arg_count);
|
assert!(argument_names.len() <= max_arg_count);
|
||||||
let arguments_span = arguments_pair.as_span();
|
let arguments_span = arguments_pair.as_span();
|
||||||
let make_error = |message, span| {
|
|
||||||
RevsetParseError::with_span(
|
|
||||||
RevsetParseErrorKind::InvalidFunctionArguments {
|
|
||||||
name: function_name.to_owned(),
|
|
||||||
message,
|
|
||||||
},
|
|
||||||
span,
|
|
||||||
)
|
|
||||||
};
|
|
||||||
let make_count_error = || {
|
let make_count_error = || {
|
||||||
let message = if min_arg_count == max_arg_count {
|
let message = if min_arg_count == max_arg_count {
|
||||||
format!("Expected {min_arg_count} arguments")
|
format!("Expected {min_arg_count} arguments")
|
||||||
} else {
|
} else {
|
||||||
format!("Expected {min_arg_count} to {max_arg_count} arguments")
|
format!("Expected {min_arg_count} to {max_arg_count} arguments")
|
||||||
};
|
};
|
||||||
make_error(message, arguments_span)
|
RevsetParseError::invalid_arguments(function_name, message, arguments_span)
|
||||||
};
|
};
|
||||||
|
|
||||||
let mut pos_iter = Some(0..max_arg_count);
|
let mut pos_iter = Some(0..max_arg_count);
|
||||||
|
@ -1376,8 +1373,9 @@ fn expect_named_arguments_vec<'i>(
|
||||||
let pos = pos_iter
|
let pos = pos_iter
|
||||||
.as_mut()
|
.as_mut()
|
||||||
.ok_or_else(|| {
|
.ok_or_else(|| {
|
||||||
make_error(
|
RevsetParseError::invalid_arguments(
|
||||||
"Positional argument follows keyword argument".to_owned(),
|
function_name,
|
||||||
|
"Positional argument follows keyword argument",
|
||||||
span,
|
span,
|
||||||
)
|
)
|
||||||
})?
|
})?
|
||||||
|
@ -1397,13 +1395,15 @@ fn expect_named_arguments_vec<'i>(
|
||||||
.iter()
|
.iter()
|
||||||
.position(|&n| n == name.as_str())
|
.position(|&n| n == name.as_str())
|
||||||
.ok_or_else(|| {
|
.ok_or_else(|| {
|
||||||
make_error(
|
RevsetParseError::invalid_arguments(
|
||||||
|
function_name,
|
||||||
format!(r#"Unexpected keyword argument "{}""#, name.as_str()),
|
format!(r#"Unexpected keyword argument "{}""#, name.as_str()),
|
||||||
span,
|
span,
|
||||||
)
|
)
|
||||||
})?;
|
})?;
|
||||||
if extracted_pairs[pos].is_some() {
|
if extracted_pairs[pos].is_some() {
|
||||||
return Err(make_error(
|
return Err(RevsetParseError::invalid_arguments(
|
||||||
|
function_name,
|
||||||
format!(r#"Got multiple values for keyword "{}""#, name.as_str()),
|
format!(r#"Got multiple values for keyword "{}""#, name.as_str()),
|
||||||
span,
|
span,
|
||||||
));
|
));
|
||||||
|
@ -1437,16 +1437,6 @@ fn parse_function_argument_to_string_pattern(
|
||||||
state: ParseState,
|
state: ParseState,
|
||||||
) -> Result<StringPattern, RevsetParseError> {
|
) -> Result<StringPattern, RevsetParseError> {
|
||||||
let span = pair.as_span();
|
let span = pair.as_span();
|
||||||
let make_error = |message| {
|
|
||||||
RevsetParseError::with_span(
|
|
||||||
RevsetParseErrorKind::InvalidFunctionArguments {
|
|
||||||
name: name.to_string(),
|
|
||||||
message,
|
|
||||||
},
|
|
||||||
span,
|
|
||||||
)
|
|
||||||
};
|
|
||||||
let make_type_error = || make_error("Expected function argument of string pattern".to_owned());
|
|
||||||
let expression = {
|
let expression = {
|
||||||
let mut inner_state = state;
|
let mut inner_state = state;
|
||||||
inner_state.allow_string_pattern = true;
|
inner_state.allow_string_pattern = true;
|
||||||
|
@ -1459,9 +1449,16 @@ fn parse_function_argument_to_string_pattern(
|
||||||
}
|
}
|
||||||
RevsetExpression::StringPattern { kind, value } => {
|
RevsetExpression::StringPattern { kind, value } => {
|
||||||
// TODO: error span can be narrowed to the lhs node
|
// TODO: error span can be narrowed to the lhs node
|
||||||
StringPattern::from_str_kind(value, kind).map_err(|err| make_error(err.to_string()))?
|
StringPattern::from_str_kind(value, kind)
|
||||||
|
.map_err(|err| RevsetParseError::invalid_arguments(name, err.to_string(), span))?
|
||||||
|
}
|
||||||
|
_ => {
|
||||||
|
return Err(RevsetParseError::invalid_arguments(
|
||||||
|
name,
|
||||||
|
"Expected function argument of string pattern",
|
||||||
|
span,
|
||||||
|
));
|
||||||
}
|
}
|
||||||
_ => return Err(make_type_error()),
|
|
||||||
};
|
};
|
||||||
Ok(pattern)
|
Ok(pattern)
|
||||||
}
|
}
|
||||||
|
@ -1474,11 +1471,9 @@ fn parse_function_argument_as_literal<T: FromStr>(
|
||||||
) -> Result<T, RevsetParseError> {
|
) -> Result<T, RevsetParseError> {
|
||||||
let span = pair.as_span();
|
let span = pair.as_span();
|
||||||
let make_error = || {
|
let make_error = || {
|
||||||
RevsetParseError::with_span(
|
RevsetParseError::invalid_arguments(
|
||||||
RevsetParseErrorKind::InvalidFunctionArguments {
|
name,
|
||||||
name: name.to_string(),
|
format!("Expected function argument of type {type_name}"),
|
||||||
message: format!("Expected function argument of type {type_name}"),
|
|
||||||
},
|
|
||||||
span,
|
span,
|
||||||
)
|
)
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue