mirror of
https://github.com/nushell/nushell
synced 2025-01-28 04:45:18 +00:00
Add first prototype of functionality to parse numbers in parantheses (#3209)
* Add first prototype of functionality to parse numbers in parantheses (). Needs testing and more wide-testing+integration * Fix styling issue * Try something else by copying existing matching code * Fix formatting * Fix the parser to accept numbers in paranthesis. Not really happy with the code, but let's see * Refactor to only use once the parsing of strings into numbers * Remove errors that are not used * Fix formatting Co-authored-by: Stefan Stanciulescu <contact@stefanstanciulescu.com>
This commit is contained in:
parent
cfee151d4e
commit
001123dbd6
1 changed files with 67 additions and 0 deletions
|
@ -772,6 +772,65 @@ fn parse_table(
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Tries to parse a number in a paranthesis, e.g., (123) or (-123)
|
||||||
|
fn try_parse_number_in_paranthesis(
|
||||||
|
lite_arg: &Spanned<String>,
|
||||||
|
) -> (SpannedExpression, Option<ParseError>) {
|
||||||
|
let mut chars = lite_arg.item.chars();
|
||||||
|
|
||||||
|
match (chars.next(), chars.next_back()) {
|
||||||
|
(Some('('), Some(')')) => {
|
||||||
|
match chars.as_str().trim().parse::<BigInt>() {
|
||||||
|
Ok(parsed_integer) => (
|
||||||
|
SpannedExpression::new(Expression::integer(parsed_integer), lite_arg.span),
|
||||||
|
None,
|
||||||
|
),
|
||||||
|
// we don't care if it does not manage to parse it, because then likely it is not a number
|
||||||
|
Err(_) => {
|
||||||
|
match chars.as_str().trim().parse::<BigDecimal>() {
|
||||||
|
Ok(parsed_decimal) => (
|
||||||
|
SpannedExpression::new(
|
||||||
|
Expression::decimal(parsed_decimal),
|
||||||
|
lite_arg.span,
|
||||||
|
),
|
||||||
|
None,
|
||||||
|
),
|
||||||
|
// we don't care if it does not manage to parse it, because then likely it is not a number
|
||||||
|
Err(_) => (
|
||||||
|
garbage(lite_arg.span),
|
||||||
|
Some(ParseError::mismatch(
|
||||||
|
"cannot parse number",
|
||||||
|
lite_arg.clone(),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
(Some('('), _) => (
|
||||||
|
garbage(lite_arg.span),
|
||||||
|
Some(ParseError::mismatch(
|
||||||
|
"missing closing bracket",
|
||||||
|
lite_arg.clone(),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
(_, Some(')')) => (
|
||||||
|
garbage(lite_arg.span),
|
||||||
|
Some(ParseError::mismatch(
|
||||||
|
"missing starting bracket",
|
||||||
|
lite_arg.clone(),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
(_, _) => (
|
||||||
|
garbage(lite_arg.span),
|
||||||
|
Some(ParseError::mismatch(
|
||||||
|
"number in paranthesis",
|
||||||
|
lite_arg.clone(),
|
||||||
|
)),
|
||||||
|
),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Parses the given argument using the shape as a guide for how to correctly parse the argument
|
/// Parses the given argument using the shape as a guide for how to correctly parse the argument
|
||||||
fn parse_arg(
|
fn parse_arg(
|
||||||
expected_type: SyntaxShape,
|
expected_type: SyntaxShape,
|
||||||
|
@ -782,6 +841,14 @@ fn parse_arg(
|
||||||
return parse_dollar_expr(&lite_arg, scope);
|
return parse_dollar_expr(&lite_arg, scope);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// before anything else, try to see if this is a number in paranthesis
|
||||||
|
if lite_arg.item.starts_with('(') {
|
||||||
|
let (expr, err) = try_parse_number_in_paranthesis(lite_arg);
|
||||||
|
if err.is_none() {
|
||||||
|
return (expr, None);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
match expected_type {
|
match expected_type {
|
||||||
SyntaxShape::Number => {
|
SyntaxShape::Number => {
|
||||||
if let Ok(x) = lite_arg.item.parse::<BigInt>() {
|
if let Ok(x) = lite_arg.item.parse::<BigInt>() {
|
||||||
|
|
Loading…
Reference in a new issue