| 
									
										
										
										
											2010-12-03 20:14:31 +00:00
										 |  |  | #ifndef Py_LIMITED_API
 | 
					
						
							| 
									
										
										
										
											2010-08-05 17:34:27 +00:00
										 |  |  | #ifndef Py_PYTIME_H
 | 
					
						
							|  |  |  | #define Py_PYTIME_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-08 23:03:19 +01:00
										 |  |  | #include "pyconfig.h" /* include for defines */
 | 
					
						
							| 
									
										
										
										
											2012-03-02 22:54:03 +01:00
										 |  |  | #include "object.h"
 | 
					
						
							| 
									
										
										
										
											2010-08-05 17:34:27 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**************************************************************************
 | 
					
						
							|  |  |  | Symbols and macros to supply platform-independent interfaces to time related | 
					
						
							|  |  |  | functions and constants | 
					
						
							|  |  |  | **************************************************************************/ | 
					
						
							|  |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef HAVE_GETTIMEOFDAY
 | 
					
						
							|  |  |  | typedef struct timeval _PyTime_timeval; | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | typedef struct { | 
					
						
							|  |  |  |     time_t       tv_sec;   /* seconds since Jan. 1, 1970 */ | 
					
						
							|  |  |  |     long         tv_usec;  /* and microseconds */ | 
					
						
							|  |  |  | } _PyTime_timeval; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-29 02:41:27 +02:00
										 |  |  | /* Structure used by time.get_clock_info() */ | 
					
						
							|  |  |  | typedef struct { | 
					
						
							|  |  |  |     const char *implementation; | 
					
						
							| 
									
										
										
										
											2012-05-01 09:38:34 -04:00
										 |  |  |     int monotonic; | 
					
						
							| 
									
										
										
										
											2012-06-12 22:46:37 +02:00
										 |  |  |     int adjustable; | 
					
						
							| 
									
										
										
										
											2012-04-29 02:41:27 +02:00
										 |  |  |     double resolution; | 
					
						
							|  |  |  | } _Py_clock_info_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-05 17:34:27 +00:00
										 |  |  | /* Similar to POSIX gettimeofday but cannot fail.  If system gettimeofday
 | 
					
						
							|  |  |  |  * fails or is not available, fall back to lower resolution clocks. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | PyAPI_FUNC(void) _PyTime_gettimeofday(_PyTime_timeval *tp); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-29 02:41:27 +02:00
										 |  |  | /* Similar to _PyTime_gettimeofday() but retrieve also information on the
 | 
					
						
							|  |  |  |  * clock used to get the current time. */ | 
					
						
							| 
									
										
										
										
											2014-08-29 16:31:59 +02:00
										 |  |  | PyAPI_FUNC(int) _PyTime_gettimeofday_info( | 
					
						
							| 
									
										
										
										
											2012-04-29 02:41:27 +02:00
										 |  |  |     _PyTime_timeval *tp, | 
					
						
							|  |  |  |     _Py_clock_info_t *info); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-28 21:23:11 +00:00
										 |  |  | #define _PyTime_ADD_SECONDS(tv, interval) \
 | 
					
						
							|  |  |  | do { \ | 
					
						
							|  |  |  |     tv.tv_usec += (long) (((long) interval - interval) * 1000000); \ | 
					
						
							|  |  |  |     tv.tv_sec += (time_t) interval + (time_t) (tv.tv_usec / 1000000); \ | 
					
						
							|  |  |  |     tv.tv_usec %= 1000000; \ | 
					
						
							|  |  |  | } while (0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define _PyTime_INTERVAL(tv_start, tv_end) \
 | 
					
						
							|  |  |  |     ((tv_end.tv_sec - tv_start.tv_sec) + \ | 
					
						
							|  |  |  |      (tv_end.tv_usec - tv_start.tv_usec) * 0.000001) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-17 00:02:43 +01:00
										 |  |  | typedef enum { | 
					
						
							|  |  |  |     /* Round towards zero. */ | 
					
						
							|  |  |  |     _PyTime_ROUND_DOWN=0, | 
					
						
							|  |  |  |     /* Round away from zero. */ | 
					
						
							|  |  |  |     _PyTime_ROUND_UP | 
					
						
							|  |  |  | } _PyTime_round_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-13 13:35:55 +01:00
										 |  |  | /* Convert a number of seconds, int or float, to time_t. */ | 
					
						
							|  |  |  | PyAPI_FUNC(int) _PyTime_ObjectToTime_t( | 
					
						
							|  |  |  |     PyObject *obj, | 
					
						
							| 
									
										
										
										
											2014-02-17 00:02:43 +01:00
										 |  |  |     time_t *sec, | 
					
						
							|  |  |  |     _PyTime_round_t); | 
					
						
							| 
									
										
										
										
											2012-03-13 13:35:55 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-19 15:07:49 -07:00
										 |  |  | /* Convert a time_t to a PyLong. */ | 
					
						
							|  |  |  | PyAPI_FUNC(PyObject *) _PyLong_FromTime_t( | 
					
						
							|  |  |  |     time_t sec); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-03 00:30:07 -07:00
										 |  |  | /* Convert a PyLong to a time_t. */ | 
					
						
							|  |  |  | PyAPI_FUNC(time_t) _PyLong_AsTime_t( | 
					
						
							|  |  |  |     PyObject *obj); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-13 13:35:55 +01:00
										 |  |  | /* Convert a number of seconds, int or float, to a timeval structure.
 | 
					
						
							|  |  |  |    usec is in the range [0; 999999] and rounded towards zero. | 
					
						
							|  |  |  |    For example, -1.2 is converted to (-2, 800000). */ | 
					
						
							|  |  |  | PyAPI_FUNC(int) _PyTime_ObjectToTimeval( | 
					
						
							|  |  |  |     PyObject *obj, | 
					
						
							|  |  |  |     time_t *sec, | 
					
						
							| 
									
										
										
										
											2014-02-17 00:02:43 +01:00
										 |  |  |     long *usec, | 
					
						
							|  |  |  |     _PyTime_round_t); | 
					
						
							| 
									
										
										
										
											2012-03-13 13:35:55 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-02 22:54:03 +01:00
										 |  |  | /* Convert a number of seconds, int or float, to a timespec structure.
 | 
					
						
							| 
									
										
										
										
											2012-03-13 13:35:55 +01:00
										 |  |  |    nsec is in the range [0; 999999999] and rounded towards zero. | 
					
						
							|  |  |  |    For example, -1.2 is converted to (-2, 800000000). */ | 
					
						
							| 
									
										
										
										
											2012-03-02 22:54:03 +01:00
										 |  |  | PyAPI_FUNC(int) _PyTime_ObjectToTimespec( | 
					
						
							|  |  |  |     PyObject *obj, | 
					
						
							|  |  |  |     time_t *sec, | 
					
						
							| 
									
										
										
										
											2014-02-17 00:02:43 +01:00
										 |  |  |     long *nsec, | 
					
						
							|  |  |  |     _PyTime_round_t); | 
					
						
							| 
									
										
										
										
											2012-03-02 22:54:03 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-02 23:18:25 +02:00
										 |  |  | /* Get the time of a monotonic clock, i.e. a clock that cannot go backwards.
 | 
					
						
							|  |  |  |    The clock is not affected by system clock updates. The reference point of | 
					
						
							|  |  |  |    the returned value is undefined, so that only the difference between the | 
					
						
							|  |  |  |    results of consecutive calls is valid. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The function never fails. _PyTime_Init() ensures that a monotonic clock | 
					
						
							|  |  |  |    is available and works. */ | 
					
						
							|  |  |  | PyAPI_FUNC(void) _PyTime_monotonic( | 
					
						
							|  |  |  |     _PyTime_timeval *tp); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Similar to _PyTime_monotonic(), fill also info (if set) with information of
 | 
					
						
							|  |  |  |    the function used to get the time. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Return 0 on success, raise an exception and return -1 on error. */ | 
					
						
							|  |  |  | PyAPI_FUNC(int) _PyTime_monotonic_info( | 
					
						
							|  |  |  |     _PyTime_timeval *tp, | 
					
						
							|  |  |  |     _Py_clock_info_t *info); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-29 16:31:59 +02:00
										 |  |  | /* Initialize time.
 | 
					
						
							|  |  |  |    Return 0 on success, raise an exception and return -1 on error. */ | 
					
						
							|  |  |  | PyAPI_FUNC(int) _PyTime_Init(void); | 
					
						
							| 
									
										
										
										
											2010-08-05 17:34:27 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* Py_PYTIME_H */
 | 
					
						
							| 
									
										
										
										
											2010-12-03 20:14:31 +00:00
										 |  |  | #endif /* Py_LIMITED_API */
 |