chiark / gitweb /
Infra: Rudimentary setup system.
[clg] / gtk / gtkwidget.lisp
index 1aabe4f3454e50b586b725d9ab0883a6866ecfb1..0117544438a7c97c66a5f933d6689cdc9acb6c9b 100644 (file)
@@ -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: gtkwidget.lisp,v 1.29 2007-09-06 14:27:07 espen Exp $
+;; $Id: gtkwidget.lisp,v 1.32 2008-11-25 22:17:08 espen Exp $
 
 (in-package "GTK")
 
@@ -60,8 +60,7 @@ (defmethod slot-unbound ((class gobject-class) (object widget)
    ((slot-boundp object 'parent)
     (with-slots (parent child-properties) object
       (setf child-properties
-       (make-instance 
-        (gethash (class-of parent) *container-to-child-class-mappings*)
+       (make-instance (find-child-class (class-of parent))
        :parent parent :child object))))
    ((call-next-method))))
 
@@ -71,23 +70,23 @@ (defparameter *widget-display-as-default-in-signal-handler-p* t)
 (defmethod compute-signal-function ((widget widget) signal function object args)
   (let ((wrapper
         (if (eq object :parent)
-            #'(lambda (&rest emission-args)
-                (let ((all-args (nconc (rest emission-args) args)))
+            #'(lambda (widget &rest emission-args)
+                (let ((all-args (nconc emission-args args)))
                   (if (slot-boundp widget 'parent)
                       (apply function (widget-parent widget) all-args)
                     ;; Delay until parent is set
                     (signal-connect widget 'parent-set
                      #'(lambda (old-parent)
                          (declare (ignore old-parent))
-                         (apply #'signal-emit widget signal (rest emission-args)))
+                         (apply #'signal-emit widget signal emission-args))
                      :remove t))))
           (call-next-method))))
     (if *widget-display-as-default-in-signal-handler-p*
-       #'(lambda (&rest args)
+       #'(lambda (widget &rest args)
            (let ((display (when (slot-boundp widget 'window)
                             (gdk:drawable-display (widget-window widget)))))
              (gdk:with-default-display (display)
-               (apply wrapper args))))
+               (apply wrapper widget args))))
       wrapper)))
 
 
@@ -522,6 +521,11 @@ (defbinding widget-remove-mnemonic-label () nil
   (widget widget)
   (label widget))
 
+#?(pkg-exists-p "gtk+-2.0" :atleast-version "2.14.0")
+(defbinding widget-get-snapshot () gdk:pixmap
+  (widget widget)
+  (clip-rect (or null gdk:rectangle)))
+
 
 ;;; Additional bindings and functions