ctime(3)



NAME

     ctime, localtime, gmtime, asctime, tzset -   convert  date  and  time  to
     ASCII


SYNOPSIS

     #include <sys/types.h>
     #include <time.h>

     void tzset(void)
     char *ctime(const time_t *clock)
     char *asctime(const struct tm *tm)
     struct tm *localtime(const time_t *clock)
     struct tm *gmtime(const time_t *clock)


DESCRIPTION

     Tzset uses the value of the environment variable TZ to set  up  the  time
     conversion information used by localtime.

     If TZ does not appear in the environment, the TZDEFAULT file (as  defined
     in  <tzfile.h>) is used by localtime.  If this file fails for any reason,
     the GMT offset as provided by the kernel is used.  In this case,  DST  is
     ignored,  resulting  in the time being incorrect by some amount if DST is
     currently in effect.  If this fails for any reason, GMT is used.

     If TZ appears in  the  environment  but  its  value  is  a  null  string,
     Greenwich Mean Time is used; if TZ appears and begins with a slash, it is
     used as the absolute pathname of the tzfile(5)-format file from which  to
     read  the  time  conversion  information; if TZ appears and begins with a
     character other than a slash, it's used as a  pathname  relative  to  the
     system  time  conversion  information  directory, defined as TZDIR in the
     include file tzfile.h.  If this file fails for any reason, the GMT offset
     as provided by the kernel is used, as described above.  If this fails for
     any reason, GMT is used.  See TZ(5) for a proper description  of  the  TZ
     variable.

     Ctime converts a time value, pointed to by clock,  such  as  returned  by
     time(2)  into ASCII and returns a pointer to a 26-character string in the
     following form.  All the fields have constant width.

          Sun Sep 16 01:03:52 1973\n\0

     Localtime and gmtime return pointers to structures containing the broken-
     down  time.   Localtime  corrects for the time zone and possible daylight
     savings time; gmtime converts directly to GMT, which  is  the  time  UNIX
     uses.  Asctime converts a broken-down time to ASCII and returns a pointer
     to a 26-character string.

     The structure declaration from the include file is:


          struct tm {
                int tm_sec;    /* 0-59  seconds */
                int tm_min;    /* 0-59  minutes */
                int tm_hour;   /* 0-23  hour */
                int tm_mday;   /* 1-31  day of month */
                int tm_mon;    /* 0-11  month */
                int tm_year;   /* 0-    year - 1900 */
                int tm_wday;   /* 0-6   day of week (Sunday = 0) */
                int tm_yday;   /* 0-365 day of year */
                int tm_isdst;  /* flag: daylight savings time in effect */
                long tm_gmtoff; /* offset from GMT in seconds */
                char **tm_zone; /* abbreviation of timezone name */
          };

     Tm_isdst is non-zero if a time zone adjustment such as  Daylight  Savings
     time is in effect.

     Tm_gmtoff is the offset (in seconds) of the time  represented  from  GMT,
     with positive values indicating East of Greenwich.


FILES

     /usr/lib/zoneinfo    time zone information directory
     /etc/localtime       local time zone file


SEE ALSO

     time(2), getenv(3), tzfile(5), TZ(5), environ(7), zic(8).


NOTE

     The return values point to static data whose content  is  overwritten  by
     each  call.  The tm_zone field of a returned struct tm points to a static
     array of characters, which will also be overwritten at the next call (and
     by calls to tzset).