;; TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
;; SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-;; $Id: genums.lisp,v 1.14 2005/04/24 13:24:41 espen Exp $
+;; $Id: genums.lisp,v 1.18 2006/02/19 22:25:31 espen Exp $
(in-package "GLIB")
(t (error 'type-error :datum ,form :expected-type '(enum ,@args)))))
+(defmethod callback-from-alien-form (form (type (eql 'enum)) &rest args)
+ (apply #'from-alien-form form type args))
+
(defmethod from-alien-form (form (type (eql 'enum)) &rest args)
(declare (ignore type))
`(case ,form
(declare (ignore type))
(let ((reader (reader-function 'signed))
(function (apply #'from-alien-function 'enum args)))
- #'(lambda (location &optional (offset 0))
+ #'(lambda (location &optional (offset 0) weak-p)
+ (declare (ignore weak-p))
(funcall function (funcall reader location offset)))))
(defun enum-int (enum type)
(defmethod reader-function ((type (eql ',name)) &rest args)
(declare (ignore type args))
(let ((reader (reader-function 'signed)))
- #'(lambda (location &optional (offset 0))
+ #'(lambda (location &optional (offset 0) weak-p)
+ (declare (ignore weak-p))
(,int-enum (funcall reader location offset))))))))
(t (error 'type-error :datum ,flags
:expected-type '(,type ,@args)))))))
+(defmethod callback-from-alien-form (form (type (eql 'flags)) &rest args)
+ (apply #'from-alien-form form type args))
+
(defmethod from-alien-form (value (type (eql 'flags)) &rest args)
(declare (ignore type))
`(loop
(declare (ignore type))
(let ((reader (reader-function 'unsigned))
(function (apply #'from-alien-function 'flags args)))
- #'(lambda (location &optional (offset 0))
+ #'(lambda (location &optional (offset 0) weak-p)
+ (declare (ignore weak-p))
(funcall function (funcall reader location offset)))))
(defmethod reader-function ((type (eql ',name)) &rest args)
(declare (ignore type args))
(let ((reader (reader-function 'signed)))
- #'(lambda (location &optional (offset 0))
+ #'(lambda (location &optional (offset 0) weak-p)
+ (declare (ignore weak-p))
(,int-flags (funcall reader location offset))))))))
(multiple-value-bind (sap length)
(funcall query-function (type-class-ref type))
(let ((values nil)
- (size (proxy-instance-size (find-class class)))
- (proxy (make-instance class :location sap)))
+ (size (foreign-size (find-class class)))
+ (proxy (ensure-proxy-instance class sap)))
(dotimes (i length)
(with-slots (location nickname value) proxy
(setf location sap)