]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/DEVEL/lablgtk/lablgtk_20001129-0.1.0/ml_gtk.h
lablgtk_20001129* created
[helm.git] / helm / DEVEL / lablgtk / lablgtk_20001129-0.1.0 / ml_gtk.h
diff --git a/helm/DEVEL/lablgtk/lablgtk_20001129-0.1.0/ml_gtk.h b/helm/DEVEL/lablgtk/lablgtk_20001129-0.1.0/ml_gtk.h
new file mode 100644 (file)
index 0000000..eac3f6e
--- /dev/null
@@ -0,0 +1,24 @@
+/* $Id$ */
+
+#define GtkObject_val(obj) ((GtkObject*)Field(obj,1))
+value Val_GtkObject (GtkObject *w);
+value Val_GtkObject_sink (GtkObject *w);
+#define GtkAccelGroup_val(val) ((GtkAccelGroup*)Pointer_val(val))
+value Val_GtkAccelGroup (GtkAccelGroup *);
+#define GtkStyle_val(val) ((GtkStyle*)Pointer_val(val))
+value Val_GtkStyle (GtkStyle *);
+
+#define Val_GtkAny(w) Val_GtkObject((GtkObject*)w)
+#define Val_GtkAny_sink(w) Val_GtkObject_sink((GtkObject*)w)
+#define Val_GtkWidget Val_GtkAny
+#define Val_GtkWidget_sink Val_GtkAny_sink
+
+#ifdef GTK_NO_CHECK_CASTS
+#define check_cast(f,v) f(Pointer_val(v))
+#else
+#define check_cast(f,v) (Pointer_val(v) == NULL ? NULL : f(Pointer_val(v)))
+#endif
+
+#define GtkWidget_val(val) check_cast(GTK_WIDGET,val)
+#define GtkAdjustment_val(val) check_cast(GTK_ADJUSTMENT,val)
+#define GtkItem_val(val) check_cast(GTK_ITEM,val)