mirror of
https://github.com/nushell/nushell
synced 2025-01-13 21:55:07 +00:00
unify the *-BuiltinVar
parser errors (#8944)
# Description this pr condenses `MutBuiltinVar`, `LetBuiltinVar` and `ConstBuiltinVar` into one error: ```nu Error: nu::parser::name_is_builtin_var × `in` used as variable name. ╭─[entry #69:1:1] 1 │ let in = 420 · ─┬ · ╰── already a builtin variable ╰──── help: 'in' is the name of a builtin Nushell variable and cannot be used as a variable name ``` it also fixes this case which was previously not handled ```nu let $nu = 420 # this variable would have been 'lost' ```
This commit is contained in:
parent
d339902dc6
commit
fb72da0e82
4 changed files with 40 additions and 29 deletions
|
@ -1,7 +1,7 @@
|
||||||
use nu_test_support::{nu, pipeline};
|
use nu_test_support::{nu, pipeline};
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn let_parse_error() {
|
fn let_name_builtin_var() {
|
||||||
let actual = nu!(
|
let actual = nu!(
|
||||||
cwd: ".", pipeline(
|
cwd: ".", pipeline(
|
||||||
r#"
|
r#"
|
||||||
|
|
|
@ -12,6 +12,34 @@ fn mut_variable() {
|
||||||
assert_eq!(actual.out, "4");
|
assert_eq!(actual.out, "4");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn mut_name_builtin_var() {
|
||||||
|
let actual = nu!(
|
||||||
|
cwd: ".", pipeline(
|
||||||
|
r#"
|
||||||
|
mut in = 3
|
||||||
|
"#
|
||||||
|
));
|
||||||
|
|
||||||
|
assert!(actual
|
||||||
|
.err
|
||||||
|
.contains("'in' is the name of a builtin Nushell variable"));
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn mut_name_builtin_var_with_dollar() {
|
||||||
|
let actual = nu!(
|
||||||
|
cwd: ".", pipeline(
|
||||||
|
r#"
|
||||||
|
mut $env = 3
|
||||||
|
"#
|
||||||
|
));
|
||||||
|
|
||||||
|
assert!(actual
|
||||||
|
.err
|
||||||
|
.contains("'env' is the name of a builtin Nushell variable"))
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn mut_variable_in_loop() {
|
fn mut_variable_in_loop() {
|
||||||
let actual = nu!(
|
let actual = nu!(
|
||||||
|
|
|
@ -2439,15 +2439,11 @@ pub fn parse_let_or_const(working_set: &mut StateWorkingSet, spans: &[Span]) ->
|
||||||
|
|
||||||
let var_name =
|
let var_name =
|
||||||
String::from_utf8_lossy(working_set.get_span_contents(lvalue.span))
|
String::from_utf8_lossy(working_set.get_span_contents(lvalue.span))
|
||||||
|
.trim_start_matches('$')
|
||||||
.to_string();
|
.to_string();
|
||||||
|
|
||||||
if ["in", "nu", "env", "nothing"].contains(&var_name.as_str()) {
|
if ["in", "nu", "env", "nothing"].contains(&var_name.as_str()) {
|
||||||
if is_const {
|
working_set.error(ParseError::NameIsBuiltinVar(var_name, lvalue.span))
|
||||||
working_set
|
|
||||||
.error(ParseError::ConstBuiltinVar(var_name, lvalue.span))
|
|
||||||
} else {
|
|
||||||
working_set.error(ParseError::LetBuiltinVar(var_name, lvalue.span))
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
let var_id = lvalue.as_var();
|
let var_id = lvalue.as_var();
|
||||||
|
@ -2551,10 +2547,11 @@ pub fn parse_mut(working_set: &mut StateWorkingSet, spans: &[Span]) -> Pipeline
|
||||||
|
|
||||||
let var_name =
|
let var_name =
|
||||||
String::from_utf8_lossy(working_set.get_span_contents(lvalue.span))
|
String::from_utf8_lossy(working_set.get_span_contents(lvalue.span))
|
||||||
|
.trim_start_matches('$')
|
||||||
.to_string();
|
.to_string();
|
||||||
|
|
||||||
if ["in", "nu", "env", "nothing"].contains(&var_name.as_str()) {
|
if ["in", "nu", "env", "nothing"].contains(&var_name.as_str()) {
|
||||||
working_set.error(ParseError::MutBuiltinVar(var_name, lvalue.span));
|
working_set.error(ParseError::NameIsBuiltinVar(var_name, lvalue.span))
|
||||||
}
|
}
|
||||||
|
|
||||||
let var_id = lvalue.as_var();
|
let var_id = lvalue.as_var();
|
||||||
|
|
|
@ -142,26 +142,14 @@ pub enum ParseError {
|
||||||
)]
|
)]
|
||||||
AssignInPipeline(String, String, String, #[label("'{0}' in pipeline")] Span),
|
AssignInPipeline(String, String, String, #[label("'{0}' in pipeline")] Span),
|
||||||
|
|
||||||
#[error("Let used with builtin variable name.")]
|
#[error("`{0}` used as variable name.")]
|
||||||
#[diagnostic(
|
#[diagnostic(
|
||||||
code(nu::parser::let_builtin_var),
|
code(nu::parser::name_is_builtin_var),
|
||||||
help("'{0}' is the name of a builtin Nushell variable. `let` cannot assign to it.")
|
help(
|
||||||
|
"'{0}' is the name of a builtin Nushell variable and cannot be used as a variable name"
|
||||||
|
)
|
||||||
)]
|
)]
|
||||||
LetBuiltinVar(String, #[label("already a builtin variable")] Span),
|
NameIsBuiltinVar(String, #[label("already a builtin variable")] Span),
|
||||||
|
|
||||||
#[error("Const used with builtin variable name.")]
|
|
||||||
#[diagnostic(
|
|
||||||
code(nu::parser::let_builtin_var),
|
|
||||||
help("'{0}' is the name of a builtin Nushell variable. `const` cannot assign to it.")
|
|
||||||
)]
|
|
||||||
ConstBuiltinVar(String, #[label("already a builtin variable")] Span),
|
|
||||||
|
|
||||||
#[error("Mut used with builtin variable name.")]
|
|
||||||
#[diagnostic(
|
|
||||||
code(nu::parser::let_builtin_var),
|
|
||||||
help("'{0}' is the name of a builtin Nushell variable. `mut` cannot assign to it.")
|
|
||||||
)]
|
|
||||||
MutBuiltinVar(String, #[label("already a builtin variable")] Span),
|
|
||||||
|
|
||||||
#[error("Incorrect value")]
|
#[error("Incorrect value")]
|
||||||
#[diagnostic(code(nu::parser::incorrect_value), help("{2}"))]
|
#[diagnostic(code(nu::parser::incorrect_value), help("{2}"))]
|
||||||
|
@ -445,9 +433,7 @@ impl ParseError {
|
||||||
ParseError::CantAliasExpression(_, s) => *s,
|
ParseError::CantAliasExpression(_, s) => *s,
|
||||||
ParseError::BuiltinCommandInPipeline(_, s) => *s,
|
ParseError::BuiltinCommandInPipeline(_, s) => *s,
|
||||||
ParseError::AssignInPipeline(_, _, _, s) => *s,
|
ParseError::AssignInPipeline(_, _, _, s) => *s,
|
||||||
ParseError::LetBuiltinVar(_, s) => *s,
|
ParseError::NameIsBuiltinVar(_, s) => *s,
|
||||||
ParseError::MutBuiltinVar(_, s) => *s,
|
|
||||||
ParseError::ConstBuiltinVar(_, s) => *s,
|
|
||||||
ParseError::CaptureOfMutableVar(s) => *s,
|
ParseError::CaptureOfMutableVar(s) => *s,
|
||||||
ParseError::IncorrectValue(_, s, _) => *s,
|
ParseError::IncorrectValue(_, s, _) => *s,
|
||||||
ParseError::MultipleRestParams(s) => *s,
|
ParseError::MultipleRestParams(s) => *s,
|
||||||
|
|
Loading…
Reference in a new issue