X-Git-Url: http://git.kpe.io/?a=blobdiff_plain;f=tests%2Ftime.lisp;fp=tests%2Ftime.lisp;h=410d14c8174e8006f4290eff0d27834e11a642b3;hb=cc739f67940b866f1a3b963cd1f35d1c0c81dd0c;hp=2402b429987d54b82730145b0c146f6b625312bf;hpb=30e6dcb79dc5d298d3c9e4f1252d256cc4a08599;p=uffi.git diff --git a/tests/time.lisp b/tests/time.lisp index 2402b42..410d14c 100644 --- a/tests/time.lisp +++ b/tests/time.lisp @@ -7,7 +7,7 @@ ;;;; Author: Kevin M. Rosenberg ;;;; Date Started: Feb 2002 ;;;; -;;;; $Id: time.lisp,v 1.2 2003/08/13 18:53:42 kevin Exp $ +;;;; $Id: time.lisp,v 1.3 2003/08/23 12:36:59 kevin Exp $ ;;;; ;;;; This file, part of UFFI, is Copyright (c) 2002 by Kevin M. Rosenberg ;;;; @@ -59,7 +59,34 @@ 1 1 1970 2 3 1) - +(uffi:def-struct timeval + (secs :long) + (usecs :long)) +(uffi:def-struct timezone + (minutes-west :int) + (dsttime :int)) +(uffi:def-function ("gettimeofday" c-gettimeofday) + ((tv (* timeval)) + (tz (* timezone))) + :returning :int) + +(defun get-utime () + (uffi:with-foreign-object (tv 'timeval) + (let ((res (c-gettimeofday tv (uffi:make-null-pointer 'timezone)))) + (values + (+ (* 1000000 (uffi:get-slot-value tv 'timeval 'secs)) + (uffi:get-slot-value tv 'timeval 'usecs)) + res)))) +(deftest timeofday.1 + (multiple-value-bind (t1 res1) (get-utime) + (multiple-value-bind (t2 res2) (get-utime) + (and (or (= t2 t1) (> t2 t1)) + (> t1 1000000000) + (> t2 1000000000) + (zerop res1) + (zerop res2)))) + t) +