X-Git-Url: https://git.distorted.org.uk/~mdw/clg/blobdiff_plain/b19bbc943eecd2655a0e3f32eefada102f51142f..c96779a5019b4a7788b92baa95552d47413ab161:/glib/gobject.lisp diff --git a/glib/gobject.lisp b/glib/gobject.lisp index 51086f5..59066da 100644 --- a/glib/gobject.lisp +++ b/glib/gobject.lisp @@ -20,7 +20,7 @@ ;; TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE ;; SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -;; $Id: gobject.lisp,v 1.47 2006-02-15 09:45:41 espen Exp $ +;; $Id: gobject.lisp,v 1.51 2006-03-03 10:01:01 espen Exp $ (in-package "GLIB") @@ -64,7 +64,9 @@ #+glib2.8 (progn - (defcallback toggle-ref-callback (nil (data pointer) (location pointer) (last-ref-p boolean)) + (define-callback toggle-ref-callback nil + ((data pointer) (location pointer) (last-ref-p boolean)) + (declare (ignore data)) #+debug-ref-counting (if last-ref-p (format t "Object at 0x~8,'0X has no foreign references~%" (sap-int location)) @@ -73,14 +75,14 @@ (cache-instance (find-cached-instance location) t) (cache-instance (find-cached-instance location) nil))) - (defbinding %object-add-toggle-ref () pointer + (defbinding %object-add-toggle-ref (location) pointer (location pointer) - ((callback toggle-ref-callback) pointer) + (toggle-ref-callback callback) (nil null)) - (defbinding %object-remove-toggle-ref () pointer + (defbinding %object-remove-toggle-ref (location) pointer (location pointer) - ((callback toggle-ref-callback) pointer) + (toggle-ref-callback callback) (nil null))) (defmethod reference-foreign ((class gobject-class) location) @@ -93,12 +95,12 @@ #+debug-ref-counting (progn - (defcallback weak-ref-callback (nil (data pointer) (location pointer)) + (define-callback weak-ref-callback nil ((data pointer) (location pointer)) (format t "Object at 0x~8,'0X being finalized~%" (sap-int location))) - (defbinding %object-weak-ref () pointer + (defbinding %object-weak-ref (location) pointer (location pointer) - ((callback weak-ref-callback) pointer) + (weak-ref-callback callback) (nil null))) @@ -214,7 +216,6 @@ (setf (slot-value class 'instance-slots-p) t))) - ;;;; Super class for all classes in the GObject type hierarchy (eval-when (:compile-toplevel :load-toplevel :execute) @@ -224,6 +225,9 @@ (:metaclass gobject-class) (:gtype "GObject"))) +(define-type-method callback-from-alien-form ((type gobject) form) + (from-alien-form type form)) + #+debug-ref-counting (defmethod print-object ((instance gobject) stream) (print-unreadable-object (instance stream :type t :identity nil) @@ -381,16 +385,14 @@ (object gobject) (id quark) (data unsigned-long) - (destroy-marshal pointer)) + (destroy-marshal callback)) -(defcallback user-data-destroy-func (nil (id unsigned-int)) +(define-callback user-data-destroy-callback nil ((id unsigned-int)) (destroy-user-data id)) -(export 'user-data-destroy-func) - (defun (setf user-data) (data object key) (%object-set-qdata-full object (quark-intern key) - (register-user-data data) (callback user-data-destroy-func)) + (register-user-data data) user-data-destroy-callback) data) ;; deprecated @@ -555,16 +557,17 @@ ;;; Pseudo type for gobject instances which have their reference count ;;; increased by the returning function -(defmethod alien-type ((type (eql 'referenced)) &rest args) - (declare (ignore type args)) - (alien-type 'gobject)) +(deftype referenced (type) type) -(defmethod from-alien-form (form (type (eql 'referenced)) &rest args) +(define-type-method alien-type ((type referenced)) (declare (ignore type)) - (destructuring-bind (type) args + (alien-type 'gobject)) + +(define-type-method from-alien-form ((type referenced) form) + (let ((class (second (type-expand-to 'referenced type)))) (if (subtypep type 'gobject) (let ((instance (make-symbol "INSTANCE"))) - `(let ((,instance ,(from-alien-form form type))) + `(let ((,instance ,(from-alien-form class form))) (when ,instance (%object-unref (foreign-location ,instance))) ,instance))