From: Kevin M. Rosenberg Date: Wed, 30 Apr 2003 14:06:14 +0000 (+0000) Subject: r4719: *** empty log message *** X-Git-Tag: v1.6.1~222 X-Git-Url: http://git.kpe.io/?p=uffi.git;a=commitdiff_plain;h=33b8a5afb55eb161ef04a1be94e6d2dca85c748c r4719: *** empty log message *** --- diff --git a/tests/gettime.lisp b/tests/gettime.lisp deleted file mode 100644 index 37461ff..0000000 --- a/tests/gettime.lisp +++ /dev/null @@ -1,76 +0,0 @@ -;;;; -*- Mode: LISP; Syntax: ANSI-Common-Lisp; Base: 10 -*- -;;;; ************************************************************************* -;;;; FILE IDENTIFICATION -;;;; -;;;; Name: gettime -;;;; Purpose: UFFI Example file to get time, use C structures -;;;; Programmer: Kevin M. Rosenberg -;;;; Date Started: Feb 2002 -;;;; -;;;; $Id: gettime.lisp,v 1.1 2002/09/30 10:02:36 kevin Exp $ -;;;; -;;;; This file, part of UFFI, is Copyright (c) 2002 by Kevin M. Rosenberg -;;;; -;;;; UFFI users are granted the rights to distribute and use this software -;;;; as governed by the terms of the Lisp Lesser GNU Public License -;;;; (http://opensource.franz.com/preamble.html), also known as the LLGPL. -;;;; ************************************************************************* - -(in-package :cl-user) - -(uffi:def-foreign-type time-t :unsigned-long) - -(uffi:def-struct tm - (sec :int) - (min :int) - (hour :int) - (mday :int) - (mon :int) - (year :int) - (wday :int) - (yday :int) - (isdst :int)) - -(uffi:def-function ("time" c-time) - ((time (* time-t))) - :returning time-t) - -(uffi:def-function ("localtime" c-localtime) - ((time (* time-t))) - :returning (* tm)) - -(uffi:def-type time-t :unsigned-long) -(uffi:def-type tm-pointer (* tm)) - -(defun gettime () - "Returns the local time" - (uffi:with-foreign-object (time 'time-t) -;; (declare (type time-t time)) - (c-time time) - (let ((tm-ptr (the tm-pointer (c-localtime time)))) - (declare (type tm-pointer tm-ptr)) - (let ((time-string (format nil "~2d/~2,'0d/~d ~2d:~2,'0d:~2,'0d" - (1+ (uffi:get-slot-value tm-ptr 'tm 'mon)) - (uffi:get-slot-value tm-ptr 'tm 'mday) - (+ 1900 (uffi:get-slot-value tm-ptr 'tm 'year)) - (uffi:get-slot-value tm-ptr 'tm 'hour) - (uffi:get-slot-value tm-ptr 'tm 'min) - (uffi:get-slot-value tm-ptr 'tm 'sec) - ))) - time-string)))) - - - - -#+examples-uffi -(format t "~&~A" (gettime)) - -#+test-uffi -(progn - (let ((time (gettime))) - (util.test:test (stringp time) t :fail-info "Time is not a string") - (util.test:test (plusp (parse-integer time :junk-allowed t)) - t - :fail-info "time string does not start with a number"))) - - diff --git a/tests/time.lisp b/tests/time.lisp new file mode 100644 index 0000000..0dd1816 --- /dev/null +++ b/tests/time.lisp @@ -0,0 +1,68 @@ +;;;; -*- Mode: LISP; Syntax: ANSI-Common-Lisp; Base: 10 -*- +;;;; ************************************************************************* +;;;; FILE IDENTIFICATION +;;;; +;;;; Name: time.lisp +;;;; Purpose: UFFI test file, time, use C structures +;;;; Author: Kevin M. Rosenberg +;;;; Date Started: Feb 2002 +;;;; +;;;; $Id: time.lisp,v 1.1 2003/04/30 14:06:14 kevin Exp $ +;;;; +;;;; This file, part of UFFI, is Copyright (c) 2002 by Kevin M. Rosenberg +;;;; +;;;; UFFI users are granted the rights to distribute and use this software +;;;; as governed by the terms of the Lisp Lesser GNU Public License +;;;; (http://opensource.franz.com/preamble.html), also known as the LLGPL. +;;;; ************************************************************************* + +(in-package :uffi-tests) + +(uffi:def-foreign-type time-t :unsigned-long) + +(uffi:def-struct tm + (sec :int) + (min :int) + (hour :int) + (mday :int) + (mon :int) + (year :int) + (wday :int) + (yday :int) + (isdst :int)) + +(uffi:def-function ("time" c-time) + ((time (* time-t))) + :returning time-t) + +(uffi:def-function ("gmtime" c-gmtime) + ((time (* time-t))) + :returning (* tm)) + +(uffi:def-type time-t :unsigned-long) +(uffi:def-type tm-pointer (* tm)) + +(deftest time.1 + (uffi:with-foreign-object (time 'time-t) + (setf (uffi:deref-pointer time :unsigned-long) 7381) + (uffi:deref-pointer time :unsigned-long)) + 7381) + +(deftest time.2 + (uffi:with-foreign-object (time 'time-t) + (setf (uffi:deref-pointer time :unsigned-long) 7381) + (let ((tm-ptr (the tm-pointer (c-gmtime time)))) + (values (1+ (uffi:get-slot-value tm-ptr 'tm 'mon)) + (uffi:get-slot-value tm-ptr 'tm 'mday) + (+ 1900 (uffi:get-slot-value tm-ptr 'tm 'year)) + (uffi:get-slot-value tm-ptr 'tm 'hour) + (uffi:get-slot-value tm-ptr 'tm 'min) + (uffi:get-slot-value tm-ptr 'tm 'sec) + ))) + 1 1 1970 2 3 1) + + + + + + diff --git a/uffi-tests.asd b/uffi-tests.asd index f5ff0c9..91af3a5 100644 --- a/uffi-tests.asd +++ b/uffi-tests.asd @@ -7,7 +7,7 @@ ;;;; Author: Kevin M. Rosenberg ;;;; Date Started: Apr 2003 ;;;; -;;;; $Id: uffi-tests.asd,v 1.5 2003/04/30 13:48:34 kevin Exp $ +;;;; $Id: uffi-tests.asd,v 1.6 2003/04/30 14:06:14 kevin Exp $ ;;;; ************************************************************************* (defpackage #:uffi-tests-system @@ -28,6 +28,7 @@ (:file "gethostname" :depends-on ("package")) (:file "union" :depends-on ("package")) (:file "arrays" :depends-on ("package")) + (:file "time" :depends-on ("package")) (:file "uffi-c-test-lib" :depends-on ("package")) ))))