Blame timezone/private.h

Packit 6c4009
#ifndef PRIVATE_H
Packit 6c4009
Packit 6c4009
#define PRIVATE_H
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** This file is in the public domain, so clarified as of
Packit 6c4009
** 1996-06-05 by Arthur David Olson.
Packit 6c4009
*/
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** This header is for use ONLY with the time conversion code.
Packit 6c4009
** There is no guarantee that it will remain unchanged,
Packit 6c4009
** or that it will remain at all.
Packit 6c4009
** Do NOT copy it to any system include directory.
Packit 6c4009
** Thank you!
Packit 6c4009
*/
Packit 6c4009
Packit 6c4009
/* This string was in the Factory zone through version 2016f.  */
Packit 6c4009
#define GRANDPARENTED	"Local time zone must be set--see zic manual page"
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** Defaults for preprocessor symbols.
Packit 6c4009
** You can override these in your C compiler options, e.g. '-DHAVE_GETTEXT=1'.
Packit 6c4009
*/
Packit 6c4009
Packit 6c4009
#ifndef HAVE_DECL_ASCTIME_R
Packit 6c4009
#define HAVE_DECL_ASCTIME_R 1
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef HAVE_GETTEXT
Packit 6c4009
#define HAVE_GETTEXT		0
Packit 6c4009
#endif /* !defined HAVE_GETTEXT */
Packit 6c4009
Packit 6c4009
#ifndef HAVE_INCOMPATIBLE_CTIME_R
Packit 6c4009
#define HAVE_INCOMPATIBLE_CTIME_R	0
Packit 6c4009
#endif /* !defined INCOMPATIBLE_CTIME_R */
Packit 6c4009
Packit 6c4009
#ifndef HAVE_LINK
Packit 6c4009
#define HAVE_LINK		1
Packit 6c4009
#endif /* !defined HAVE_LINK */
Packit 6c4009
Packit 6c4009
#ifndef HAVE_POSIX_DECLS
Packit 6c4009
#define HAVE_POSIX_DECLS 1
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef HAVE_STRDUP
Packit 6c4009
#define HAVE_STRDUP 1
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef HAVE_SYMLINK
Packit 6c4009
#define HAVE_SYMLINK		1
Packit 6c4009
#endif /* !defined HAVE_SYMLINK */
Packit 6c4009
Packit 6c4009
#ifndef HAVE_SYS_STAT_H
Packit 6c4009
#define HAVE_SYS_STAT_H		1
Packit 6c4009
#endif /* !defined HAVE_SYS_STAT_H */
Packit 6c4009
Packit 6c4009
#ifndef HAVE_SYS_WAIT_H
Packit 6c4009
#define HAVE_SYS_WAIT_H		1
Packit 6c4009
#endif /* !defined HAVE_SYS_WAIT_H */
Packit 6c4009
Packit 6c4009
#ifndef HAVE_UNISTD_H
Packit 6c4009
#define HAVE_UNISTD_H		1
Packit 6c4009
#endif /* !defined HAVE_UNISTD_H */
Packit 6c4009
Packit 6c4009
#ifndef HAVE_UTMPX_H
Packit 6c4009
#define HAVE_UTMPX_H		1
Packit 6c4009
#endif /* !defined HAVE_UTMPX_H */
Packit 6c4009
Packit 6c4009
#ifndef NETBSD_INSPIRED
Packit 6c4009
# define NETBSD_INSPIRED 1
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#if HAVE_INCOMPATIBLE_CTIME_R
Packit 6c4009
#define asctime_r _incompatible_asctime_r
Packit 6c4009
#define ctime_r _incompatible_ctime_r
Packit 6c4009
#endif /* HAVE_INCOMPATIBLE_CTIME_R */
Packit 6c4009
Packit 6c4009
/* Enable tm_gmtoff and tm_zone on GNUish systems.  */
Packit 6c4009
#define _GNU_SOURCE 1
Packit 6c4009
/* Fix asctime_r on Solaris 11.  */
Packit 6c4009
#define _POSIX_PTHREAD_SEMANTICS 1
Packit 6c4009
/* Enable strtoimax on pre-C99 Solaris 11.  */
Packit 6c4009
#define __EXTENSIONS__ 1
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** Nested includes
Packit 6c4009
*/
Packit 6c4009
Packit 6c4009
/* Avoid clashes with NetBSD by renaming NetBSD's declarations.  */
Packit 6c4009
#define localtime_rz sys_localtime_rz
Packit 6c4009
#define mktime_z sys_mktime_z
Packit 6c4009
#define posix2time_z sys_posix2time_z
Packit 6c4009
#define time2posix_z sys_time2posix_z
Packit 6c4009
#define timezone_t sys_timezone_t
Packit 6c4009
#define tzalloc sys_tzalloc
Packit 6c4009
#define tzfree sys_tzfree
Packit 6c4009
#include <time.h>
Packit 6c4009
#undef localtime_rz
Packit 6c4009
#undef mktime_z
Packit 6c4009
#undef posix2time_z
Packit 6c4009
#undef time2posix_z
Packit 6c4009
#undef timezone_t
Packit 6c4009
#undef tzalloc
Packit 6c4009
#undef tzfree
Packit 6c4009
Packit 6c4009
#include <sys/types.h>	/* for time_t */
Packit 6c4009
#include <stdio.h>
Packit 6c4009
#include <string.h>
Packit 6c4009
#include <limits.h>	/* for CHAR_BIT et al. */
Packit 6c4009
#include <stdlib.h>
Packit 6c4009
Packit 6c4009
#include <errno.h>
Packit 6c4009
Packit 6c4009
#ifndef ENAMETOOLONG
Packit 6c4009
# define ENAMETOOLONG EINVAL
Packit 6c4009
#endif
Packit 6c4009
#ifndef ENOTSUP
Packit 6c4009
# define ENOTSUP EINVAL
Packit 6c4009
#endif
Packit 6c4009
#ifndef EOVERFLOW
Packit 6c4009
# define EOVERFLOW EINVAL
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#if HAVE_GETTEXT
Packit 6c4009
#include <libintl.h>
Packit 6c4009
#endif /* HAVE_GETTEXT */
Packit 6c4009
Packit 6c4009
#if HAVE_SYS_WAIT_H
Packit 6c4009
#include <sys/wait.h>	/* for WIFEXITED and WEXITSTATUS */
Packit 6c4009
#endif /* HAVE_SYS_WAIT_H */
Packit 6c4009
Packit 6c4009
#ifndef WIFEXITED
Packit 6c4009
#define WIFEXITED(status)	(((status) & 0xff) == 0)
Packit 6c4009
#endif /* !defined WIFEXITED */
Packit 6c4009
#ifndef WEXITSTATUS
Packit 6c4009
#define WEXITSTATUS(status)	(((status) >> 8) & 0xff)
Packit 6c4009
#endif /* !defined WEXITSTATUS */
Packit 6c4009
Packit 6c4009
#if HAVE_UNISTD_H
Packit 6c4009
#include <unistd.h>	/* for F_OK, R_OK, and other POSIX goodness */
Packit 6c4009
#endif /* HAVE_UNISTD_H */
Packit 6c4009
Packit 6c4009
#ifndef HAVE_STRFTIME_L
Packit 6c4009
# if _POSIX_VERSION < 200809
Packit 6c4009
#  define HAVE_STRFTIME_L 0
Packit 6c4009
# else
Packit 6c4009
#  define HAVE_STRFTIME_L 1
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef F_OK
Packit 6c4009
#define F_OK	0
Packit 6c4009
#endif /* !defined F_OK */
Packit 6c4009
#ifndef R_OK
Packit 6c4009
#define R_OK	4
Packit 6c4009
#endif /* !defined R_OK */
Packit 6c4009
Packit 6c4009
/* Unlike <ctype.h>'s isdigit, this also works if c < 0 | c > UCHAR_MAX. */
Packit 6c4009
#define is_digit(c) ((unsigned)(c) - '0' <= 9)
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** Define HAVE_STDINT_H's default value here, rather than at the
Packit 6c4009
** start, since __GLIBC__ and INTMAX_MAX's values depend on
Packit 6c4009
** previously-included files.  glibc 2.1 and Solaris 10 and later have
Packit 6c4009
** stdint.h, even with pre-C99 compilers.
Packit 6c4009
*/
Packit 6c4009
#ifndef HAVE_STDINT_H
Packit 6c4009
#define HAVE_STDINT_H \
Packit 6c4009
   (199901 <= __STDC_VERSION__ \
Packit 6c4009
    || 2 < __GLIBC__ + (1 <= __GLIBC_MINOR__)	\
Packit 6c4009
    || __CYGWIN__ || INTMAX_MAX)
