diff options
author | Andrew Tridgell <tridge@samba.org> | 2006-05-30 05:57:43 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 14:08:44 -0500 |
commit | 0a1a19d9d95b5adbe6c3dd3ed689ce7e3b43ab12 (patch) | |
tree | fdce0cec565cce5cd12563682d07a95de7cfb5ef /source4 | |
parent | 86f86f99efa44037e31a773fb561eca0c9d31d2a (diff) | |
download | samba-0a1a19d9d95b5adbe6c3dd3ed689ce7e3b43ab12.tar.gz samba-0a1a19d9d95b5adbe6c3dd3ed689ce7e3b43ab12.tar.bz2 samba-0a1a19d9d95b5adbe6c3dd3ed689ce7e3b43ab12.zip |
r15953: our timegm() replacement still doesn't work, so grab the one from
Heimdal which does work. This should fix most of the rest of the
failures on solaris
(This used to be commit acfaa98b5ea686feb81350baf09b3f4480f96edc)
Diffstat (limited to 'source4')
-rw-r--r-- | source4/lib/replace/config.mk | 1 | ||||
-rw-r--r-- | source4/lib/replace/replace.c | 13 | ||||
-rw-r--r-- | source4/lib/replace/replace.h | 4 | ||||
-rw-r--r-- | source4/lib/replace/timegm.c (renamed from source4/heimdal/lib/asn1/timegm.c) | 55 |
4 files changed, 33 insertions, 40 deletions
diff --git a/source4/lib/replace/config.mk b/source4/lib/replace/config.mk index 4fd5402f61..7ec1eaffa2 100644 --- a/source4/lib/replace/config.mk +++ b/source4/lib/replace/config.mk @@ -11,6 +11,7 @@ OBJ_FILES = \ [SUBSYSTEM::LIBREPLACE] OBJ_FILES = replace.o \ snprintf.o \ + timegm.o \ dlfcn.o \ getpass.o PUBLIC_DEPENDENCIES = REPLACE_READDIR diff --git a/source4/lib/replace/replace.c b/source4/lib/replace/replace.c index 38a3d517df..6f51bd2e99 100644 --- a/source4/lib/replace/replace.c +++ b/source4/lib/replace/replace.c @@ -368,19 +368,6 @@ duplicate a string #endif /* HAVE_VSYSLOG */ -#ifndef HAVE_TIMEGM -/* - yes, I know this looks insane, but its really needed. The function in the - Linux timegm() manpage does not work on solaris. -*/ - time_t timegm(struct tm *tm) -{ - time_t t = mktime(tm); - t -= mktime(gmtime(&t)) - (int)mktime(localtime(&t)); - return t; -} -#endif - #ifndef HAVE_SETENV int setenv(const char *name, const char *value, int overwrite) { diff --git a/source4/lib/replace/replace.h b/source4/lib/replace/replace.h index 7a1c4b5ce7..f9d67fb2ec 100644 --- a/source4/lib/replace/replace.h +++ b/source4/lib/replace/replace.h @@ -112,6 +112,10 @@ int vasprintf(char **ptr, const char *format, va_list ap); #define bzero(a,b) memset((a),'\0',(b)) #endif +#ifndef HAVE_TIMEGM +time_t timegm(struct tm *tm); +#endif + #ifndef PRINTF_ATTRIBUTE #if __GNUC__ >= 3 /** Use gcc attribute to check printf fns. a1 is the 1-based index of diff --git a/source4/heimdal/lib/asn1/timegm.c b/source4/lib/replace/timegm.c index bdc997fa44..f2741e0eff 100644 --- a/source4/heimdal/lib/asn1/timegm.c +++ b/source4/lib/replace/timegm.c @@ -31,41 +31,42 @@ * SUCH DAMAGE. */ -#include "der_locl.h" +/* + adapted for Samba4 by Andrew Tridgell +*/ -RCSID("$Id: timegm.c,v 1.7 1999/12/02 17:05:02 joda Exp $"); +#include "includes.h" +#include "system/time.h" #ifndef HAVE_TIMEGM -static int -is_leap(unsigned y) +static int is_leap(unsigned y) { - y += 1900; - return (y % 4) == 0 && ((y % 100) != 0 || (y % 400) == 0); + y += 1900; + return (y % 4) == 0 && ((y % 100) != 0 || (y % 400) == 0); } -time_t -timegm (struct tm *tm) +time_t timegm(struct tm *tm) { - static const unsigned ndays[2][12] ={ - {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}, - {31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}}; - time_t res = 0; - unsigned i; - - for (i = 70; i < tm->tm_year; ++i) - res += is_leap(i) ? 366 : 365; - - for (i = 0; i < tm->tm_mon; ++i) - res += ndays[is_leap(tm->tm_year)][i]; - res += tm->tm_mday - 1; - res *= 24; - res += tm->tm_hour; - res *= 60; - res += tm->tm_min; - res *= 60; - res += tm->tm_sec; - return res; + static const unsigned ndays[2][12] ={ + {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}, + {31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}}; + time_t res = 0; + unsigned i; + + for (i = 70; i < tm->tm_year; ++i) + res += is_leap(i) ? 366 : 365; + + for (i = 0; i < tm->tm_mon; ++i) + res += ndays[is_leap(tm->tm_year)][i]; + res += tm->tm_mday - 1; + res *= 24; + res += tm->tm_hour; + res *= 60; + res += tm->tm_min; + res *= 60; + res += tm->tm_sec; + return res; } #endif /* HAVE_TIMEGM */ |