r10087: add convert-from-foreign-usb8
authorKevin M. Rosenberg <kevin@rosenberg.net>
Thu, 7 Oct 2004 18:36:28 +0000 (18:36 +0000)
committerKevin M. Rosenberg <kevin@rosenberg.net>
Thu, 7 Oct 2004 18:36:28 +0000 (18:36 +0000)
ChangeLog
src/objects.lisp
src/package.lisp

index 4c0ea2e0e54dc8981f4c5c617eefd1afa9f8c4b1..ba64d0612c2eda9ea6a5c49e9a336b5dcafdc1ea 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+2004-10-07 Kevin Rosenberg (kevin@rosenberg.net)
+       * src/objects.lisp: Add new function:
+       convert-from-foreign-usb8
+       
 2004-04-15 Kevin Rosenberg (kevin@rosenberg.net)
        * src/objects.lisp: Add new functions:
        MAKE-POINTER and POINTER-ADDRESS
index 358763e41fc829c815845886a3e898dcf31bd733..0e2d908f45fe9edea2b6709e2f4ed28a1a455c02 100644 (file)
@@ -270,3 +270,37 @@ an array of TYPE with size SIZE. The TYPE parameter is evaluated."
     `(define-symbol-macro ,lisp-name
       '(error "DEF-FOREIGN-VAR not (yet) defined for ~A"
         (lisp-implementation-type)))))
+
+#-(or sbcl cmu)
+(defun convert-from-foreign-usb8 (s len)
+  (declare (optimize (speed 3) (space 0) (safety 0) (compilation-speed 0))
+          (fixnum len))
+  (let ((a (make-array len :element-type '(unsigned-byte 8))))
+    (dotimes (i len a)
+      (declare (fixnum i))
+      (setf (aref a i) (uffi:deref-array s '(:array :unsigned-byte) i)))))
+
+#+sbcl
+(defun convert-from-foreign-usb8 (s len)
+  (declare (type sb-sys:system-area-pointer sap))
+  (locally
+      (declare (optimize (speed 3) (safety 0)))
+    (let ((result (make-array len :element-type '(unsiged-byte 8))))
+      (sb-kernel:copy-from-system-area s 0
+                                      result (* sb-vm:vector-data-offset
+                                                sb-vm:n-word-bits)
+                                      (* len sb-vm:n-byte-bits))
+      result)))
+
+#+cmu
+(defun convert-from-foreign-usb8 (s le)
+  (declare (type system:system-area-pointer sap))
+  (locally
+      (declare (optimize (speed 3) (safety 0)))
+    (let ((result (make-array len :element-type '(unsiged-byte 8))))
+      (kernel:copy-from-system-area s 0
+                                   result (* vm:vector-data-offset
+                                             vm:word-bits)
+                                   (* len vm:byte-bits))
+      result)))
+
index 3c22730a3f73e7735f9d0701915f0fd184879f42..e25c9cef71b1403544324b2e506ae5e16e22c6cb 100644 (file)
@@ -54,6 +54,7 @@
    #:char-array-to-pointer
    #:with-cast-pointer
    #:def-foreign-var
+   #:convert-from-foreign-usb8
    
    ;; string functions
    #:convert-from-cstring