(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
#:g-initially-unowned
#:define-g-enum
#:*lisp-name-package*
- #:define-g-boxed-class
#:define-g-flags
#:fixed-array
#:g-boxed-inline
#:release
#:using
#:using*
- #:define-g-boxed-ref
#:g-boxed-ref
#:allocate-stable-pointer
#:free-stable-pointer
#:g-boxed-opaque
#:g-boxed-opaque-pointer
#:define-g-boxed-variant-cstruct
- #:g-boxed-foreign)
+ #:g-boxed-foreign
+ #:boxed-related-symbols
+ #:define-boxed-opaque-accessor
+ #:glib-defcallback)
(: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)
-(defun 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)))