(format stream "~S~%"
(string-right-trim '(#\return) (raw-message-string msg)))))
-(uffi:def-foreign-type time-t :unsigned-long)
-(uffi:def-function ("ctime" c-ctime)
- ((time (* time-t)))
- :returning :cstring)
+(defconstant +posix-epoch+
+ (encode-universal-time 0 0 0 1 1 1970 0))
+
+(defun posix-time-to-utime (time)
+ (+ time +posix-epoch+))
(defun last-sexp-field (type msg)
(cond
(when (stringp (car (last (arguments msg))))
(let ((secs (parse-integer (car (last (arguments msg))) :junk-allowed t)))
(when secs
- (string-right-trim '(#\newline #\return)
- (uffi:convert-from-cstring
- (uffi:with-foreign-object (time 'time-t)
- (setf (uffi:deref-pointer time :unsigned-long) secs)
- (c-ctime time))))))))
+ (posix-time-to-utime secs)))))
((need-user-address? type)
(user-address msg))))