mirror of
https://github.com/uutils/coreutils
synced 2024-12-14 23:32:39 +00:00
Merge pull request #5695 from cakebaker/mv_update_destination_with_trailing_slash
mv: allow destination with slash when using --update
This commit is contained in:
commit
2635ddf719
2 changed files with 19 additions and 1 deletions
|
@ -341,7 +341,11 @@ fn handle_two_paths(source: &Path, target: &Path, opts: &Options) -> UResult<()>
|
|||
|
||||
let target_is_dir = target.is_dir();
|
||||
|
||||
if path_ends_with_terminator(target) && !target_is_dir && !opts.no_target_dir {
|
||||
if path_ends_with_terminator(target)
|
||||
&& !target_is_dir
|
||||
&& !opts.no_target_dir
|
||||
&& opts.update != UpdateMode::ReplaceIfOlder
|
||||
{
|
||||
return Err(MvError::FailedToAccessNotADirectory(target.quote().to_string()).into());
|
||||
}
|
||||
|
||||
|
|
|
@ -905,6 +905,20 @@ fn test_mv_update_option() {
|
|||
assert!(!at.file_exists(file_b));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_mv_update_with_dest_ending_with_slash() {
|
||||
let (at, mut ucmd) = at_and_ucmd!();
|
||||
let source = "source";
|
||||
let dest = "destination/";
|
||||
|
||||
at.mkdir("source");
|
||||
|
||||
ucmd.arg("--update").arg(source).arg(dest).succeeds();
|
||||
|
||||
assert!(!at.dir_exists(source));
|
||||
assert!(at.dir_exists(dest));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_mv_arg_update_none() {
|
||||
let (at, mut ucmd) = at_and_ucmd!();
|
||||
|
|
Loading…
Reference in a new issue