diff options
author | Jeff King <peff@peff.net> | 2014-04-01 17:28:42 -0400 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-04-01 14:39:04 -0700 |
commit | 6654754779d2a90af91a9c6b93d7e4e7ee16cfab (patch) | |
tree | 1b6a7851e5e1dfd88ac4705de569343dfe0f0931 /git-compat-util.h | |
parent | 3f419d45ef0dfc33dc301d9ae4737043c091291a (diff) | |
download | git-6654754779d2a90af91a9c6b93d7e4e7ee16cfab.tar.gz |
date: recognize bogus FreeBSD gmtime output
Most gmtime implementations return a NULL value when they
encounter an error (and this behavior is specified by ANSI C
and POSIX). FreeBSD's implementation, however, will simply
leave the "struct tm" untouched. Let's also recognize this
and convert it to a NULL (with this patch, t4212 should pass
on FreeBSD).
Reported-by: René Scharfe <l.s.r@web.de>
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'git-compat-util.h')
-rw-r--r-- | git-compat-util.h | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/git-compat-util.h b/git-compat-util.h index ad4762499e..66728145b4 100644 --- a/git-compat-util.h +++ b/git-compat-util.h @@ -697,4 +697,11 @@ void warn_on_inaccessible(const char *path); /* Get the passwd entry for the UID of the current process. */ struct passwd *xgetpwuid_self(void); +#ifdef GMTIME_UNRELIABLE_ERRORS +struct tm *git_gmtime(const time_t *); +struct tm *git_gmtime_r(const time_t *, struct tm *); +#define gmtime git_gmtime +#define gmtime_r git_gmtime_r +#endif + #endif |