Packit 6c4009
#endif /* !defined HAVE_STDINT_H */
Packit 6c4009
Packit 6c4009
#if HAVE_STDINT_H
Packit 6c4009
#include <stdint.h>
Packit 6c4009
#endif /* !HAVE_STDINT_H */
Packit 6c4009
Packit 6c4009
#ifndef HAVE_INTTYPES_H
Packit 6c4009
# define HAVE_INTTYPES_H HAVE_STDINT_H
Packit 6c4009
#endif
Packit 6c4009
#if HAVE_INTTYPES_H
Packit 6c4009
# include <inttypes.h>
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
/* Pre-C99 GCC compilers define __LONG_LONG_MAX__ instead of LLONG_MAX.  */
Packit 6c4009
#ifdef __LONG_LONG_MAX__
Packit 6c4009
# ifndef LLONG_MAX
Packit 6c4009
#  define LLONG_MAX __LONG_LONG_MAX__
Packit 6c4009
# endif
Packit 6c4009
# ifndef LLONG_MIN
Packit 6c4009
#  define LLONG_MIN (-1 - LLONG_MAX)
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef INT_FAST64_MAX
Packit 6c4009
# ifdef LLONG_MAX
Packit 6c4009
typedef long long	int_fast64_t;
Packit 6c4009
#  define INT_FAST64_MIN LLONG_MIN
Packit 6c4009
#  define INT_FAST64_MAX LLONG_MAX
Packit 6c4009
# else
Packit 6c4009
#  if LONG_MAX >> 31 < 0xffffffff
Packit 6c4009
Please use a compiler that supports a 64-bit integer type (or wider);
Packit 6c4009
you may need to compile with "-DHAVE_STDINT_H".
Packit 6c4009
#  endif
Packit 6c4009
typedef long		int_fast64_t;
Packit 6c4009
#  define INT_FAST64_MIN LONG_MIN
Packit 6c4009
#  define INT_FAST64_MAX LONG_MAX
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef PRIdFAST64
Packit 6c4009
# if INT_FAST64_MAX == LLONG_MAX
Packit 6c4009
#  define PRIdFAST64 "lld"
Packit 6c4009
# else
Packit 6c4009
#  define PRIdFAST64 "ld"
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef SCNdFAST64
Packit 6c4009
# define SCNdFAST64 PRIdFAST64
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef INT_FAST32_MAX
Packit 6c4009
# if INT_MAX >> 31 == 0
Packit 6c4009
typedef long int_fast32_t;
Packit 6c4009
#  define INT_FAST32_MAX LONG_MAX
Packit 6c4009
#  define INT_FAST32_MIN LONG_MIN
Packit 6c4009
# else
Packit 6c4009
typedef int int_fast32_t;
Packit 6c4009
#  define INT_FAST32_MAX INT_MAX
Packit 6c4009
#  define INT_FAST32_MIN INT_MIN
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef INTMAX_MAX
Packit 6c4009
# ifdef LLONG_MAX
Packit 6c4009
typedef long long intmax_t;
Packit 6c4009
#  define strtoimax strtoll
Packit 6c4009
#  define INTMAX_MAX LLONG_MAX
Packit 6c4009
#  define INTMAX_MIN LLONG_MIN
Packit 6c4009
# else
Packit 6c4009
typedef long intmax_t;
Packit 6c4009
#  define strtoimax strtol
Packit 6c4009
#  define INTMAX_MAX LONG_MAX
Packit 6c4009
#  define INTMAX_MIN LONG_MIN
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef PRIdMAX
Packit 6c4009
# if INTMAX_MAX == LLONG_MAX
Packit 6c4009
#  define PRIdMAX "lld"
Packit 6c4009
# else
Packit 6c4009
#  define PRIdMAX "ld"
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef UINT_FAST64_MAX
Packit 6c4009
# if defined ULLONG_MAX || defined __LONG_LONG_MAX__
Packit 6c4009
typedef unsigned long long uint_fast64_t;
Packit 6c4009
# else
Packit 6c4009
#  if ULONG_MAX >> 31 >> 1 < 0xffffffff
Packit 6c4009
Please use a compiler that supports a 64-bit integer type (or wider);
Packit 6c4009
you may need to compile with "-DHAVE_STDINT_H".
Packit 6c4009
#  endif
Packit 6c4009
typedef unsigned long	uint_fast64_t;
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef UINTMAX_MAX
Packit 6c4009
# if defined ULLONG_MAX || defined __LONG_LONG_MAX__
Packit 6c4009
typedef unsigned long long uintmax_t;
Packit 6c4009
# else
Packit 6c4009
typedef unsigned long uintmax_t;
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef PRIuMAX
Packit 6c4009
# if defined ULLONG_MAX || defined __LONG_LONG_MAX__
Packit 6c4009
#  define PRIuMAX "llu"
Packit 6c4009
# else
Packit 6c4009
#  define PRIuMAX "lu"
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef INT32_MAX
Packit 6c4009
#define INT32_MAX 0x7fffffff
Packit 6c4009
#endif /* !defined INT32_MAX */
Packit 6c4009
#ifndef INT32_MIN
Packit 6c4009
#define INT32_MIN (-1 - INT32_MAX)
Packit 6c4009
#endif /* !defined INT32_MIN */
Packit 6c4009
Packit 6c4009
#ifndef SIZE_MAX
Packit 6c4009
#define SIZE_MAX ((size_t) -1)
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#if 2 < __GNUC__ + (96 <= __GNUC_MINOR__)
Packit 6c4009
# define ATTRIBUTE_CONST __attribute__ ((const))
Packit 6c4009
# define ATTRIBUTE_PURE __attribute__ ((__pure__))
Packit 6c4009
# define ATTRIBUTE_FORMAT(spec) __attribute__ ((__format__ spec))
Packit 6c4009
#else
Packit 6c4009
# define ATTRIBUTE_CONST /* empty */
Packit 6c4009
# define ATTRIBUTE_PURE /* empty */
Packit 6c4009
# define ATTRIBUTE_FORMAT(spec) /* empty */
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#if !defined _Noreturn && __STDC_VERSION__ < 201112
Packit 6c4009
# if 2 < __GNUC__ + (8 <= __GNUC_MINOR__)
Packit 6c4009
#  define _Noreturn __attribute__ ((__noreturn__))
Packit 6c4009
# else
Packit 6c4009
#  define _Noreturn
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#if __STDC_VERSION__ < 199901 && !defined restrict
Packit 6c4009
# define restrict /* empty */
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** Workarounds for compilers/systems.
Packit 6c4009
*/
Packit 6c4009
Packit 6c4009
#ifndef EPOCH_LOCAL
Packit 6c4009
# define EPOCH_LOCAL 0
Packit 6c4009
#endif
Packit 6c4009
#ifndef EPOCH_OFFSET
Packit 6c4009
# define EPOCH_OFFSET 0
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** Compile with -Dtime_tz=T to build the tz package with a private
Packit 6c4009
** time_t type equivalent to T rather than the system-supplied time_t.
Packit 6c4009
** This debugging feature can test unusual design decisions
Packit 6c4009
** (e.g., time_t wider than 'long', or unsigned time_t) even on
Packit 6c4009
** typical platforms.
Packit 6c4009
*/
Packit 6c4009
#if defined time_tz || EPOCH_LOCAL || EPOCH_OFFSET != 0
Packit 6c4009
# ifdef LOCALTIME_IMPLEMENTATION
Packit 6c4009
static time_t sys_time(time_t *x) { return time(x); }
Packit 6c4009
# endif
Packit 6c4009
Packit 6c4009
typedef time_tz tz_time_t;
Packit 6c4009
Packit 6c4009
# undef  ctime
Packit 6c4009
# define ctime tz_ctime
Packit 6c4009
# undef  ctime_r
Packit 6c4009
# define ctime_r tz_ctime_r
Packit 6c4009
# undef  difftime
Packit 6c4009
# define difftime tz_difftime
Packit 6c4009
# undef  gmtime
Packit 6c4009
# define gmtime tz_gmtime
Packit 6c4009
# undef  gmtime_r
Packit 6c4009
# define gmtime_r tz_gmtime_r
Packit 6c4009
# undef  localtime
Packit 6c4009
# define localtime tz_localtime
Packit 6c4009
# undef  localtime_r
Packit 6c4009
# define localtime_r tz_localtime_r
Packit 6c4009
# undef  localtime_rz
Packit 6c4009
# define localtime_rz tz_localtime_rz
Packit 6c4009
# undef  mktime
Packit 6c4009
# define mktime tz_mktime
Packit 6c4009
# undef  mktime_z
Packit 6c4009
# define mktime_z tz_mktime_z
Packit 6c4009
# undef  offtime
Packit 6c4009
# define offtime tz_offtime
Packit 6c4009
# undef  posix2time
Packit 6c4009
# define posix2time tz_posix2time
Packit 6c4009
# undef  posix2time_z
Packit 6c4009
# define posix2time_z tz_posix2time_z
Packit 6c4009
# undef  time
Packit 6c4009
# define time tz_time
Packit 6c4009
# undef  time2posix
Packit 6c4009
# define time2posix tz_time2posix
Packit 6c4009
# undef  time2posix_z
Packit 6c4009
# define time2posix_z tz_time2posix_z
Packit 6c4009
# undef  time_t
Packit 6c4009
# define time_t tz_time_t
Packit 6c4009
# undef  timegm
Packit 6c4009
# define timegm tz_timegm
Packit 6c4009
# undef  timelocal
Packit 6c4009
# define timelocal tz_timelocal
Packit 6c4009
# undef  timeoff
Packit 6c4009
# define timeoff tz_timeoff
Packit 6c4009
# undef  tzalloc
Packit 6c4009
# define tzalloc tz_tzalloc
Packit 6c4009
# undef  tzfree
Packit 6c4009
# define tzfree tz_tzfree
Packit 6c4009
# undef  tzset
Packit 6c4009
# define tzset tz_tzset
Packit 6c4009
# undef  tzsetwall
Packit 6c4009
# define tzsetwall tz_tzsetwall
Packit 6c4009
Packit 6c4009
char *ctime(time_t const *);
Packit 6c4009
char *ctime_r(time_t const *, char *);
Packit 6c4009
double difftime(time_t, time_t);
Packit 6c4009
struct tm *gmtime(time_t const *);
Packit 6c4009
struct tm *gmtime_r(time_t const *restrict, struct tm *restrict);
Packit 6c4009
struct tm *localtime(time_t const *);
Packit 6c4009
struct tm *localtime_r(time_t const *restrict, struct tm *restrict);
Packit 6c4009
time_t mktime(struct tm *);
Packit 6c4009
time_t time(time_t *);
Packit 6c4009
void tzset(void);
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#if !HAVE_DECL_ASCTIME_R && !defined asctime_r
Packit 6c4009
extern char *asctime_r(struct tm const *restrict, char *restrict);
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#if !HAVE_POSIX_DECLS
Packit 6c4009
# ifdef USG_COMPAT
Packit 6c4009
#  ifndef timezone
Packit 6c4009
extern long timezone;
Packit 6c4009
#  endif
Packit 6c4009
#  ifndef daylight
Packit 6c4009
extern int daylight;
Packit 6c4009
#  endif
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#if defined ALTZONE && !defined altzone
Packit 6c4009
extern long altzone;
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** The STD_INSPIRED functions are similar, but most also need
Packit 6c4009
** declarations if time_tz is defined.
Packit 6c4009
*/
Packit 6c4009
Packit 6c4009
#ifdef STD_INSPIRED
Packit 6c4009
# if !defined tzsetwall || defined time_tz
Packit 6c4009
void tzsetwall(void);
Packit 6c4009
# endif
Packit 6c4009
# if !defined offtime || defined time_tz
Packit 6c4009
struct tm *offtime(time_t const *, long);
Packit 6c4009
# endif
Packit 6c4009
# if !defined timegm || defined time_tz
Packit 6c4009
time_t timegm(struct tm *);
Packit 6c4009
# endif
Packit 6c4009
# if !defined timelocal || defined time_tz
Packit 6c4009
time_t timelocal(struct tm *);
Packit 6c4009
# endif
Packit 6c4009
# if !defined timeoff || defined time_tz
Packit 6c4009
time_t timeoff(struct tm *, long);
Packit 6c4009
# endif
Packit 6c4009
# if !defined time2posix || defined time_tz
Packit 6c4009
time_t time2posix(time_t);
Packit 6c4009
# endif
Packit 6c4009
# if !defined posix2time || defined time_tz
Packit 6c4009
time_t posix2time(time_t);
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
/* Infer TM_ZONE on systems where this information is known, but suppress
Packit 6c4009
   guessing if NO_TM_ZONE is defined.  Similarly for TM_GMTOFF.  */
