forked from extern/nushell
nu-path crate refactor (#3730)
* Resolve rebase artifacts * Remove leftover dependencies on removed feature * Remove unnecessary 'pub' * Start taking notes and fooling around * Split canonicalize to two versions; Add TODOs One that takes `relative_to` and one that doesn't. More TODO notes. * Merge absolutize to and rename resolve_dots * Add custom absolutize fn and use it in path expand * Convert a couple of dunce::canonicalize to ours * Update nu-path description * Replace all canonicalize with nu-path version * Remove leftover dunce dependencies * Fix broken autocd with trailing slash Trailing slash is preserved *only* in paths that do not contain "." or "..". This should be fixed in the future to cover all paths but for now it at least covers basic cases. * Use dunce::canonicalize for canonicalizing * Alow cd recovery from non-existent cwd * Disable removed canonicalize functionality tests Remove unused import * Break down nu-path into separate modules * Remove unused public imports * Remove abundant cow mapping * Fix clippy warning * Reformulate old canonicalize tests to expand_path They wouldn't work with the new canonicalize. * Canonicalize also ~ and ndots; Unify path joining Also, add doc comments in nu_path::expansions. * Add comment * Avoid expanding ndots if path is not valid UTF-8 With this change, no lossy path->string conversion should happen in the nu-path crate. * Fmt * Slight expand_tilde refactor; Add doc comments * Start nu-path integration tests * Add tests TODO * Fix docstring typo * Fix some doc strings * Add README for nu-path crate * Add a couple of canonicalize tests * Add nu-path integration tests * Add trim trailing slashes tests * Update nu-path dependency * Remove unused import * Regenerate lockfile
This commit is contained in:
@ -1,11 +1,10 @@
|
||||
use std::borrow::Cow;
|
||||
use std::{path::PathBuf, sync::Arc};
|
||||
|
||||
use bigdecimal::BigDecimal;
|
||||
use indexmap::IndexMap;
|
||||
use log::trace;
|
||||
use nu_errors::{ArgumentError, ParseError};
|
||||
use nu_path::{expand_path, expand_path_string};
|
||||
use nu_path::expand_path;
|
||||
use nu_protocol::hir::{
|
||||
self, Binary, Block, Call, ClassifiedCommand, Expression, ExternalRedirection, Flag, FlagKind,
|
||||
Group, InternalCommand, Member, NamedArguments, Operator, Pipeline, RangeOperator,
|
||||
@ -954,8 +953,8 @@ fn parse_arg(
|
||||
)
|
||||
}
|
||||
SyntaxShape::GlobPattern => {
|
||||
let trimmed = Cow::Owned(trim_quotes(&lite_arg.item));
|
||||
let expanded = expand_path_string(trimmed).to_string();
|
||||
let trimmed = trim_quotes(&lite_arg.item);
|
||||
let expanded = expand_path(trimmed).to_string_lossy().to_string();
|
||||
(
|
||||
SpannedExpression::new(Expression::glob_pattern(expanded), lite_arg.span),
|
||||
None,
|
||||
@ -972,7 +971,7 @@ fn parse_arg(
|
||||
SyntaxShape::FilePath => {
|
||||
let trimmed = trim_quotes(&lite_arg.item);
|
||||
let path = PathBuf::from(trimmed);
|
||||
let expanded = expand_path(Cow::Owned(path)).to_path_buf();
|
||||
let expanded = expand_path(path);
|
||||
(
|
||||
SpannedExpression::new(Expression::FilePath(expanded), lite_arg.span),
|
||||
None,
|
||||
@ -1659,8 +1658,8 @@ fn parse_external_call(
|
||||
) -> (Option<ClassifiedCommand>, Option<ParseError>) {
|
||||
let mut error = None;
|
||||
let name = lite_cmd.parts[0].clone().map(|v| {
|
||||
let trimmed = Cow::Owned(trim_quotes(&v));
|
||||
expand_path_string(trimmed).to_string()
|
||||
let trimmed = trim_quotes(&v);
|
||||
expand_path(trimmed).to_string_lossy().to_string()
|
||||
});
|
||||
|
||||
let mut args = vec![];
|
||||
|
Reference in New Issue
Block a user