diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2012-01-18 01:05:38 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2012-01-18 01:05:38 (GMT) |
commit | e39ebe45c4953ff506a1f7bd5c115b5c1b8e66d7 (patch) | |
tree | 2a4d9ae2bf1c22fb8787ba433f8f2bd2d5591718 /Modules/timemodule.c | |
parent | 2c085604b761e56ea6635ca6158356c9d46fea50 (diff) | |
parent | 855889b4bf4478cc359fb1354ab5bbb99a7829aa (diff) | |
download | cpython-e39ebe45c4953ff506a1f7bd5c115b5c1b8e66d7.zip cpython-e39ebe45c4953ff506a1f7bd5c115b5c1b8e66d7.tar.gz cpython-e39ebe45c4953ff506a1f7bd5c115b5c1b8e66d7.tar.bz2 |
Merge
Diffstat (limited to 'Modules/timemodule.c')
-rw-r--r-- | Modules/timemodule.c | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/Modules/timemodule.c b/Modules/timemodule.c index 46b8e9a..f7dac5b 100644 --- a/Modules/timemodule.c +++ b/Modules/timemodule.c @@ -737,6 +737,52 @@ the local timezone used by methods such as localtime, but this behaviour\n\ should not be relied on."); #endif /* HAVE_WORKING_TZSET */ +static PyObject * +time_wallclock(PyObject *self, PyObject *unused) +{ +#if defined(MS_WINDOWS) && !defined(__BORLANDC__) + return time_clock(self, NULL); +#elif defined(HAVE_CLOCK_GETTIME) && defined(CLOCK_MONOTONIC) + static int clk_index = 0; + clockid_t clk_ids[] = { +#ifdef CLOCK_MONOTONIC_RAW + CLOCK_MONOTONIC_RAW, +#endif + CLOCK_MONOTONIC +#ifdef CLOCK_REALTIME + /* On Linux, CLOCK_REALTIME uses the same clock than gettimeofday(), + but clock_gettime() has a nanosecond resolution. */ + , CLOCK_REALTIME +#endif + }; + int ret; + struct timespec tp; + + while (0 <= clk_index) { + clockid_t clk_id = clk_ids[clk_index]; + ret = clock_gettime(clk_id, &tp); + if (ret == 0) + return PyFloat_FromDouble(tp.tv_sec + tp.tv_nsec * 1e-9); + + clk_index++; + if (Py_ARRAY_LENGTH(clk_ids) <= clk_index) + clk_index = -1; + } + return time_time(self, NULL); +#else + return time_time(self, NULL); +#endif +} + +PyDoc_STRVAR(wallclock_doc, +"wallclock() -> float\n\ +\n\ +Return the current time in fractions of a second to the system's best\n\ +ability. Use this when the most accurate representation of wall-clock is\n\ +required, i.e. when \"processor time\" is inappropriate. The reference point\n\ +of the returned value is undefined so only the difference of consecutive\n\ +calls is valid."); + static void PyInit_timezone(PyObject *m) { /* This code moved from PyInit_time wholesale to allow calling it from @@ -872,6 +918,7 @@ static PyMethodDef time_methods[] = { #ifdef HAVE_WORKING_TZSET {"tzset", time_tzset, METH_NOARGS, tzset_doc}, #endif + {"wallclock", time_wallclock, METH_NOARGS, wallclock_doc}, {NULL, NULL} /* sentinel */ }; |