Packit 6c4009
#if (defined __GLIBC__ \
Packit 6c4009
     || defined __FreeBSD__ || defined __NetBSD__ || defined __OpenBSD__ \
Packit 6c4009
     || (defined __APPLE__ && defined __MACH__))
Packit 6c4009
# if !defined TM_GMTOFF && !defined NO_TM_GMTOFF
Packit 6c4009
#  define TM_GMTOFF tm_gmtoff
Packit 6c4009
# endif
Packit 6c4009
# if !defined TM_ZONE && !defined NO_TM_ZONE
Packit 6c4009
#  define TM_ZONE tm_zone
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** Define functions that are ABI compatible with NetBSD but have
Packit 6c4009
** better prototypes.  NetBSD 6.1.4 defines a pointer type timezone_t
Packit 6c4009
** and labors under the misconception that 'const timezone_t' is a
Packit 6c4009
** pointer to a constant.  This use of 'const' is ineffective, so it
Packit 6c4009
** is not done here.  What we call 'struct state' NetBSD calls
Packit 6c4009
** 'struct __state', but this is a private name so it doesn't matter.
Packit 6c4009
*/
Packit 6c4009
#if NETBSD_INSPIRED
Packit 6c4009
typedef struct state *timezone_t;
Packit 6c4009
struct tm *localtime_rz(timezone_t restrict, time_t const *restrict,
Packit 6c4009
			struct tm *restrict);
