Browse Source

close_lock_file(): exit (successfully) if file is already closed

Suggested-by: Jonathan Nieder <jrnieder@gmail.com>
Signed-off-by: Michael Haggerty <mhagger@alum.mit.edu>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Michael Haggerty 10 years ago committed by Junio C Hamano
parent
commit
419f0c0f68
  1. 6
      lockfile.c
  2. 2
      read-cache.c

6
lockfile.c

@ -233,6 +233,10 @@ int hold_lock_file_for_append(struct lock_file *lk, const char *path, int flags) @@ -233,6 +233,10 @@ int hold_lock_file_for_append(struct lock_file *lk, const char *path, int flags)
int close_lock_file(struct lock_file *lk)
{
int fd = lk->fd;

if (fd < 0)
return 0;

lk->fd = -1;
return close(fd);
}
@ -251,7 +255,7 @@ int commit_lock_file(struct lock_file *lk) @@ -251,7 +255,7 @@ int commit_lock_file(struct lock_file *lk)
{
char result_file[PATH_MAX];
size_t i;
if (lk->fd >= 0 && close_lock_file(lk))
if (close_lock_file(lk))
return -1;
strcpy(result_file, lk->filename);
i = strlen(result_file) - 5; /* .lock */

2
read-cache.c

@ -2042,7 +2042,7 @@ void set_alternate_index_output(const char *name) @@ -2042,7 +2042,7 @@ void set_alternate_index_output(const char *name)
static int commit_locked_index(struct lock_file *lk)
{
if (alternate_index_output) {
if (lk->fd >= 0 && close_lock_file(lk))
if (close_lock_file(lk))
return -1;
if (rename(lk->filename, alternate_index_output))
return -1;

Loading…
Cancel
Save