]> granicus.if.org Git - git/commit
git mv: do not keep slash in `git mv dir non-existing-dir/`
authorJohannes Schindelin <johannes.schindelin@gmx.de>
Fri, 5 Aug 2016 14:41:12 +0000 (16:41 +0200)
committerJunio C Hamano <gitster@pobox.com>
Mon, 8 Aug 2016 17:43:20 +0000 (10:43 -0700)
commit189d035e67b1f8cdbb1dbd388efd1b7434f34b04
treea8155d6ee7d1052b8054a87945fa0152f9622f17
parent08df31eeccfe1576971ea4ba42570a424c3cfc41
git mv: do not keep slash in `git mv dir non-existing-dir/`

When calling `rename("dir", "non-existing-dir/")` on Linux, it silently
succeeds, stripping the trailing slash of the second argument.

This is all good and dandy but this behavior disagrees with the specs at

http://pubs.opengroup.org/onlinepubs/9699919799/functions/rename.html

that state clearly regarding the 2nd parameter (called `new`):

If the `new` argument does not resolve to an existing directory
entry for a file of type directory and the `new` argument
contains at least one non- <slash> character and ends with one
or more trailing <slash> characters after all symbolic links
have been processed, `rename()` shall fail.

Of course, we would like `git mv dir non-existing-dir/` to succeed (and
rename the directory "dir" to "non-existing-dir"). Let's be extra
careful to remove the trailing slash in that case.

This lets t7001-mv.sh pass in Bash on Windows.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/mv.c