X-Git-Url: http://git.kpe.io/?a=blobdiff_plain;f=uffi%2Fclsql-uffi.lisp;h=331db7d3ab795d3f974dc09f834ca180f452532b;hb=8b42ade98431d9089422974c26d7ec593173d062;hp=da5276afaba79926e8da8a89fc13091bd45e5041;hpb=bada52b7a8fd2cc484dee33cccd64ca09a52ec3d;p=clsql.git diff --git a/uffi/clsql-uffi.lisp b/uffi/clsql-uffi.lisp index da5276a..331db7d 100644 --- a/uffi/clsql-uffi.lisp +++ b/uffi/clsql-uffi.lisp @@ -21,7 +21,7 @@ (defun canonicalize-type-list (types auto-list) "Ensure a field type list meets expectations" - (declaim (optimize (speed 3) (safety 0))) + (declare (optimize (speed 3) (safety 0))) (do ((i 0 (1+ i)) (new-types '()) (length-types (length types)) @@ -87,9 +87,9 @@ (uffi:def-type char-ptr-def (* :unsigned-char)) -(defun convert-raw-field (char-ptr types index) +(defun convert-raw-field (char-ptr types index &optional length) (declare (optimize (speed 3) (safety 0) (space 0)) - (type char-ptr-def char-ptr)) + (type char-ptr-def char-ptr)) (let ((type (if (listp types) (nth index types) types))) @@ -110,5 +110,9 @@ low32 (make-64-bit-integer high32 low32))))) (t - (uffi:convert-from-foreign-string char-ptr :locale :none))))))) - + (if length + (uffi:convert-from-foreign-string char-ptr :locale :none + :null-terminated-p nil + :length length) + (uffi:convert-from-foreign-string char-ptr :locale :none)))))))) +