Mercurial > hg > python-clock
changeset 0:1c0396a8fff4 default tip
Import
author | Daniele Nicolodi <daniele.nicolodi@obspm.fr> |
---|---|
date | Fri, 03 Jul 2015 21:00:16 +0200 (2015-07-03) |
parents | |
children | |
files | .hgignore Makefile clock.pyx setup.py test.py |
diffstat | 5 files changed, 120 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/.hgignore Fri Jul 03 21:00:16 2015 +0200 @@ -0,0 +1,7 @@ +syntax: glob +clock.c +build/ +*.pyc +*.so +*~ +
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Makefile Fri Jul 03 21:00:16 2015 +0200 @@ -0,0 +1,4 @@ +PYTHON = python + +all: + $(PYTHON) setup.py build_ext --inplace
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/clock.pyx Fri Jul 03 21:00:16 2015 +0200 @@ -0,0 +1,80 @@ +from libc.errno cimport * +from libc.stdio cimport snprintf + +cdef extern from "time.h": + ctypedef long time_t + cdef struct _timespec "timespec": + time_t tv_sec + long tv_nsec + cdef enum: + CLOCK_MONOTONIC + CLOCK_REALTIME + cdef enum: + TIMER_ABSTIME + int clock_gettime(int id, _timespec *tp) nogil + int clock_nanosleep(int id, int flags, + _timespec *request, + _timespec *remain) nogil + + +cdef class timespec: + cdef _timespec t + + def __init__(self, long sec=0, long nsec=0): + self.t.tv_sec = sec + self.t.tv_nsec = nsec + + property sec: + def __get__(self): + return self.t.tv_sec + def __set__(self, long v): + self.t.tv_sec = v + + property nsec: + def __get__(self): + return self.t.tv_nsec + def __set__(self, long v): + self.t.tv_nsec = v + while self.t.tv_nsec >= 1000000000: + self.t.tv_sec += 1 + self.t.tv_nsec -= 1000000000 + + def __add__(self, long v): + self.sec += v + return self + + def __float__(self): + return self.t.tv_sec + self.t.tv_nsec * 1e-9 + + def __repr__(self): + cdef char[64] s + snprintf(s, 64, "{ sec=%ld nsec=%ld }", self.t.tv_sec, self.t.tv_nsec) + return s + + +def gettime(clockid=CLOCK_REALTIME): + t = timespec() + clock_gettime(clockid, &t.t) + return t + + +def nanosleep(timespec request, int clockid=CLOCK_REALTIME, bint absolute=False): + cdef _timespec remain + cdef int flags = 0 + cdef int r + cdef _timespec *t = &request.t + + if absolute: + flags = flags | TIMER_ABSTIME + + with nogil: + while 1: + r = clock_nanosleep(clockid, flags, t, &remain) + if r == EINTR: + if not absolute: + t = &remain + continue + break + + if r != 0: + raise ValueError
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/setup.py Fri Jul 03 21:00:16 2015 +0200 @@ -0,0 +1,7 @@ +from distutils.core import setup +from distutils.extension import Extension +from Cython.Build import cythonize + +setup( + ext_modules = cythonize([Extension("clock", ["clock.pyx"])]) +)
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test.py Fri Jul 03 21:00:16 2015 +0200 @@ -0,0 +1,22 @@ +import clock + +# print clock.gettime() +# clock.nanosleep(clock.timespec(1)) +# print clock.gettime() + +# t = clock.gettime() +# print t +# t.sec += 1 +# print t +# clock.nanosleep(t, absolute=True) +# print clock.gettime() + +# t += 1 +# print t + +t = clock.gettime() +print t +for x in range(10): + t.nsec += 10 + print t + clock.nanosleep(t, absolute=True)