mirror of
https://github.com/nushell/nushell
synced 2025-01-16 07:04:09 +00:00
Improve the 'use' and 'source' errors (#4966)
* Improve the 'use' and 'source' errors * Add register
This commit is contained in:
parent
19fa41b114
commit
66087b01e6
2 changed files with 35 additions and 6 deletions
|
@ -95,7 +95,11 @@ pub enum ParseError {
|
||||||
VariableNotValid(#[label = "variable name can't contain spaces or quotes"] Span),
|
VariableNotValid(#[label = "variable name can't contain spaces or quotes"] Span),
|
||||||
|
|
||||||
#[error("Module not found.")]
|
#[error("Module not found.")]
|
||||||
#[diagnostic(code(nu::parser::module_not_found), url(docsrs))]
|
#[diagnostic(
|
||||||
|
code(nu::parser::module_not_found),
|
||||||
|
url(docsrs),
|
||||||
|
help("module files need to be available before your script is run")
|
||||||
|
)]
|
||||||
ModuleNotFound(#[label = "module not found"] Span),
|
ModuleNotFound(#[label = "module not found"] Span),
|
||||||
|
|
||||||
#[error("Not found.")]
|
#[error("Not found.")]
|
||||||
|
@ -221,6 +225,22 @@ pub enum ParseError {
|
||||||
#[diagnostic(code(nu::parser::export_not_found), url(docsrs))]
|
#[diagnostic(code(nu::parser::export_not_found), url(docsrs))]
|
||||||
ExportNotFound(#[label = "could not find imports"] Span),
|
ExportNotFound(#[label = "could not find imports"] Span),
|
||||||
|
|
||||||
|
#[error("File not found")]
|
||||||
|
#[diagnostic(
|
||||||
|
code(nu::parser::sourced_file_not_found),
|
||||||
|
url(docsrs),
|
||||||
|
help("sourced files need to be available before your script is run")
|
||||||
|
)]
|
||||||
|
SourcedFileNotFound(String, #[label("File not found: {0}")] Span),
|
||||||
|
|
||||||
|
#[error("File not found")]
|
||||||
|
#[diagnostic(
|
||||||
|
code(nu::parser::registered_file_not_found),
|
||||||
|
url(docsrs),
|
||||||
|
help("registered files need to be available before your script is run")
|
||||||
|
)]
|
||||||
|
RegisteredFileNotFound(String, #[label("File not found: {0}")] Span),
|
||||||
|
|
||||||
#[error("File not found")]
|
#[error("File not found")]
|
||||||
#[diagnostic(code(nu::parser::file_not_found), url(docsrs))]
|
#[diagnostic(code(nu::parser::file_not_found), url(docsrs))]
|
||||||
FileNotFound(String, #[label("File not found: {0}")] Span),
|
FileNotFound(String, #[label("File not found: {0}")] Span),
|
||||||
|
@ -274,6 +294,8 @@ impl ParseError {
|
||||||
ParseError::MissingImportPattern(s) => *s,
|
ParseError::MissingImportPattern(s) => *s,
|
||||||
ParseError::WrongImportPattern(s) => *s,
|
ParseError::WrongImportPattern(s) => *s,
|
||||||
ParseError::ExportNotFound(s) => *s,
|
ParseError::ExportNotFound(s) => *s,
|
||||||
|
ParseError::SourcedFileNotFound(_, s) => *s,
|
||||||
|
ParseError::RegisteredFileNotFound(_, s) => *s,
|
||||||
ParseError::FileNotFound(_, s) => *s,
|
ParseError::FileNotFound(_, s) => *s,
|
||||||
ParseError::LabeledError(_, _, s) => *s,
|
ParseError::LabeledError(_, _, s) => *s,
|
||||||
}
|
}
|
||||||
|
|
|
@ -1853,7 +1853,7 @@ pub fn parse_source(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
error = error.or(Some(ParseError::FileNotFound(filename, spans[1])));
|
error = error.or(Some(ParseError::SourcedFileNotFound(filename, spans[1])));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return (garbage_pipeline(spans), Some(ParseError::NonUtf8(spans[1])));
|
return (garbage_pipeline(spans), Some(ParseError::NonUtf8(spans[1])));
|
||||||
|
@ -1959,14 +1959,17 @@ pub fn parse_register(
|
||||||
if let Some(p) = find_in_dirs(&name, working_set, &cwd, PLUGIN_DIRS_ENV) {
|
if let Some(p) = find_in_dirs(&name, working_set, &cwd, PLUGIN_DIRS_ENV) {
|
||||||
Ok(p)
|
Ok(p)
|
||||||
} else {
|
} else {
|
||||||
Err(ParseError::FileNotFound(name, expr.span))
|
Err(ParseError::RegisteredFileNotFound(name, expr.span))
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
.and_then(|path| {
|
.and_then(|path| {
|
||||||
if path.exists() & path.is_file() {
|
if path.exists() & path.is_file() {
|
||||||
Ok(path)
|
Ok(path)
|
||||||
} else {
|
} else {
|
||||||
Err(ParseError::FileNotFound(format!("{:?}", path), expr.span))
|
Err(ParseError::RegisteredFileNotFound(
|
||||||
|
format!("{:?}", path),
|
||||||
|
expr.span,
|
||||||
|
))
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
@ -2007,13 +2010,17 @@ pub fn parse_register(
|
||||||
String::from_utf8(shell_expr.to_vec())
|
String::from_utf8(shell_expr.to_vec())
|
||||||
.map_err(|_| ParseError::NonUtf8(expr.span))
|
.map_err(|_| ParseError::NonUtf8(expr.span))
|
||||||
.and_then(|name| {
|
.and_then(|name| {
|
||||||
canonicalize_with(&name, cwd).map_err(|_| ParseError::FileNotFound(name, expr.span))
|
canonicalize_with(&name, cwd)
|
||||||
|
.map_err(|_| ParseError::RegisteredFileNotFound(name, expr.span))
|
||||||
})
|
})
|
||||||
.and_then(|path| {
|
.and_then(|path| {
|
||||||
if path.exists() & path.is_file() {
|
if path.exists() & path.is_file() {
|
||||||
Ok(path)
|
Ok(path)
|
||||||
} else {
|
} else {
|
||||||
Err(ParseError::FileNotFound(format!("{:?}", path), expr.span))
|
Err(ParseError::RegisteredFileNotFound(
|
||||||
|
format!("{:?}", path),
|
||||||
|
expr.span,
|
||||||
|
))
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue