commit_ref(): if there is an empty dir in the way, delete it
commit5387c0d8839e366c44838c808ccc20eb7f9bd358
authorMichael Haggerty <mhagger@alum.mit.edu>
Thu, 5 May 2016 13:33:03 +0000 (5 15:33 +0200)
committerMichael Haggerty <mhagger@alum.mit.edu>
Thu, 5 May 2016 14:31:17 +0000 (5 16:31 +0200)
tree8a892e8d400343d7fd17e05e95b7f4d8600bef38
parent19dd7d06e5d2c58895dd101025c013404025e192
commit_ref(): if there is an empty dir in the way, delete it

Part of the bug revealed in the last commit is that resolve_ref_unsafe()
incorrectly returns EISDIR if it finds a directory in the place where it
is looking for a loose reference, even if the corresponding packed
reference exists. lock_ref_sha1_basic() notices the bogus EISDIR, and
use it as an indication that it should call remove_empty_directories()
and call resolve_ref_unsafe() again.

But resolve_ref_unsafe() shouldn't report EISDIR in this case. If we
would simply make that change, then remove_empty_directories() wouldn't
get called anymore, and the empty directory would get in the way when
commit_ref() calls commit_lock_file() to rename the lockfile into place.

So instead of relying on lock_ref_sha1_basic() to delete empty
directories, teach commit_ref(), just before calling commit_lock_file(),
to check whether a directory is in the way, and if so, try to delete it.

Signed-off-by: Michael Haggerty <mhagger@alum.mit.edu>
refs/files-backend.c