/* timegm.cc timegm: Portable version of timegm (mytimegm) for ht://Dig Based on a version from the GNU C Library and a previous implementation for ht://Dig Part of the ht://Dig package Copyright (c) 1999-2004 The ht://Dig Group For copyright details, see the file COPYING in your distribution or the GNU Library General Public License (LGPL) version 2 or later $Id: timegm.c,v 1.18 2004/05/28 13:15:22 lha Exp $ */ /* Copyright (C) 1993, 1994, 1995, 1996, 1997 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Paul Eggert (eggert@twinsun.com). The GNU C Library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. The GNU C Library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with the GNU C Library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ /* #define TEST_TIMEGM */ #include #ifdef TEST_TIMEGM #include #include #endif static struct tm *my_mktime_gmtime_r (const time_t *t, struct tm *tp); static struct tm *my_mktime_gmtime_r (const time_t *t, struct tm *tp) { struct tm *l = gmtime (t); if (! l) return 0; *tp = *l; return tp; } time_t __mktime_internal(struct tm *, struct tm *(*) (const time_t *, struct tm *), time_t *); time_t Httimegm(tmp) struct tm *tmp; { static time_t gmtime_offset; tmp->tm_isdst = 0; return __mktime_internal (tmp, my_mktime_gmtime_r, &gmtime_offset); } #ifdef TEST_TIMEGM void parse_time(char *s, struct tm *tm) { sscanf(s, "%d.%d.%d %d:%d:%d", &tm->tm_year, &tm->tm_mon, &tm->tm_mday, &tm->tm_hour, &tm->tm_min, &tm->tm_sec); tm->tm_year -= 1900; tm->tm_mon--; } void print_time(struct tm *tm) { fprintf(stderr, "%04d.%02d.%02d %02d:%02d:%02d", tm->tm_year+1900, tm->tm_mon+1, tm->tm_mday, tm->tm_hour, tm->tm_min, tm->tm_sec); } int time_equal(struct tm *tm1, struct tm *tm2) { return ((tm1->tm_year == tm2->tm_year) && (tm1->tm_mon == tm2->tm_mon) && (tm1->tm_mday == tm2->tm_mday) && (tm1->tm_hour == tm2->tm_hour) && (tm1->tm_min == tm2->tm_min) && (tm1->tm_sec == tm2->tm_sec)); } int main(void) { char *test_dates[] = { "1970.01.01 00:00:00", "1970.01.01 00:00:01", "1972.02.05 23:59:59", "1972.02.28 00:59:59", "1972.02.28 23:59:59", "1972.02.29 00:00:00", "1972.03.01 13:00:04", "1973.03.01 12:00:00", "1980.01.01 00:00:05", "1984.12.31 23:00:00", "1997.06.05 17:55:35", "1999.12.31 23:00:00", "2000.01.01 00:00:05", "2000.02.28 23:00:05", "2000.02.29 23:00:05", "2000.03.01 00:00:05", "2007.06.05 17:55:35", "2038.01.19 03:14:07", 0 }; int i, ok = 1; struct tm orig, *conv; time_t t; for (i = 0; (test_dates[i]); i++) { parse_time(test_dates[i], &orig); t = Httimegm(&orig); conv = gmtime(&t); if (!time_equal(&orig, conv)) { fprintf(stderr, "timegm() test failed!\n Original: "); print_time(&orig); fprintf(stderr, "\n Converted: "); print_time(conv); fprintf(stderr, "\n time_t: %ld\n", (long) t); ok = 0; } } exit(ok ? 0 : 1); } #endif