/* systime.h - System-dependent definitions for time manipulations. Copyright (C) 1993-1994, 2002-2014 Free Software Foundation, Inc. This file is part of GNU Emacs. GNU Emacs is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. GNU Emacs 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 General Public License for more details. You should have received a copy of the GNU General Public License along with GNU Emacs. If not, see . */ #ifndef EMACS_SYSTIME_H #define EMACS_SYSTIME_H #include INLINE_HEADER_BEGIN #ifdef emacs # ifdef HAVE_X_WINDOWS # include # else typedef unsigned long Time; # endif #endif /* On some configurations (hpux8.0, X11R4), sys/time.h and X11/Xos.h disagree about the name of the guard symbol. */ #ifdef HPUX #ifdef _STRUCT_TIMEVAL #ifndef __TIMEVAL__ #define __TIMEVAL__ #endif #endif #endif #include /* for 'struct timeval' */ /* Emacs uses struct timespec to represent nonnegative temporal intervals. WARNING: Since tv_sec might be an unsigned value, do not use struct timespec as a general-purpose data type for adding or subtracting arbitrary time values! When computing A + B or A - B, typically A should be an absolute time since the epoch and B a nonnegative offset. */ /* Return an invalid timespec. */ INLINE struct timespec invalid_timespec (void) { return make_timespec (0, -1); } /* Return true if TIME is a valid timespec. This currently doesn't worry about whether tv_nsec is less than TIMESPEC_RESOLUTION; leap seconds might cause a problem if it did. */ INLINE bool timespec_valid_p (struct timespec t) { return t.tv_nsec >= 0; } /* Return current system time. */ INLINE struct timespec current_timespec (void) { struct timespec r; gettime (&r); return r; } /* defined in sysdep.c */ extern int set_file_times (int, const char *, struct timespec, struct timespec); extern struct timeval make_timeval (struct timespec) ATTRIBUTE_CONST; /* defined in keyboard.c */ extern void set_waiting_for_input (struct timespec *); /* When lisp.h is not included Lisp_Object is not defined (this can happen when this files is used outside the src directory). Use GCPRO1 to determine if lisp.h was included. */ #ifdef GCPRO1 /* Emacs uses the integer list (HI LO US PS) to represent the time (HI << LO_TIME_BITS) + LO + US / 1e6 + PS / 1e12. */ enum { LO_TIME_BITS = 16 }; /* A Lisp time (HI LO US PS), sans the cons cells. */ struct lisp_time { EMACS_INT hi; int lo, us, ps; }; /* defined in editfns.c */ extern Lisp_Object make_lisp_time (struct timespec); extern bool decode_time_components (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, struct lisp_time *, double *); extern struct timespec lisp_to_timespec (struct lisp_time); extern struct timespec lisp_time_argument (Lisp_Object); #endif #ifndef HAVE_TZALLOC # undef mktime_z # undef timezone_t # undef tzalloc # undef tzfree # define mktime_z emacs_mktime_z # define timezone_t emacs_timezone_t # define tzalloc emacs_tzalloc # define tzfree emacs_tzfree typedef char const *timezone_t; INLINE timezone_t tzalloc (char const *name) { return name; } INLINE void tzfree (timezone_t tz) { } /* Defined in editfns.c. */ extern time_t mktime_z (timezone_t, struct tm *); #endif INLINE_HEADER_END #endif /* EMACS_SYSTIME_H */