chiark / gitweb /
Work around for an unknown bug
[clg] / glib / ginterface.lisp
index 1882d351ab90c813221e3d436f4cff3c3b17671c..81b5cb46c0948d9f6bca0f53072706f7557b9136 100644 (file)
@@ -15,7 +15,7 @@
 ;; License along with this library; if not, write to the Free Software
 ;; Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
-;; $Id: ginterface.lisp,v 1.7 2005-02-03 23:09:04 espen Exp $
+;; $Id: ginterface.lisp,v 1.11 2005-03-11 19:13:05 espen Exp $
 
 (in-package "GLIB")
 
@@ -54,14 +54,16 @@ (defmethod compute-effective-slot-definition-initargs ((class ginterface-class)
     (call-next-method)))
 
 
-(defmethod shared-initialize ((class ginterface-class) names
-                             &rest initargs &key name alien-name)
-  (declare (ignore initargs names))
+(defmethod shared-initialize ((class ginterface-class) names &key name gtype)
+  (declare (ignore names))
   (let* ((class-name (or name (class-name class)))
         (type-number
-         (find-type-number
-          (or (first alien-name) (default-alien-type-name class-name)) t)))
-    (register-type class-name type-number))
+         (or
+          (find-type-number class-name)
+          (register-type class-name 
+           (or (first gtype) (default-type-init-name class-name))))))
+;    (type-default-interface-ref type-number)
+    )
   (call-next-method))
 
 
@@ -128,9 +130,10 @@ (defun query-object-interface-properties (type &optional inherited-p)
     (unwind-protect
         (multiple-value-bind (array length)
             (%object-interface-list-properties iface)
-          (unwind-protect
-               (%map-params array length type-number inherited-p)
-            (deallocate-memory array)))
+          (unless (null-pointer-p array)
+            (unwind-protect
+                (%map-params array length type-number inherited-p)
+              (deallocate-memory array))))
 ;      (type-default-interface-unref type-number)
       )))
 
@@ -143,9 +146,12 @@ (defun expand-ginterface-type (type forward-p options &rest args)
        ,(unless forward-p
          (slot-definitions class (query-object-interface-properties type) slots))
       (:metaclass ginterface-class)
-      (:alien-name ,(find-type-name type)))))
+      (:gtype ,(register-type-as type)))))
 
 (defun ginterface-dependencies (type)
-  (delete-duplicates (mapcar #'param-value-type (query-object-interface-properties type))))
+  (delete-duplicates 
+   (cons
+    (supertype type)
+    (mapcar #'param-value-type (query-object-interface-properties type)))))
 
 (register-derivable-type 'ginterface "GInterface" 'expand-ginterface-type 'ginterface-dependencies)