(defpackage :gobject
(:use :cl :glib :cffi :tg :bordeaux-threads :iter :closer-mop :gobject.ffi)
+ #+(or clozure-common-lisp openmcl) (:shadowing-import-from :closer-mop #:defgeneric #:ensure-generic-function #:standard-generic-function)
(:export #:g-type
#:g-type-string
#:g-type-numeric
#:get-flags-items
#:stable-pointer-value
#:g-value-type
- #:create-g-closure
#:g-object-call-constructor
#:g-object-call-get-property
#:g-object-call-set-property
#:define-g-boxed-variant-cstruct
#:g-boxed-foreign
#:boxed-related-symbols
- #:define-boxed-opaque-accessor)
+ #:define-boxed-opaque-accessor
+ #:glib-defcallback
+ #:create-signal-handler-closure
+ #:save-handler-to-object
+ #:retrieve-handler-from-object
+ #:delete-handler-from-object
+ #:disconnect-signal)
(:documentation
"CL-GTK2-GOBJECT is a binding to GObject type system.
For information on GObject, see its @a[http://library.gnome.org/devel/gobject/stable/]{documentation}.
(defvar *gobject-debug* nil)
-(defmacro debugf (&rest args)
- (when *gobject-debug*
- (apply 'format t args)))
\ No newline at end of file
+(defvar *debug-gc* nil)
+(defvar *debug-subclass* nil)
+
+(defvar *debug-stream* t)
+
+(defmacro log-for (categories control-string &rest args)
+ (let ((vars (iter (for sym in (if (listp categories) categories (list categories)))
+ (collect (intern (format nil "*DEBUG-~A*" (symbol-name sym)) (find-package :gobject))))))
+ `(progn
+ (when (or ,@vars)
+ (format *debug-stream* ,control-string ,@args))
+ nil)))