Merge branch 'jk/fix-refresh-utime'

Fix a small bug in our use of umask() return value.

* jk/fix-refresh-utime:
  check_and_freshen_file: fix reversed success-check
This commit is contained in:
Junio C Hamano 2015-07-10 14:26:14 -07:00
commit 1f9e0a5348

View File

@ -443,6 +443,7 @@ void prepare_alt_odb(void)
read_info_alternates(get_object_directory(), 0); read_info_alternates(get_object_directory(), 0);
} }
/* Returns 1 if we have successfully freshened the file, 0 otherwise. */
static int freshen_file(const char *fn) static int freshen_file(const char *fn)
{ {
struct utimbuf t; struct utimbuf t;
@ -450,11 +451,18 @@ static int freshen_file(const char *fn)
return !utime(fn, &t); return !utime(fn, &t);
} }
/*
* All of the check_and_freshen functions return 1 if the file exists and was
* freshened (if freshening was requested), 0 otherwise. If they return
* 0, you should not assume that it is safe to skip a write of the object (it
* either does not exist on disk, or has a stale mtime and may be subject to
* pruning).
*/
static int check_and_freshen_file(const char *fn, int freshen) static int check_and_freshen_file(const char *fn, int freshen)
{ {
if (access(fn, F_OK)) if (access(fn, F_OK))
return 0; return 0;
if (freshen && freshen_file(fn)) if (freshen && !freshen_file(fn))
return 0; return 0;
return 1; return 1;
} }