(defun nanosleep (secs nsecs)
(with-alien ((req (struct timespec))
(rem (struct timespec)))
- (setf (slot req 'tv-sec) secs)
- (setf (slot req 'tv-nsec) nsecs)
+ (setf (slot req 'tv-sec) secs
+ (slot req 'tv-nsec) nsecs)
(loop while (and (eql sb!unix:eintr
(nth-value 1
(int-syscall ("nanosleep" (* (struct timespec))
(rem-nsec (slot rem 'tv-nsec)))
(when (or (> secs rem-sec)
(and (= secs rem-sec) (>= nsecs rem-nsec)))
- (setf secs rem-sec
- nsecs rem-nsec)
t)))
- do (rotatef req rem))))
+ do (setf (slot req 'tv-sec) (slot rem 'tv-sec)
+ (slot req 'tv-nsec) (slot rem 'tv-nsec)))))
(defun unix-get-seconds-west (secs)
(multiple-value-bind (ignore seconds dst) (get-timezone secs)
;;;; more information.
(in-package :cl-user)
+
+(load "test-util.lisp")
+(load "compiler-test-util.lisp")
+(use-package :test-util)
\f
;;;; properties of symbols, e.g. presence of doc strings for public symbols
(sleep 2)
(sleep 2))))
+;;; SLEEP should not cons
+(with-test (:name (sleep :non-consing))
+ (ctu:assert-no-consing (sleep 0.00001)))
+
;;; SLEEP should work with large integers as well -- no timers
;;; on win32, so don't test there.
(with-test (:name (sleep pretty-much-forever) :skipped-on :win32)