Packit 6c4009
time_t mktime_z(timezone_t restrict, struct tm *restrict);
Packit 6c4009
timezone_t tzalloc(char const *);
Packit 6c4009
void tzfree(timezone_t);
Packit 6c4009
# ifdef STD_INSPIRED
Packit 6c4009
#  if !defined posix2time_z || defined time_tz
Packit 6c4009
time_t posix2time_z(timezone_t, time_t) ATTRIBUTE_PURE;
Packit 6c4009
#  endif
Packit 6c4009
#  if !defined time2posix_z || defined time_tz
Packit 6c4009
time_t time2posix_z(timezone_t, time_t) ATTRIBUTE_PURE;
Packit 6c4009
#  endif
Packit 6c4009
# endif
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** Finally, some convenience items.
Packit 6c4009
*/
Packit 6c4009
Packit 6c4009
#if __STDC_VERSION__ < 199901
Packit 6c4009
# define true 1
Packit 6c4009
# define false 0
Packit 6c4009
# define bool int
Packit 6c4009
#else
Packit 6c4009
# include <stdbool.h>
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#define TYPE_BIT(type)	(sizeof (type) * CHAR_BIT)
Packit 6c4009
#define TYPE_SIGNED(type) (((type) -1) < 0)
Packit 6c4009
#define TWOS_COMPLEMENT(t) ((t) ~ (t) 0 < 0)
Packit 6c4009
Packit 6c4009
/* Max and min values of the integer type T, of which only the bottom
Packit 6c4009
   B bits are used, and where the highest-order used bit is considered
Packit 6c4009
   to be a sign bit if T is signed.  */
