-/* $Id$ */
-
-#include <string.h>
-#include <gtk/gtk.h>
-#include <caml/mlvalues.h>
-#include <caml/alloc.h>
-#include <caml/memory.h>
-#include <caml/callback.h>
-#include <caml/fail.h>
-
-#include "wrappers.h"
-#include "ml_glib.h"
-#include "ml_gdk.h"
-#include "ml_gtk.h"
-#include "gtk_tags.h"
-
-void ml_raise_gtk (const char *errmsg)
-{
- static value * exn = NULL;
- if (exn == NULL)
- exn = caml_named_value ("gtkerror");
- raise_with_string (*exn, (char*)errmsg);
-}
-
-/* conversion functions */
-
-#include "gtk_tags.c"
-
-ML_1 (Val_direction_type, Int_val, Id)
-ML_1 (Val_orientation, Int_val, Id)
-ML_1 (Val_toolbar_style, Int_val, Id)
-ML_1 (Val_state_type, Int_val, Id)
-ML_1 (Val_scroll_type, Int_val, Id)
-
-static Make_Flags_val (Dest_defaults_val)
-static Make_Flags_val (Target_flags_val)
-static Make_Flags_val (Font_type_val)
-
-/* gtkobject.h */
-
-Make_Val_final_pointer(GtkObject, gtk_object_ref, gtk_object_unref, 0)
-
-#define gtk_object_ref_and_sink(w) (gtk_object_ref(w), gtk_object_sink(w))
-Make_Val_final_pointer_ext(GtkObject, _sink , gtk_object_ref_and_sink,
- gtk_object_unref, 20)
-
-/* gtkaccelgroup.h */
-
-Make_Val_final_pointer (GtkAccelGroup, gtk_accel_group_ref,
- gtk_accel_group_unref, 0)
-Make_Val_final_pointer_ext (GtkAccelGroup, _no_ref, Ignore,
- gtk_accel_group_unref, 20)
-Make_OptFlags_val (Accel_flag_val)
-
-#define Signal_name_val(val) String_val(Field(val,0))
-
-ML_0 (gtk_accel_group_new, Val_GtkAccelGroup_no_ref)
-ML_0 (gtk_accel_group_get_default, Val_GtkAccelGroup)
-ML_3 (gtk_accel_group_activate, GtkAccelGroup_val, Int_val,
- OptFlags_GdkModifier_val, Val_bool)
-ML_3 (gtk_accel_groups_activate, GtkObject_val, Int_val,
- OptFlags_GdkModifier_val, Val_bool)
-ML_2 (gtk_accel_group_attach, GtkAccelGroup_val, GtkObject_val, Unit)
-ML_2 (gtk_accel_group_detach, GtkAccelGroup_val, GtkObject_val, Unit)
-ML_1 (gtk_accel_group_lock, GtkAccelGroup_val, Unit)
-ML_1 (gtk_accel_group_unlock, GtkAccelGroup_val, Unit)
-ML_3 (gtk_accel_group_lock_entry, GtkAccelGroup_val, Int_val,
- OptFlags_GdkModifier_val, Unit)
-ML_3 (gtk_accel_group_unlock_entry, GtkAccelGroup_val, Int_val,
- OptFlags_GdkModifier_val, Unit)
-ML_6 (gtk_accel_group_add, GtkAccelGroup_val, Int_val,
- OptFlags_GdkModifier_val, OptFlags_Accel_flag_val,
- GtkObject_val, Signal_name_val, Unit)
-ML_bc6 (ml_gtk_accel_group_add)
-ML_4 (gtk_accel_group_remove, GtkAccelGroup_val, Int_val,
- OptFlags_GdkModifier_val, GtkObject_val, Unit)
-ML_2 (gtk_accelerator_valid, Int_val, OptFlags_GdkModifier_val, Val_bool)
-ML_1 (gtk_accelerator_set_default_mod_mask, OptFlags_GdkModifier_val, Unit)
-
-/* gtkstyle.h */
-
-Make_Val_final_pointer (GtkStyle, gtk_style_ref, gtk_style_unref, 0)
-Make_Val_final_pointer_ext (GtkStyle, _no_ref, Ignore, gtk_style_unref, 20)
-ML_0 (gtk_style_new, Val_GtkStyle_no_ref)
-ML_1 (gtk_style_copy, GtkStyle_val, Val_GtkStyle_no_ref)
-ML_2 (gtk_style_attach, GtkStyle_val, GdkWindow_val, Val_GtkStyle)
-ML_1 (gtk_style_detach, GtkStyle_val, Unit)
-ML_3 (gtk_style_set_background, GtkStyle_val, GdkWindow_val, State_type_val, Unit)
-ML_6 (gtk_draw_hline, GtkStyle_val, GdkWindow_val, State_type_val,
- Int_val, Int_val, Int_val, Unit)
-ML_bc6 (ml_gtk_draw_hline)
-ML_6 (gtk_draw_vline, GtkStyle_val, GdkWindow_val, State_type_val,
- Int_val, Int_val, Int_val, Unit)
-ML_bc6 (ml_gtk_draw_vline)
-Make_Array_Extractor (gtk_style_get, GtkStyle_val, State_type_val, bg, Val_copy)
-Make_Array_Setter (gtk_style_set, GtkStyle_val, State_type_val, *GdkColor_val, bg)
-Make_Extractor (gtk_style_get, GtkStyle_val, colormap, Val_GdkColormap)
-Make_Extractor (gtk_style_get, GtkStyle_val, depth, Val_int)
-Make_Extractor (gtk_style_get, GtkStyle_val, font, Val_GdkFont)
-/* Make_Setter (gtk_style_set, GtkStyle_val, GdkFont_val, font) */
-value ml_gtk_style_set_font (value st, value font)
-{
- GtkStyle *style = GtkStyle_val(st);
- if (style->font) gdk_font_unref(style->font);
- style->font = GdkFont_val(font);
- gdk_font_ref(style->font);
- return Val_unit;
-}
-Make_Array_Extractor (gtk_style_get, GtkStyle_val, State_type_val, dark_gc, Val_GdkGC)
-Make_Array_Extractor (gtk_style_get, GtkStyle_val, State_type_val, light_gc, Val_GdkGC)
-
-/* gtktypeutils.h */
-
-ML_1 (gtk_type_name, Int_val, Val_string)
-ML_1 (gtk_type_from_name, String_val, Val_int)
-ML_1 (gtk_type_parent, Int_val, Val_int)
-ML_1 (gtk_type_class, Int_val, (value))
-ML_1 (gtk_type_parent_class, Int_val, (value))
-ML_2 (gtk_type_is_a, Int_val, Int_val, Val_bool)
-value ml_gtk_type_fundamental (value type)
-{
- return Val_fundamental_type (GTK_FUNDAMENTAL_TYPE (Int_val(type)));
-}
-
-/* gtkobject.h */
-
-/* ML_1 (GTK_OBJECT_TYPE, GtkObject_val, Val_int) */
-value ml_gtk_object_type (value val)
-{
- return Val_int (GtkObject_val(val)->klass->type);
-}
-
-ML_1 (gtk_object_destroy, GtkObject_val, Unit)
-ML_1 (gtk_object_ref, GtkObject_val, Unit)
-ML_1 (gtk_object_unref, GtkObject_val, Unit)
-ML_1 (gtk_object_sink, GtkObject_val, Unit)
-
-Make_Extractor (gtk_class,(GtkObjectClass *),type,Val_int)
-
-/* gtkdata.h */
-
-/* gtkadjustment.h */
-
-ML_6 (gtk_adjustment_new, Float_val, Float_val, Float_val, Float_val,
- Float_val, Float_val, Val_GtkObject_sink)
-ML_bc6 (ml_gtk_adjustment_new)
-ML_2 (gtk_adjustment_set_value, GtkAdjustment_val, Float_val, Unit)
-ML_3 (gtk_adjustment_clamp_page, GtkAdjustment_val,
- Float_val, Float_val, Unit)
-Make_Extractor (gtk_adjustment_get, GtkAdjustment_val, lower, copy_double)
-Make_Extractor (gtk_adjustment_get, GtkAdjustment_val, upper, copy_double)
-Make_Extractor (gtk_adjustment_get, GtkAdjustment_val, value, copy_double)
-Make_Extractor (gtk_adjustment_get, GtkAdjustment_val, step_increment,
- copy_double)
-Make_Extractor (gtk_adjustment_get, GtkAdjustment_val, page_increment,
- copy_double)
-Make_Extractor (gtk_adjustment_get, GtkAdjustment_val, page_size, copy_double)
-
-/* gtktooltips.h */
-
-#define GtkTooltips_val(val) check_cast(GTK_TOOLTIPS,val)
-ML_0 (gtk_tooltips_new, Val_GtkAny)
-ML_1 (gtk_tooltips_enable, GtkTooltips_val, Unit)
-ML_1 (gtk_tooltips_disable, GtkTooltips_val, Unit)
-ML_2 (gtk_tooltips_set_delay, GtkTooltips_val, Int_val, Unit)
-ML_4 (gtk_tooltips_set_tip, GtkTooltips_val, GtkWidget_val,
- String_option_val, String_option_val, Unit)
-ML_3 (gtk_tooltips_set_colors, GtkTooltips_val,
- Option_val(arg2, GdkColor_val, NULL) Ignore,
- Option_val(arg3, GdkColor_val, NULL) Ignore,
- Unit)
-
-/* gtkwidget.h */
-
-value ml_gtk_widget_set_can_default (value val, value bool)
-{
- GtkWidget *w = GtkWidget_val(val);
- guint32 saved_flags = GTK_WIDGET_FLAGS(w);
- if (Bool_val(bool)) GTK_WIDGET_SET_FLAGS(w, GTK_CAN_DEFAULT);
- else GTK_WIDGET_UNSET_FLAGS(w, GTK_CAN_DEFAULT);
- if (saved_flags != GTK_WIDGET_FLAGS(w))
- gtk_widget_queue_resize (w);
- return Val_unit;
-}
-value ml_gtk_widget_set_can_focus (value val, value bool)
-{
- GtkWidget *w = GtkWidget_val(val);
- guint32 saved_flags = GTK_WIDGET_FLAGS(w);
- if (Bool_val(bool)) GTK_WIDGET_SET_FLAGS(w, GTK_CAN_FOCUS);
- else GTK_WIDGET_UNSET_FLAGS(w, GTK_CAN_FOCUS);
- if (saved_flags != GTK_WIDGET_FLAGS(w))
- gtk_widget_queue_resize (w);
- return Val_unit;
-}
-ML_1 (gtk_widget_unparent, GtkWidget_val, Unit)
-ML_1 (gtk_widget_show, GtkWidget_val, Unit)
-ML_1 (gtk_widget_show_now, GtkWidget_val, Unit)
-ML_1 (gtk_widget_show_all, GtkWidget_val, Unit)
-ML_1 (gtk_widget_hide, GtkWidget_val, Unit)
-ML_1 (gtk_widget_hide_all, GtkWidget_val, Unit)
-ML_1 (gtk_widget_map, GtkWidget_val, Unit)
-ML_1 (gtk_widget_unmap, GtkWidget_val, Unit)
-ML_1 (gtk_widget_realize, GtkWidget_val, Unit)
-ML_1 (gtk_widget_unrealize, GtkWidget_val, Unit)
-ML_1 (gtk_widget_queue_draw, GtkWidget_val, Unit)
-ML_1 (gtk_widget_queue_resize, GtkWidget_val, Unit)
-ML_2 (gtk_widget_draw, GtkWidget_val,
- Option_val(arg2,GdkRectangle_val,NULL) Ignore, Unit)
-ML_1 (gtk_widget_draw_focus, GtkWidget_val, Unit)
-ML_1 (gtk_widget_draw_default, GtkWidget_val, Unit)
-/* ML_1 (gtk_widget_draw_children, GtkWidget_val, Unit) */
-ML_2 (gtk_widget_event, GtkWidget_val, GdkEvent_val, Val_bool)
-ML_1 (gtk_widget_activate, GtkWidget_val, Val_bool)
-ML_2 (gtk_widget_reparent, GtkWidget_val, GtkWidget_val, Unit)
-ML_3 (gtk_widget_popup, GtkWidget_val, Int_val, Int_val, Unit)
-value ml_gtk_widget_intersect (value w, value area)
-{
- GdkRectangle inter;
- if (gtk_widget_intersect(GtkWidget_val(w), GdkRectangle_val(area), &inter))
- return ml_some (Val_copy (inter));
- return Val_unit;
-}
-/* ML_1 (gtk_widget_basic, GtkWidget_val, Val_bool) */
-ML_1 (gtk_widget_grab_focus, GtkWidget_val, Unit)
-ML_1 (gtk_widget_grab_default, GtkWidget_val, Unit)
-ML_2 (gtk_widget_set_name, GtkWidget_val, String_val, Unit)
-ML_1 (gtk_widget_get_name, GtkWidget_val, Val_string)
-ML_2 (gtk_widget_set_state, GtkWidget_val, State_type_val, Unit)
-ML_2 (gtk_widget_set_sensitive, GtkWidget_val, Bool_val, Unit)
-ML_3 (gtk_widget_set_uposition, GtkWidget_val, Int_val, Int_val, Unit)
-ML_3 (gtk_widget_set_usize, GtkWidget_val, Int_val, Int_val, Unit)
-ML_2 (gtk_widget_add_events, GtkWidget_val, Flags_Event_mask_val, Unit)
-ML_2 (gtk_widget_set_events, GtkWidget_val, Flags_Event_mask_val, Unit)
-ML_2 (gtk_widget_set_extension_events, GtkWidget_val, Extension_events_val,
- Unit)
-ML_1 (gtk_widget_get_toplevel, GtkWidget_val, Val_GtkWidget)
-ML_2 (gtk_widget_get_ancestor, GtkWidget_val, Int_val, Val_GtkWidget)
-ML_1 (gtk_widget_get_colormap, GtkWidget_val, Val_GdkColormap)
-ML_1 (gtk_widget_get_visual, GtkWidget_val, (value))
-value ml_gtk_widget_get_pointer (value w)
-{
- int x,y;
- value ret;
- gtk_widget_get_pointer (GtkWidget_val(w), &x, &y);
- ret = alloc_small (2,0);
- Field(ret,0) = Val_int(x);
- Field(ret,1) = Val_int(y);
- return ret;
-}
-ML_2 (gtk_widget_is_ancestor, GtkWidget_val, GtkWidget_val, Val_bool)
-/* ML_2 (gtk_widget_is_child, GtkWidget_val, GtkWidget_val, Val_bool) */
-ML_2 (gtk_widget_set_style, GtkWidget_val, GtkStyle_val, Unit)
-ML_1 (gtk_widget_set_rc_style, GtkWidget_val, Unit)
-ML_1 (gtk_widget_ensure_style, GtkWidget_val, Unit)
-ML_1 (gtk_widget_get_style, GtkWidget_val, Val_GtkStyle)
-ML_1 (gtk_widget_restore_default_style, GtkWidget_val, Unit)
-
-ML_6 (gtk_widget_add_accelerator, GtkWidget_val, Signal_name_val,
- GtkAccelGroup_val, Char_val, OptFlags_GdkModifier_val,
- OptFlags_Accel_flag_val, Unit)
-ML_bc6 (ml_gtk_widget_add_accelerator)
-ML_4 (gtk_widget_remove_accelerator, GtkWidget_val, GtkAccelGroup_val,
- Char_val, OptFlags_GdkModifier_val, Unit)
-ML_1 (gtk_widget_lock_accelerators, GtkWidget_val, Unit)
-ML_1 (gtk_widget_unlock_accelerators, GtkWidget_val, Unit)
-ML_1 (gtk_widget_accelerators_locked, GtkWidget_val, Val_bool)
-
-ML_1 (GTK_WIDGET_VISIBLE, GtkWidget_val, Val_bool)
-ML_1 (GTK_WIDGET_HAS_FOCUS, GtkWidget_val, Val_bool)
-
-Make_Extractor (GtkWidget, GtkWidget_val, window, Val_GdkWindow)
-Make_Extractor (gtk_widget, GtkWidget_val, parent, Val_GtkWidget)
-static value Val_GtkAllocation (GtkAllocation allocation)
-{
- value ret = alloc_small (4, 0);
- Field(ret,0) = Val_int(allocation.x);
- Field(ret,1) = Val_int(allocation.y);
- Field(ret,2) = Val_int(allocation.width);
- Field(ret,3) = Val_int(allocation.height);
- return ret;
-}
-Make_Extractor (gtk_widget, GtkWidget_val, allocation, Val_GtkAllocation)
-/*
-#define GtkAllocation_val(val) ((GtkAllocation*)Pointer_val(val))
-Make_Extractor (gtk_allocation, GtkAllocation_val, x, Val_int)
-Make_Extractor (gtk_allocation, GtkAllocation_val, y, Val_int)
-Make_Extractor (gtk_allocation, GtkAllocation_val, width, Val_int)
-Make_Extractor (gtk_allocation, GtkAllocation_val, height, Val_int)
-*/
-
-ML_2 (gtk_widget_set_app_paintable, GtkWidget_val, Bool_val, Unit)
-
-ML_2 (gtk_widget_set_visual, GtkWidget_val, GdkVisual_val, Unit)
-ML_2 (gtk_widget_set_colormap, GtkWidget_val, GdkColormap_val, Unit)
-ML_1 (gtk_widget_set_default_visual, GdkVisual_val, Unit)
-ML_1 (gtk_widget_set_default_colormap, GdkColormap_val, Unit)
-ML_0 (gtk_widget_get_default_visual, Val_GdkVisual)
-ML_0 (gtk_widget_get_default_colormap, Val_GdkColormap)
-ML_1 (gtk_widget_push_visual, GdkVisual_val, Unit)
-ML_1 (gtk_widget_push_colormap, GdkColormap_val, Unit)
-ML_0 (gtk_widget_pop_visual, Unit)
-ML_0 (gtk_widget_pop_colormap, Unit)
-
-/* gtkdnd.h */
-
-value ml_gtk_drag_dest_set (value w, value f, value t, value a)
-{
- GtkTargetEntry *targets = (GtkTargetEntry *)Val_unit;
- int n_targets, i;
-
- CAMLparam4 (w,f,t,a);
- n_targets = Wosize_val(t);
- if (n_targets)
- targets = (GtkTargetEntry *)
- alloc (Wosize_asize(n_targets * sizeof(GtkTargetEntry)),
- Abstract_tag);
- for (i=0; i<n_targets; i++) {
- targets[i].target = String_val(Field(Field(t, i), 0));
- targets[i].flags = Flags_Target_flags_val(Field(Field(t, i), 1));
- targets[i].info = Int_val(Field(Field(t, i), 2));
- }
- gtk_drag_dest_set (GtkWidget_val(w), Flags_Dest_defaults_val(f),
- targets, n_targets, Flags_GdkDragAction_val(a));
- CAMLreturn(Val_unit);
-}
-ML_1 (gtk_drag_dest_unset, GtkWidget_val, Unit)
-ML_4 (gtk_drag_finish, GdkDragContext_val, Bool_val, Bool_val, Int_val, Unit)
-ML_4 (gtk_drag_get_data, GtkWidget_val, GdkDragContext_val, Int_val, Int_val, Unit)
-ML_1 (gtk_drag_get_source_widget, GdkDragContext_val, Val_GtkWidget)
-ML_1 (gtk_drag_highlight, GtkWidget_val, Unit)
-ML_1 (gtk_drag_unhighlight, GtkWidget_val, Unit)
-ML_4 (gtk_drag_set_icon_widget, GdkDragContext_val, GtkWidget_val,
- Int_val, Int_val, Unit)
-ML_6 (gtk_drag_set_icon_pixmap, GdkDragContext_val, GdkColormap_val,
- GdkPixmap_val, Option_val(arg4, GdkBitmap_val, NULL) Ignore,
- Int_val, Int_val, Unit)
-ML_bc6 (ml_gtk_drag_set_icon_pixmap)
-ML_1 (gtk_drag_set_icon_default, GdkDragContext_val, Unit)
-ML_5 (gtk_drag_set_default_icon, GdkColormap_val,
- GdkPixmap_val, Option_val(arg3, GdkBitmap_val, NULL) Ignore,
- Int_val, Int_val, Unit)
-value ml_gtk_drag_source_set (value w, value m, value t, value a)
-{
- GtkTargetEntry *targets = (GtkTargetEntry *)Val_unit;
- int n_targets, i;
- CAMLparam4 (w,m,t,a);
-
- n_targets = Wosize_val(t);
- if (n_targets)
- targets = (GtkTargetEntry *)
- alloc (Wosize_asize(n_targets * sizeof(GtkTargetEntry)),
- Abstract_tag);
- for (i=0; i<n_targets; i++) {
- targets[i].target = String_val(Field(Field(t, i), 0));
- targets[i].flags = Flags_Target_flags_val(Field(Field(t, i), 1));
- targets[i].info = Int_val(Field(Field(t, i), 2));
- }
- gtk_drag_source_set (GtkWidget_val(w), OptFlags_GdkModifier_val(m),
- targets, n_targets, Flags_GdkDragAction_val(a));
- CAMLreturn(Val_unit);
-}
-ML_4 (gtk_drag_source_set_icon, GtkWidget_val, GdkColormap_val,
- GdkPixmap_val, Option_val(arg4, GdkBitmap_val, NULL) Ignore, Unit)
-ML_1 (gtk_drag_source_unset, GtkWidget_val, Unit)
-
-/* gtkwidget.h / gtkselection.h */
-
-#define GtkSelectionData_val(val) ((GtkSelectionData *)Pointer_val(val))
-
-Make_Extractor (gtk_selection_data, GtkSelectionData_val, selection, Val_int)
-Make_Extractor (gtk_selection_data, GtkSelectionData_val, target, Val_int)
-Make_Extractor (gtk_selection_data, GtkSelectionData_val, type, Val_int)
-Make_Extractor (gtk_selection_data, GtkSelectionData_val, format, Val_int)
-value ml_gtk_selection_data_get_data (value val)
-{
- value ret;
- GtkSelectionData *data = GtkSelectionData_val(val);
-
- if (data->length < 0) ml_raise_null_pointer();
- ret = alloc_string (data->length);
- if (data->length) memcpy ((void*)ret, data->data, data->length);
- return ret;
-}
-
-ML_4 (gtk_selection_data_set, GtkSelectionData_val, Int_val, Int_val,
- Insert((guchar*)String_option_val(arg4))
- Option_val(arg4, string_length, -1) Ignore,
- Unit)
-
-/* gtkcontainer.h */
-
-#define GtkContainer_val(val) check_cast(GTK_CONTAINER,val)
-ML_2 (gtk_container_set_border_width, GtkContainer_val, Int_val, Unit)
-ML_2 (gtk_container_set_resize_mode, GtkContainer_val, Resize_mode_val, Unit)
-ML_2 (gtk_container_add, GtkContainer_val, GtkWidget_val, Unit)
-ML_2 (gtk_container_remove, GtkContainer_val, GtkWidget_val, Unit)
-static void ml_gtk_simple_callback (GtkWidget *w, gpointer data)
-{
- value val, *clos = (value*)data;
- val = Val_GtkWidget(w);
- callback (*clos, val);
-}
-value ml_gtk_container_foreach (value w, value clos)
-{
- CAMLparam1(clos);
- gtk_container_foreach (GtkContainer_val(w), ml_gtk_simple_callback,
- &clos);
- CAMLreturn(Val_unit);
-}
-ML_1 (gtk_container_register_toplevel, GtkContainer_val, Unit)
-ML_1 (gtk_container_unregister_toplevel, GtkContainer_val, Unit)
-ML_2 (gtk_container_focus, GtkContainer_val, Direction_type_val, Val_bool)
-ML_2 (gtk_container_set_focus_child, GtkContainer_val, GtkWidget_val, Unit)
-ML_2 (gtk_container_set_focus_vadjustment, GtkContainer_val,
- GtkAdjustment_val, Unit)
-ML_2 (gtk_container_set_focus_hadjustment, GtkContainer_val,
- GtkAdjustment_val, Unit)
-
-/* gtkdialog.h */
-
-static void window_unref (GtkObject *w)
-{
- /* If the window exists and is still not visible, then unreference twice.
- This should be enough to destroy it. */
- if (!GTK_OBJECT_DESTROYED(w) && !GTK_WIDGET_VISIBLE(w))
- gtk_object_unref (w);
- gtk_object_unref (w);
-}
-Make_Val_final_pointer_ext (GtkObject, _window, gtk_object_ref, window_unref,
- 20)
-#define Val_GtkWidget_window(w) Val_GtkObject_window((GtkObject*)w)
-
-#define GtkDialog_val(val) check_cast(GTK_DIALOG,val)
-ML_0 (gtk_dialog_new, Val_GtkWidget_window)
-Make_Extractor (GtkDialog, GtkDialog_val, action_area, Val_GtkWidget)
-Make_Extractor (GtkDialog, GtkDialog_val, vbox, Val_GtkWidget)
-
-/* gtkinputdialog.h */
-
-ML_0 (gtk_input_dialog_new, Val_GtkWidget_window)
-
-/* gtkfileselection.h */
-
-#define GtkFileSelection_val(val) check_cast(GTK_FILE_SELECTION,val)
-ML_1 (gtk_file_selection_new, String_val, Val_GtkWidget_window)
-ML_2 (gtk_file_selection_set_filename, GtkFileSelection_val, String_val, Unit)
-ML_1 (gtk_file_selection_get_filename, GtkFileSelection_val, Val_string)
-ML_1 (gtk_file_selection_show_fileop_buttons, GtkFileSelection_val, Unit)
-ML_1 (gtk_file_selection_hide_fileop_buttons, GtkFileSelection_val, Unit)
-Make_Extractor (gtk_file_selection_get, GtkFileSelection_val, ok_button,
- Val_GtkWidget)
-Make_Extractor (gtk_file_selection_get, GtkFileSelection_val, cancel_button,
- Val_GtkWidget)
-Make_Extractor (gtk_file_selection_get, GtkFileSelection_val, help_button,
- Val_GtkWidget)
-
-/* gtkwindow.h */
-
-#define GtkWindow_val(val) check_cast(GTK_WINDOW,val)
-ML_1 (gtk_window_new, Window_type_val, Val_GtkWidget_window)
-ML_2 (gtk_window_set_title, GtkWindow_val, String_val, Unit)
-ML_3 (gtk_window_set_wmclass, GtkWindow_val, String_val, String_val, Unit)
-Make_Extractor (gtk_window_get, GtkWindow_val, wmclass_name, Val_optstring)
-Make_Extractor (gtk_window_get, GtkWindow_val, wmclass_class, Val_optstring)
-ML_2 (gtk_window_set_focus, GtkWindow_val, GtkWidget_val, Unit)
-ML_2 (gtk_window_set_default, GtkWindow_val, GtkWidget_val, Unit)
-ML_4 (gtk_window_set_policy, GtkWindow_val, Bool_val, Bool_val, Bool_val, Unit)
-Make_Extractor (gtk_window_get, GtkWindow_val, allow_shrink, Val_bool)
-Make_Extractor (gtk_window_get, GtkWindow_val, allow_grow, Val_bool)
-Make_Extractor (gtk_window_get, GtkWindow_val, auto_shrink, Val_bool)
-ML_2 (gtk_window_add_accel_group, GtkWindow_val,
- GtkAccelGroup_val, Unit)
-ML_2 (gtk_window_remove_accel_group, GtkWindow_val,
- GtkAccelGroup_val, Unit)
-ML_1 (gtk_window_activate_focus, GtkWindow_val, Val_bool)
-ML_1 (gtk_window_activate_default, GtkWindow_val, Val_bool)
-ML_2 (gtk_window_set_modal, GtkWindow_val, Bool_val, Unit)
-ML_3 (gtk_window_set_default_size, GtkWindow_val, Int_val, Int_val, Unit)
-ML_2 (gtk_window_set_position, GtkWindow_val, Window_position_val, Unit)
-ML_2 (gtk_window_set_transient_for, GtkWindow_val, GtkWindow_val, Unit)
-
-/* gtkcolorsel.h */
-
-#define GtkColorSelection_val(val) check_cast(GTK_COLOR_SELECTION,val)
-#define GtkColorSelectionDialog_val(val) check_cast(GTK_COLOR_SELECTION_DIALOG,val)
-ML_0 (gtk_color_selection_new, Val_GtkWidget_sink)
-ML_2 (gtk_color_selection_set_update_policy, GtkColorSelection_val,
- Update_type_val, Unit)
-ML_2 (gtk_color_selection_set_opacity, GtkColorSelection_val,
- Bool_val, Unit)
-value ml_gtk_color_selection_set_color (value w, value red, value green,
- value blue, value opacity)
-{
- double color[4];
- color[0] = Double_val(red);
- color[1] = Double_val(green);
- color[2] = Double_val(blue);
- color[3] = Option_val(opacity,Double_val,0.0);
- gtk_color_selection_set_color (GtkColorSelection_val(w), color);
- return Val_unit;
-}
-value ml_gtk_color_selection_get_color (value w)
-{
- value ret;
- double color[4];
- color[3] = 0.0;
- gtk_color_selection_get_color (GtkColorSelection_val(w), color);
- ret = alloc (4*Double_wosize, Double_array_tag);
- Store_double_field (ret, 0, color[0]);
- Store_double_field (ret, 1, color[1]);
- Store_double_field (ret, 2, color[2]);
- Store_double_field (ret, 3, color[3]);
- return ret;
-}
-ML_1 (gtk_color_selection_dialog_new, String_val, Val_GtkWidget_window)
-Make_Extractor (gtk_color_selection_dialog, GtkColorSelectionDialog_val, ok_button, Val_GtkWidget)
-Make_Extractor (gtk_color_selection_dialog, GtkColorSelectionDialog_val, cancel_button, Val_GtkWidget)
-Make_Extractor (gtk_color_selection_dialog, GtkColorSelectionDialog_val, help_button, Val_GtkWidget)
-Make_Extractor (gtk_color_selection_dialog, GtkColorSelectionDialog_val, colorsel, Val_GtkWidget)
-
-/* gtkfontsel.h */
-
-#define GtkFontSelection_val(val) \
- check_cast(GTK_FONT_SELECTION,val)
-ML_0 (gtk_font_selection_new, Val_GtkWidget_sink)
-ML_1 (gtk_font_selection_get_font, GtkFontSelection_val,
- Val_GdkFont)
-ML_1 (gtk_font_selection_get_font_name, GtkFontSelection_val,
- copy_string_check)
-ML_2 (gtk_font_selection_set_font_name, GtkFontSelection_val,
- String_val, Val_bool)
-ML_9 (gtk_font_selection_set_filter, GtkFontSelection_val,
- Font_filter_type_val, Flags_Font_type_val,
- (gchar**), (gchar**), (gchar**),
- (gchar**), (gchar**), (gchar**), Unit)
-ML_bc9 (ml_gtk_font_selection_set_filter)
-ML_1 (gtk_font_selection_get_preview_text, GtkFontSelection_val,
- copy_string)
-ML_2 (gtk_font_selection_set_preview_text, GtkFontSelection_val,
- String_val, Unit)
-
-#define GtkFontSelectionDialog_val(val) \
- check_cast(GTK_FONT_SELECTION_DIALOG,val)
-ML_1 (gtk_font_selection_dialog_new, String_option_val, Val_GtkWidget_window)
-/*
-ML_1 (gtk_font_selection_dialog_get_font, GtkFontSelectionDialog_val,
- Val_GdkFont)
-ML_1 (gtk_font_selection_dialog_get_font_name, GtkFontSelectionDialog_val,
- copy_string_check)
-ML_2 (gtk_font_selection_dialog_set_font_name, GtkFontSelectionDialog_val,
- String_val, Val_bool)
-ML_9 (gtk_font_selection_dialog_set_filter, GtkFontSelectionDialog_val,
- Font_filter_type_val, Flags_Font_type_val,
- (gchar**), (gchar**), (gchar**),
- (gchar**), (gchar**), (gchar**), Unit)
-ML_bc9 (ml_gtk_font_selection_dialog_set_filter)
-ML_1 (gtk_font_selection_dialog_get_preview_text, GtkFontSelectionDialog_val,
- copy_string)
-ML_2 (gtk_font_selection_dialog_set_preview_text, GtkFontSelectionDialog_val,
- String_val, Unit)
-*/
-Make_Extractor (gtk_font_selection_dialog, GtkFontSelectionDialog_val,
- fontsel, Val_GtkWidget)
-Make_Extractor (gtk_font_selection_dialog, GtkFontSelectionDialog_val,
- ok_button, Val_GtkWidget)
-Make_Extractor (gtk_font_selection_dialog, GtkFontSelectionDialog_val,
- apply_button, Val_GtkWidget)
-Make_Extractor (gtk_font_selection_dialog, GtkFontSelectionDialog_val,
- cancel_button, Val_GtkWidget)
-
-/* gtkplug.h */
-
-ML_1 (gtk_plug_new, XID_val, Val_GtkWidget_window)
-
-/* gtkctree.h */
-#define GtkCTree_val(val) check_cast(GTK_CTREE,val)
-/* Beware: this definition axpects arg1 to be a GtkCTree */
-/*
-#define GtkCTreeNode_val(val) \
- (gtk_ctree_find(GtkCTree_val(arg1),NULL,(GtkCTreeNode*)(val-1)) \
- ? (GtkCTreeNode*)(val-1) : (ml_raise_gtk ("Bad GtkCTreeNode"), NULL))
-#define Val_GtkCTreeNode Val_addr
-ML_2 (gtk_ctree_new, Int_val, Int_val, Val_GtkWidget_sink)
-ML_3 (gtk_ctree_new_with_titles, Int_val, Int_val, (char **),
- Val_GtkWidget_sink)
-ML_11 (gtk_ctree_insert_node, GtkCTree_val, GtkCTreeNode_val,
- GtkCTreeNode_val, (char**), Int_val, GdkPixmap_val, GdkBitmap_val,
- GdkPixmap_val, GdkBitmap_val, Bool_val, Bool_val,
- Val_GtkCTreeNode)
-ML_2 (gtk_ctree_remove_node, GtkCTree_val, GtkCTreeNode_val, Unit)
-ML_2 (gtk_ctree_is_viewable, GtkCTree_val, GtkCTreeNode_val, Val_bool)
-*/
-
-/* gtkpreview.h */
-/*
-#define GtkPreview_val(val) GTK_PREVIEW(Pointer_val(val))
-ML_1 (gtk_preview_new, Preview_val, Val_GtkWidget_sink)
-ML_3 (gtk_preview_size, GtkPreview_val, Int_val, Int_val, Unit)
-ML_9 (gtk_preview_put, GtkPreview_val, GdkWindow_val, GdkGC_val,
- Int_val, Int_val, Int_val, Int_val, Int_val, Int_val, Unit)
-ML_bc9 (ml_gtk_preview_put)
-*/
-
-/* gtkmain.h */
-
-value ml_gtk_init (value argv)
-{
- CAMLparam1 (argv);
- int argc = Wosize_val(argv), i;
- CAMLlocal1 (copy);
-
- copy = (argc ? alloc (argc, Abstract_tag) : Atom(0));
- for (i = 0; i < argc; i++) Field(copy,i) = Field(argv,i);
- gtk_init (&argc, (char ***)©);
-
- argv = (argc ? alloc (argc, 0) : Atom(0));
- for (i = 0; i < argc; i++) modify(&Field(argv,i), Field(copy,i));
- CAMLreturn (argv);
-}
-ML_1 (gtk_exit, Int_val, Unit)
-ML_0 (gtk_set_locale, Val_string)
-ML_0 (gtk_main, Unit)
-ML_1 (gtk_main_iteration_do, Bool_val, Val_bool)
-ML_0 (gtk_main_quit, Unit)
-ML_1 (gtk_grab_add, GtkWidget_val, Unit)
-ML_1 (gtk_grab_remove, GtkWidget_val, Unit)
-ML_0 (gtk_grab_get_current, Val_GtkWidget)
-value ml_gtk_get_version (value unit)
-{
- value ret = alloc_small(3,0);
- Field(ret,0) = Val_int(gtk_major_version);
- Field(ret,1) = Val_int(gtk_minor_version);
- Field(ret,2) = Val_int(gtk_micro_version);
- return ret;
-}
-
-/* Marshalling */
-
-void ml_gtk_callback_marshal (GtkObject *object, gpointer data,
- guint nargs, GtkArg *args)
-{
- value vargs = alloc_small(3,0);
-
- CAMLparam1 (vargs);
- Field(vargs,0) = (value) object;
- Field(vargs,1) = Val_int(nargs);
- Field(vargs,2) = (value) args;
-
- callback (*(value*)data, vargs);
-
- Field(vargs,0) = Val_int(-1);
- Field(vargs,1) = Val_int(-1);
- CAMLreturn0;
-}
-
-value ml_gtk_arg_shift (GtkArg *args, value index)
-{
- return (value) (&args[Int_val(index)]);
-}
-
-value ml_gtk_arg_get_type (GtkArg *arg)
-{
- return Val_int (arg->type);
-}
-
-value ml_gtk_arg_get (GtkArg *arg)
-{
- CAMLparam0();
- CAMLlocal1(tmp);
- value ret = Val_unit;
- GtkFundamentalType type = GTK_FUNDAMENTAL_TYPE(arg->type);
- int tag;
-
- switch (type) {
- case GTK_TYPE_CHAR:
- tag = 0;
- tmp = Int_val(GTK_VALUE_CHAR(*arg));
- break;
- case GTK_TYPE_BOOL:
- tag = 1;
- tmp = Val_bool(GTK_VALUE_BOOL(*arg));
- break;
- case GTK_TYPE_INT:
- case GTK_TYPE_ENUM:
- case GTK_TYPE_UINT:
- case GTK_TYPE_FLAGS:
- tag = 2;
- tmp = Val_int (GTK_VALUE_INT(*arg)); break;
- case GTK_TYPE_LONG:
- case GTK_TYPE_ULONG:
- tag = 2;
- tmp = Val_int (GTK_VALUE_LONG(*arg)); break;
- case GTK_TYPE_FLOAT:
- tag = 3;
- tmp = copy_double ((double)GTK_VALUE_FLOAT(*arg)); break;
- case GTK_TYPE_DOUBLE:
- tag = 3;
- tmp = copy_double (GTK_VALUE_DOUBLE(*arg)); break;
- case GTK_TYPE_STRING:
- tag = 4;
- tmp = Val_option (GTK_VALUE_STRING(*arg), copy_string); break;
- case GTK_TYPE_OBJECT:
- tag = 5;
- tmp = Val_option (GTK_VALUE_OBJECT(*arg), Val_GtkObject); break;
- case GTK_TYPE_BOXED:
- case GTK_TYPE_POINTER:
- tag = 6;
- tmp = Val_option (GTK_VALUE_POINTER(*arg), Val_pointer); break;
- default:
- tag = -1;
- }
- if (tag != -1) {
- ret = alloc_small(1,tag);
- Field(ret,0) = tmp;
- }
- CAMLreturn(ret);
-}
-
-value ml_gtk_arg_set_retloc (GtkArg *arg, value val)
-{
- value type = Fundamental_type_val(Is_block(val) ? Field(val,0) : val);
- value data = (Is_block(val) ? Field(val,1) : 0);
- if (GTK_FUNDAMENTAL_TYPE(arg->type) != GTK_TYPE_POINTER
- && GTK_FUNDAMENTAL_TYPE(arg->type) != type)
- ml_raise_gtk ("GtkArgv.Arg.set : argument type mismatch");
- switch (type) {
- case GTK_TYPE_CHAR: *GTK_RETLOC_CHAR(*arg) = Int_val(data); break;
- case GTK_TYPE_BOOL: *GTK_RETLOC_BOOL(*arg) = Int_val(data); break;
- case GTK_TYPE_INT:
- case GTK_TYPE_ENUM: *GTK_RETLOC_INT(*arg) = Int_val(data); break;
- case GTK_TYPE_UINT:
- case GTK_TYPE_FLAGS: *GTK_RETLOC_UINT(*arg) = Int32_val(data); break;
- case GTK_TYPE_LONG:
- case GTK_TYPE_ULONG: *GTK_RETLOC_LONG(*arg) = Nativeint_val(data); break;
- case GTK_TYPE_FLOAT: *GTK_RETLOC_FLOAT(*arg) = Float_val(data); break;
- case GTK_TYPE_DOUBLE: *GTK_RETLOC_DOUBLE(*arg) = Double_val(data); break;
- case GTK_TYPE_STRING:
- *GTK_RETLOC_STRING(*arg) = Option_val(data, String_val, NULL);
- break;
- case GTK_TYPE_BOXED:
- case GTK_TYPE_POINTER:
- case GTK_TYPE_OBJECT:
- *GTK_RETLOC_POINTER(*arg) = Option_val(data, Pointer_val, NULL);
- break;
- }
- return Val_unit;
-}
-
-/*
-value ml_gtk_arg_get_char (GtkArg *arg)
-{
- if (GTK_FUNDAMENTAL_TYPE(arg->type) != GTK_TYPE_CHAR)
- ml_raise_gtk ("argument type mismatch");
- return Val_char (GTK_VALUE_CHAR(*arg));
-}
-
-value ml_gtk_arg_get_bool (GtkArg *arg)
-{
- if (GTK_FUNDAMENTAL_TYPE(arg->type) != GTK_TYPE_BOOL)
- ml_raise_gtk ("argument type mismatch");
- return Val_bool (GTK_VALUE_BOOL(*arg));
-}
-
-value ml_gtk_arg_get_int (GtkArg *arg)
-{
- switch (GTK_FUNDAMENTAL_TYPE(arg->type)) {
- case GTK_TYPE_INT:
- case GTK_TYPE_UINT:
- return Val_int (GTK_VALUE_INT(*arg));
- case GTK_TYPE_LONG:
- case GTK_TYPE_ULONG:
- return Val_long (GTK_VALUE_LONG(*arg));
- case GTK_TYPE_ENUM:
- return Val_int (GTK_VALUE_ENUM(*arg));
- case GTK_TYPE_FLAGS:
- return Val_int (GTK_VALUE_FLAGS(*arg));
- default:
- ml_raise_gtk ("argument type mismatch");
- }
- return Val_unit;
-}
-*/
-value ml_gtk_arg_get_nativeint(GtkArg *arg) {
-
- switch(GTK_FUNDAMENTAL_TYPE(arg->type)) {
- case GTK_TYPE_INT:
- case GTK_TYPE_UINT:
- return copy_nativeint (GTK_VALUE_INT(*arg));
- case GTK_TYPE_LONG:
- case GTK_TYPE_ULONG:
- return copy_nativeint (GTK_VALUE_LONG(*arg));
- case GTK_TYPE_ENUM:
- return copy_nativeint (GTK_VALUE_ENUM(*arg));
- case GTK_TYPE_FLAGS:
- return copy_nativeint (GTK_VALUE_FLAGS(*arg));
- default:
- ml_raise_gtk ("argument type mismatch");
- }
- return Val_unit;
-}
-/*
-value ml_gtk_arg_get_float (GtkArg *arg)
-{
- switch (GTK_FUNDAMENTAL_TYPE(arg->type)) {
- case GTK_TYPE_FLOAT:
- return copy_double ((double)GTK_VALUE_FLOAT(*arg));
- case GTK_TYPE_DOUBLE:
- return copy_double (GTK_VALUE_DOUBLE(*arg));
- default:
- ml_raise_gtk ("argument type mismatch");
- }
- return Val_unit;
-}
-
-value ml_gtk_arg_get_string (GtkArg *arg)
-{
- char *p;
- if (GTK_FUNDAMENTAL_TYPE(arg->type) != GTK_TYPE_STRING)
- ml_raise_gtk ("argument type mismatch");
- p = GTK_VALUE_STRING(*arg);
- return Val_option (p, copy_string);
-}
-*/
-value ml_gtk_arg_get_pointer (GtkArg *arg)
-{
- gpointer p = NULL;
- switch (GTK_FUNDAMENTAL_TYPE(arg->type)) {
- case GTK_TYPE_STRING:
- case GTK_TYPE_BOXED:
- case GTK_TYPE_POINTER:
- case GTK_TYPE_OBJECT:
- p = GTK_VALUE_POINTER(*arg); break;
- default:
- ml_raise_gtk ("GtkArgv.get_pointer : argument type mismatch");
- }
- return Val_pointer(p);
-}
-/*
-value ml_gtk_arg_get_object (GtkArg *arg)
-{
- GtkObject *p;
- if (GTK_FUNDAMENTAL_TYPE(arg->type) != GTK_TYPE_OBJECT)
- ml_raise_gtk ("argument type mismatch");
- p = GTK_VALUE_OBJECT(*arg);
- return Val_option (p, Val_GtkObject);
-}
-*/
-
-value ml_string_at_pointer (value ofs, value len, value ptr)
-{
- char *start = ((char*)Pointer_val(ptr)) + Option_val(ofs, Int_val, 0);
- int length = Option_val(len, Int_val, strlen(start));
- value ret = alloc_string(length);
- memcpy ((char*)ret, start, length);
- return ret;
-}
-
-value ml_int_at_pointer (value ptr)
-{
- return Val_int(*(int*)Pointer_val(ptr));
-}
-
-/*
-value ml_gtk_arg_set_char (GtkArg *arg, value val)
-{
- switch (GTK_FUNDAMENTAL_TYPE(arg->type)) {
- case GTK_TYPE_POINTER:
- case GTK_TYPE_CHAR:
- *GTK_RETLOC_CHAR(*arg) = Char_val(val); break;
- default:
- ml_raise_gtk ("argument type mismatch");
- }
- return Val_unit;
-}
-
-value ml_gtk_arg_set_bool (GtkArg *arg, value val)
-{
- switch (GTK_FUNDAMENTAL_TYPE(arg->type)) {
- case GTK_TYPE_POINTER:
- case GTK_TYPE_BOOL:
- *GTK_RETLOC_BOOL(*arg) = Bool_val(val); break;
- default:
- ml_raise_gtk ("argument type mismatch");
- }
- return Val_unit;
-}
-
-value ml_gtk_arg_set_int (GtkArg *arg, value val)
-{
- switch (GTK_FUNDAMENTAL_TYPE(arg->type)) {
- case GTK_TYPE_POINTER:
- case GTK_TYPE_INT:
- case GTK_TYPE_UINT:
- *GTK_RETLOC_INT(*arg) = Int_val(val); break;
- case GTK_TYPE_LONG:
- case GTK_TYPE_ULONG:
- *GTK_RETLOC_LONG(*arg) = Long_val(val); break;
- case GTK_TYPE_ENUM:
- *GTK_RETLOC_ENUM(*arg) = Int_val(val); break;
- case GTK_TYPE_FLAGS:
- *GTK_RETLOC_FLAGS(*arg) = Int_val(val); break;
- default:
- ml_raise_gtk ("argument type mismatch");
- }
- return Val_unit;
-}
-
-value ml_gtk_arg_set_nativeint (GtkArg *arg, value val)
-{
- switch (GTK_FUNDAMENTAL_TYPE(arg->type)) {
- case GTK_TYPE_POINTER:
- case GTK_TYPE_INT:
- case GTK_TYPE_UINT:
- *GTK_RETLOC_INT(*arg) = Nativeint_val(val); break;
- case GTK_TYPE_LONG:
- case GTK_TYPE_ULONG:
- *GTK_RETLOC_LONG(*arg) = Nativeint_val(val); break;
- case GTK_TYPE_ENUM:
- *GTK_RETLOC_ENUM(*arg) = Nativeint_val(val); break;
- case GTK_TYPE_FLAGS:
- *GTK_RETLOC_FLAGS(*arg) = Nativeint_val(val); break;
- default:
- ml_raise_gtk ("argument type mismatch");
- }
- return Val_unit;
-}
-
-value ml_gtk_arg_set_float (GtkArg *arg, value val)
-{
- switch (GTK_FUNDAMENTAL_TYPE(arg->type)) {
- case GTK_TYPE_POINTER:
- case GTK_TYPE_FLOAT:
- *GTK_RETLOC_FLOAT(*arg) = (float) Double_val(val); break;
- case GTK_TYPE_DOUBLE:
- *GTK_RETLOC_DOUBLE(*arg) = Double_val(val); break;
- default:
- ml_raise_gtk ("argument type mismatch");
- }
- return Val_unit;
-}
-
-value ml_gtk_arg_set_string (GtkArg *arg, value val)
-{
- switch (GTK_FUNDAMENTAL_TYPE(arg->type)) {
- case GTK_TYPE_POINTER:
- case GTK_TYPE_STRING:
- *GTK_RETLOC_STRING(*arg) = String_val(val); break;
- default:
- ml_raise_gtk ("argument type mismatch");
- }
- return Val_unit;
-}
-
-value ml_gtk_arg_set_pointer (GtkArg *arg, value val)
-{
- switch (GTK_FUNDAMENTAL_TYPE(arg->type)) {
- case GTK_TYPE_BOXED:
- *GTK_RETLOC_BOXED(*arg) = Pointer_val(val); break;
- case GTK_TYPE_POINTER:
- *GTK_RETLOC_POINTER(*arg) = Pointer_val(val); break;
- default:
- ml_raise_gtk ("argument type mismatch");
- }
- return Val_unit;
-}
-
-value ml_gtk_arg_set_object (GtkArg *arg, value val)
-{
- switch (GTK_FUNDAMENTAL_TYPE(arg->type)) {
- case GTK_TYPE_POINTER:
- case GTK_TYPE_OBJECT:
- *GTK_RETLOC_OBJECT(*arg) = GtkObject_val(val); break;
- default:
- ml_raise_gtk ("argument type mismatch");
- }
- return Val_unit;
-}
-*/
-
-/* gtksignal.h */
-
-value ml_gtk_signal_connect (value object, value name, value clos, value after)
-{
- value *clos_p = ml_global_root_new (clos);
- return Val_int (gtk_signal_connect_full
- (GtkObject_val(object), String_val(name), NULL,
- ml_gtk_callback_marshal, clos_p,
- ml_global_root_destroy, FALSE, Bool_val(after)));
-}
-
-ML_2 (gtk_signal_disconnect, GtkObject_val, Int_val, Unit)
-ML_2 (gtk_signal_emit_stop_by_name, GtkObject_val, String_val, Unit)
-ML_2 (gtk_signal_handler_block, GtkObject_val, Int_val, Unit)
-ML_2 (gtk_signal_handler_unblock, GtkObject_val, Int_val, Unit)
-ML_2_name (ml_gtk_signal_emit_none, gtk_signal_emit_by_name,
- GtkObject_val, String_val, Unit)
-ML_3_name (ml_gtk_signal_emit_int, gtk_signal_emit_by_name,
- GtkObject_val, String_val, Int_val, Unit)
-ML_4_name (ml_gtk_signal_emit_scroll, gtk_signal_emit_by_name,
- GtkObject_val, String_val, Scroll_type_val, Double_val, Unit)
-
-/* gtkmain.h (again) */
-
-value ml_gtk_timeout_add (value interval, value clos)
-{
- value *clos_p = ml_global_root_new (clos);
- return Val_int (gtk_timeout_add_full
- (Int_val(interval), NULL, ml_gtk_callback_marshal, clos_p,
- ml_global_root_destroy));
-}
-ML_1 (gtk_timeout_remove, Int_val, Unit)
-
-ML_1 (gtk_rc_add_default_file, String_val, Unit)