On Wed, Jun 6, 2018 at 9:32 PM, Thomas Fischer <thomasfischer@xxxxxxxxxxxx> wrote: > OVERVIEW > > "git rm" will remove more files than specified. This is either a bug or undocumented behavior (not in the man pages). The behavior is intended, with a question mark. This change is introduced in d9b814cc97 (Add builtin "git rm" command - 2006-05-19). I quote the relevant paragraph from that commit The other question is what to do with leading directories. The old "git rm" script didn't do anything, which is somewhat inconsistent. This one will actually clean up directories that have become empty as a result of removing the last file, but maybe we want to have a flag to decide the behaviour? To me we definitely should document this (patches welcome!) then maybe revisit this "have a flag to decide the behavior" question from 12 years ago. > SETUP > > 1. In a git repository, create an empty directory OR a chain of empty directories > > $ mkdir -p path/to/some/ > > 2. Create a file in the deepest directory and add it to tracking > > $ touch path/to/some/file > $ git add path/to/some/file > $ git commit -m 'add path/to/some/file' > > THE BUG > > Run 'git rm' on the tracked file. > > EXPECTED BEHAVIOR > > $ git rm path/to/some/file > rm 'path/to/some/file' > $ ls path > to/ > $ ls path/to > some/ > > Note that path/, path/to/, and path/to/some/ still exist. > > ACTUAL BEHAVIOR > > $ git rm path/to/some/file > rm 'path/to/some/file' > $ ls path > ls: cannot access 'path': No such file or directory > > The entire chain of empty directories is removed, despite the fact the git outputs only "rm 'path/to/some/file'". > > This ONLY occurs when all the directories in the chain are empty after the tracked file has been removed. > > This behavior is NOT documented in the man pages. > > I propose that 'rmdir' statements are added to 'git rm' output, or that the man pages be updated to reflect this behavior. > > Best, > Thomas Fischer -- Duy