Stefan Beller <sbel...@google.com> writes:

>                       if (list.entry[i].is_submodule) {
>                               if (is_empty_dir(path)) {
> +                                     if (rmdir(path))
> +                                             die_errno("git rm: '%s'", path);
> +                             } else if (file_exists(path))
> +                                     /* non empty directory: */

Lose colon?

> +                                     remove_directory_or_die(path);

... otherwise?  I.e.

                                else
                                        ???

If we are running "git rm -f <path>", then the path could be a
submodule in the index and on the filesystem, it could be (1)
already missing, as the user removed an empty submodule directory
she is not interested in, (2) a non-directory, e.g. a file or a
symbolic link, perhaps because she was trying to reorganize the
superproject working tree but decided against it, or (3) something
else?

(1) is perfectly OK; we end up with a result without the path, which
is what "git rm -f" wanted to do anyway.  I am not sure what should
happen in (2), and what other corner cases there are for (3), though.

And use of file_exists(path) in the above patch may trigger a
strange error message in case (2), as remove_directory_or_die()
would say "path is not a directory", to which the user will say "Yes
I know, I wanted you to remove it with 'git rm -f'".



Reply via email to