Hash :
67a27eec
Author :
Thomas de Grivel
Date :
2017-05-27T21:34:56
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
(in-package :cffi-fcntl)
(defcfun ("fcntl" c-fcntl) :int
(fd :int)
(cmd :int))
(defcfun ("fcntl" c-fcntl/int) :int
(fd :int)
(cmd :int)
(arg :int))
(defcfun ("fcntl" c-fcntl/pointer) :int
(fd :int)
(cmd :int)
(arg :pointer))
(defun getfl (fd)
(c-fcntl fd +f-getfl+))
(defun setfl (fd flags)
(c-fcntl/int fd +f-setfl+ flags))
(defcfun ("open" c-open/2) :int
(pathname :string)
(flags :int))
(defcfun ("open" c-open/3) :int
(pathname :string)
(flags :int)
(mode mode-t))
(defun open (pathname flags &optional mode)
(let ((fd (if (= 0 (logand flags +o-creat+))
(c-open/2 pathname flags)
(c-open/3 pathname flags mode))))
(when (< fd 0)
(error-errno "open"))
fd))
(defcfun ("openat" c-openat/3) :int
(dirfd :int)
(pathname :string)
(flags :int))
(defcfun ("openat" c-openat/4) :int
(dirfd :int)
(pathname :string)
(flags :int)
(mode mode-t))
(defun openat (dirfd pathname flags &optional mode)
(let ((fd (if (= 0 (logand flags +o-creat+))
(c-openat/3 dirfd pathname flags)
(c-openat/4 dirfd pathname flags mode))))
(when (< fd 0)
(error-errno "openat"))
fd))
(defcfun ("creat" c-creat) :int
(file :string)
(mode mode-t))
(defun creat (file mode)
(let ((fd (c-creat file mode)))
(when (< fd 0)
(error-errno "creat"))
fd))