(defmacro deref-array (obj type i)
"Returns a field from a row"
- #+(or lispworks cmu sbcl scl) (declare (ignore type))
- #+(or cmu scl) `(alien:deref ,obj ,i)
- #+sbcl `(sb-alien:deref ,obj ,i)
+ #+(or lispworks scl) (declare (ignore type))
+ #+(or cmu scl) `(alien:deref (the (alien:alien ,(convert-from-uffi-type type :declare)) ,obj) ,i)
+ #+sbcl `(sb-alien:deref (the (sb-alien:alien ,(convert-from-uffi-type type :declare)) ,obj) ,i)
#+lispworks `(fli:dereference ,obj :index ,i :copy-foreign-object nil)
#+allegro `(ff:fslot-value-typed (quote ,(convert-from-uffi-type type :type)) :c ,obj ,i)
#+openmcl
(let ((result (%convert-from-uffi-type type context)))
(cond
((atom result) result)
+ ;; Arrays without size are really pointers to type on SBCL/CMUCL
+ #+sbcl
+ ((and (consp type) (= 2 (length type)) (eq :array (car type)))
+ (setf (car result) 'sb-alien:*)
+ result)
+ #+cmu
+ ((and (consp type) (= 2 (length type)) (eq :array (car type)))
+ (setf (car result) 'alien:*)
+ result)
#+openmcl
((eq (car result) :address)
(if (eq context :struct)