diff options
author | Junio C Hamano <junkio@cox.net> | 2006-08-12 01:03:47 -0700 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2006-08-12 17:08:25 -0700 |
commit | 40aaae88adfe05be435b7bd17093d49869f3276f (patch) | |
tree | cbc2c6410884604c15a4301841b23e658cf2096a /refs.c | |
parent | fd7bcfb524a3313ef5361bdd8493ba50635f50f0 (diff) | |
download | git-40aaae88adfe05be435b7bd17093d49869f3276f.tar.gz git-40aaae88adfe05be435b7bd17093d49869f3276f.tar.xz |
Better error message when we are unable to lock the index file
Most of the callers except the one in refs.c use the function to
update the index file. Among the index writers, everybody
except write-tree dies if they cannot open it for writing.
This gives the function an extra argument, to tell it to die
when it cannot create a new file as the lockfile.
The only caller that does not have to die is write-tree, because
updating the index for the cache-tree part is optional and not
being able to do so does not affect the correctness. I think we
do not have to be so careful and make the failure into die() the
same way as other callers, but that would be a different patch.
Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'refs.c')
-rw-r--r-- | refs.c | 8 |
1 files changed, 1 insertions, 7 deletions
@@ -319,13 +319,7 @@ static struct ref_lock *lock_ref_sha1_basic(const char *path, if (safe_create_leading_directories(lock->ref_file)) die("unable to create directory for %s", lock->ref_file); - lock->lock_fd = hold_lock_file_for_update(lock->lk, lock->ref_file); - if (lock->lock_fd < 0) { - error("Couldn't open lock file %s: %s", - lock->lk->filename, strerror(errno)); - unlock_ref(lock); - return NULL; - } + lock->lock_fd = hold_lock_file_for_update(lock->lk, lock->ref_file, 1); return old_sha1 ? verify_lock(lock, old_sha1, mustexist) : lock; } |