2008-10-06 19:18:33 -04:00
|
|
|
! Copyright (C) 2008 Doug Coleman.
|
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
2012-07-15 18:16:28 -04:00
|
|
|
USING: accessors alien.data calendar calendar.private
|
|
|
|
classes.struct kernel math system unix unix.time unix.types ;
|
2007-09-20 18:09:08 -04:00
|
|
|
IN: calendar.unix
|
|
|
|
|
2012-07-15 18:16:28 -04:00
|
|
|
: timeval>seconds ( timeval -- seconds )
|
2012-07-16 18:30:58 -04:00
|
|
|
[ sec>> ] [ usec>> 1,000,000 / ] bi + ; inline
|
2012-07-15 18:16:28 -04:00
|
|
|
|
2012-08-15 11:29:00 -04:00
|
|
|
: timeval>micros ( timeval -- micros )
|
|
|
|
[ sec>> 1,000,000 * ] [ usec>> ] bi + ; inline
|
|
|
|
|
2010-06-13 19:24:48 -04:00
|
|
|
: timeval>duration ( timeval -- duration )
|
2012-08-15 11:29:00 -04:00
|
|
|
timeval>seconds seconds ; inline
|
2008-10-21 05:19:50 -04:00
|
|
|
|
|
|
|
: timeval>unix-time ( timeval -- timestamp )
|
2012-08-15 11:29:00 -04:00
|
|
|
[ unix-1970 ] dip timeval>seconds +second ; inline
|
2008-10-06 19:03:56 -04:00
|
|
|
|
2012-07-15 18:16:28 -04:00
|
|
|
: timespec>seconds ( timespec -- seconds )
|
2012-07-16 18:30:58 -04:00
|
|
|
[ sec>> ] [ nsec>> 1,000,000,000 / ] bi + ; inline
|
2008-10-21 05:19:50 -04:00
|
|
|
|
2012-07-15 18:16:28 -04:00
|
|
|
: timespec>duration ( timespec -- duration )
|
2012-08-15 11:29:00 -04:00
|
|
|
timespec>seconds seconds ; inline
|
2009-11-15 01:46:12 -05:00
|
|
|
|
2008-10-21 05:19:50 -04:00
|
|
|
: timespec>unix-time ( timespec -- timestamp )
|
2012-08-15 11:29:00 -04:00
|
|
|
[ unix-1970 ] dip timespec>seconds +second ; inline
|
2008-10-06 19:03:56 -04:00
|
|
|
|
2008-03-19 20:15:32 -04:00
|
|
|
: get-time ( -- alien )
|
2012-08-15 11:29:00 -04:00
|
|
|
f time time_t <ref> localtime ; inline
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-03-19 20:15:32 -04:00
|
|
|
: timezone-name ( -- string )
|
2009-08-30 05:06:41 -04:00
|
|
|
get-time zone>> ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-04-02 19:28:55 -04:00
|
|
|
M: unix gmt-offset ( -- hours minutes seconds )
|
2009-08-30 05:06:41 -04:00
|
|
|
get-time gmtoff>> 3600 /mod 60 /mod ;
|
2010-06-17 01:04:53 -04:00
|
|
|
|
2010-06-22 02:49:11 -04:00
|
|
|
: current-timeval ( -- timeval )
|
2012-08-15 11:29:00 -04:00
|
|
|
timeval <struct> f [ gettimeofday io-error ] 2keep drop ; inline
|
2010-06-22 02:49:11 -04:00
|
|
|
|
|
|
|
: system-micros ( -- n )
|
2012-08-15 11:29:00 -04:00
|
|
|
current-timeval timeval>micros ;
|
2010-06-22 02:49:11 -04:00
|
|
|
|
2010-06-17 01:04:53 -04:00
|
|
|
M: unix gmt
|
2010-06-22 02:49:11 -04:00
|
|
|
current-timeval timeval>unix-time ;
|