Packit 6c4009
#define MAXVAL(t, b)						\
Packit 6c4009
  ((t) (((t) 1 << ((b) - 1 - TYPE_SIGNED(t)))			\
Packit 6c4009
	- 1 + ((t) 1 << ((b) - 1 - TYPE_SIGNED(t)))))
Packit 6c4009
#define MINVAL(t, b)						\
Packit 6c4009
  ((t) (TYPE_SIGNED(t) ? - TWOS_COMPLEMENT(t) - MAXVAL(t, b) : 0))
Packit 6c4009
Packit 6c4009
/* The minimum and maximum finite time values.  This implementation
Packit 6c4009
   assumes no padding if time_t is signed and either the compiler is
Packit 6c4009
   pre-C11 or time_t is not one of the standard signed integer types.  */
Packit 6c4009
#if 201112 <= __STDC_VERSION__
Packit 6c4009
static time_t const time_t_min
Packit 6c4009
  = (TYPE_SIGNED(time_t)
Packit 6c4009
     ? _Generic((time_t) 0,
Packit 6c4009
		signed char: SCHAR_MIN, short: SHRT_MIN,
Packit 6c4009
		int: INT_MIN, long: LONG_MIN, long long: LLONG_MIN,
Packit 6c4009
		default: MINVAL(time_t, TYPE_BIT(time_t)))
Packit 6c4009
     : 0);
Packit 6c4009
static time_t const time_t_max
Packit 6c4009
  = (TYPE_SIGNED(time_t)
Packit 6c4009
     ? _Generic((time_t) 0,
Packit 6c4009
		signed char: SCHAR_MAX, short: SHRT_MAX,
Packit 6c4009
		int: INT_MAX, long: LONG_MAX, long long: LLONG_MAX,
Packit 6c4009
		default: MAXVAL(time_t, TYPE_BIT(time_t)))
Packit 6c4009
     : -1);
Packit 6c4009
#else
Packit 6c4009
static time_t const time_t_min = MINVAL(time_t, TYPE_BIT(time_t));
Packit 6c4009
static time_t const time_t_max = MAXVAL(time_t, TYPE_BIT(time_t));
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** 302 / 1000 is log10(2.0) rounded up.
Packit 6c4009
** Subtract one for the sign bit if the type is signed;
Packit 6c4009
** add one for integer division truncation;
Packit 6c4009
** add one more for a minus sign if the type is signed.
Packit 6c4009
*/
Packit 6c4009
#define INT_STRLEN_MAXIMUM(type) \
Packit 6c4009
	((TYPE_BIT(type) - TYPE_SIGNED(type)) * 302 / 1000 + \
Packit 6c4009
	1 + TYPE_SIGNED(type))
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** INITIALIZE(x)
Packit 6c4009
*/
Packit 6c4009
Packit 6c4009
#ifdef lint
Packit 6c4009
# define INITIALIZE(x)	((x) = 0)
Packit 6c4009
#else
Packit 6c4009
# define INITIALIZE(x)
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifndef UNINIT_TRAP
Packit 6c4009
# define UNINIT_TRAP 0
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** For the benefit of GNU folk...
Packit 6c4009
** '_(MSGID)' uses the current locale's message library string for MSGID.
Packit 6c4009
** The default is to use gettext if available, and use MSGID otherwise.
Packit 6c4009
*/
Packit 6c4009
Packit 6c4009
#if HAVE_GETTEXT
Packit 6c4009
#define _(msgid) gettext(msgid)
Packit 6c4009
#else /* !HAVE_GETTEXT */
Packit 6c4009
#define _(msgid) msgid
Packit 6c4009
#endif /* !HAVE_GETTEXT */
Packit 6c4009
Packit 6c4009
#if !defined TZ_DOMAIN && defined HAVE_GETTEXT
Packit 6c4009
# define TZ_DOMAIN "tz"
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#if HAVE_INCOMPATIBLE_CTIME_R
Packit 6c4009
#undef asctime_r
Packit 6c4009
#undef ctime_r
Packit 6c4009
char *asctime_r(struct tm const *, char *);
Packit 6c4009
char *ctime_r(time_t const *, char *);
Packit 6c4009
#endif /* HAVE_INCOMPATIBLE_CTIME_R */
Packit 6c4009
Packit 6c4009
/* Handy macros that are independent of tzfile implementation.  */
Packit 6c4009
Packit 6c4009
#define YEARSPERREPEAT		400	/* years before a Gregorian repeat */
Packit 6c4009
Packit 6c4009
#define SECSPERMIN	60
Packit 6c4009
#define MINSPERHOUR	60
Packit 6c4009
#define HOURSPERDAY	24
Packit 6c4009
#define DAYSPERWEEK	7
Packit 6c4009
#define DAYSPERNYEAR	365
Packit 6c4009
#define DAYSPERLYEAR	366
Packit 6c4009
#define SECSPERHOUR	(SECSPERMIN * MINSPERHOUR)
Packit 6c4009
#define SECSPERDAY	((int_fast32_t) SECSPERHOUR * HOURSPERDAY)
Packit 6c4009
#define MONSPERYEAR	12
Packit 6c4009
Packit 6c4009
#define TM_SUNDAY	0
Packit 6c4009
#define TM_MONDAY	1
Packit 6c4009
#define TM_TUESDAY	2
Packit 6c4009
#define TM_WEDNESDAY	3
Packit 6c4009
#define TM_THURSDAY	4
Packit 6c4009
#define TM_FRIDAY	5
Packit 6c4009
#define TM_SATURDAY	6
Packit 6c4009
Packit 6c4009
#define TM_JANUARY	0
Packit 6c4009
#define TM_FEBRUARY	1
Packit 6c4009
#define TM_MARCH	2
Packit 6c4009
#define TM_APRIL	3
Packit 6c4009
#define TM_MAY		4
Packit 6c4009
#define TM_JUNE		5
Packit 6c4009
#define TM_JULY		6
Packit 6c4009
#define TM_AUGUST	7
Packit 6c4009
#define TM_SEPTEMBER	8
Packit 6c4009
#define TM_OCTOBER	9
Packit 6c4009
#define TM_NOVEMBER	10
Packit 6c4009
#define TM_DECEMBER	11
Packit 6c4009
Packit 6c4009
#define TM_YEAR_BASE	1900
Packit 6c4009
Packit 6c4009
#define EPOCH_YEAR	1970
Packit 6c4009
#define EPOCH_WDAY	TM_THURSDAY
Packit 6c4009
Packit 6c4009
#define isleap(y) (((y) % 4) == 0 && (((y) % 100) != 0 || ((y) % 400) == 0))
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** Since everything in isleap is modulo 400 (or a factor of 400), we know that
Packit 6c4009
**	isleap(y) == isleap(y % 400)
Packit 6c4009
** and so
Packit 6c4009
**	isleap(a + b) == isleap((a + b) % 400)
Packit 6c4009
** or
Packit 6c4009
**	isleap(a + b) == isleap(a % 400 + b % 400)
Packit 6c4009
** This is true even if % means modulo rather than Fortran remainder
Packit 6c4009
** (which is allowed by C89 but not C99).
Packit 6c4009
** We use this to avoid addition overflow problems.
Packit 6c4009
*/
Packit 6c4009
Packit 6c4009
#define isleap_sum(a, b)	isleap((a) % 400 + (b) % 400)
Packit 6c4009
Packit 6c4009
Packit 6c4009
/*
Packit 6c4009
** The Gregorian year averages 365.2425 days, which is 31556952 seconds.
Packit 6c4009
*/
Packit 6c4009
Packit 6c4009
#define AVGSECSPERYEAR		31556952L
Packit 6c4009
#define SECSPERREPEAT \
Packit 6c4009
  ((int_fast64_t) YEARSPERREPEAT * (int_fast64_t) AVGSECSPERYEAR)
Packit 6c4009
#define SECSPERREPEAT_BITS	34	/* ceil(log2(SECSPERREPEAT)) */
Packit 6c4009
Packit 6c4009
#endif /* !defined PRIVATE_H */