--- /dev/null
+(* $Id$ *)
+
+open Gaux
+open Gtk
+open Tags
+open GtkBase
+
+module ListItem = struct
+ let cast w : list_item obj = Object.try_cast w "GtkListItem"
+ external create : unit -> list_item obj = "ml_gtk_list_item_new"
+ external create_with_label : string -> list_item obj
+ = "ml_gtk_list_item_new_with_label"
+ let create ?label () =
+ match label with None -> create ()
+ | Some label -> create_with_label label
+end
+
+module Liste = struct
+ let cast w : liste obj = Object.try_cast w "GtkList"
+ external create : unit -> liste obj = "ml_gtk_list_new"
+ external insert_item :
+ [>`list] obj -> [>`listitem] obj -> pos:int -> unit
+ = "ml_gtk_list_insert_item"
+ let insert_items l wl ~pos =
+ let wl = if pos < 0 then wl else List.rev wl in
+ List.iter wl ~f:(insert_item l ~pos)
+ let append_items l = insert_items l ~pos:(-1)
+ let prepend_items l = insert_items l ~pos:0
+ external clear_items : [>`list] obj -> start:int -> stop:int -> unit =
+ "ml_gtk_list_clear_items"
+ external select_item : [>`list] obj -> pos:int -> unit
+ = "ml_gtk_list_select_item"
+ external unselect_item : [>`list] obj -> pos:int -> unit
+ = "ml_gtk_list_unselect_item"
+ external select_child : [>`list] obj -> [>`listitem] obj -> unit
+ = "ml_gtk_list_select_child"
+ external unselect_child : [>`list] obj -> [>`listitem] obj -> unit
+ = "ml_gtk_list_unselect_child"
+ external child_position : [>`list] obj -> [>`listitem] obj -> int
+ = "ml_gtk_list_child_position"
+ external set_selection_mode : [>`list] obj -> selection_mode -> unit
+ = "ml_gtk_list_set_selection_mode"
+ module Signals = struct
+ open GtkSignal
+ let selection_changed : ([>`list],_) t =
+ { name = "selection_changed"; marshaller = marshal_unit }
+ let select_child : ([>`list],_) t =
+ { name = "select_child"; marshaller = Widget.Signals.marshal }
+ let unselect_child : ([>`list],_) t =
+ { name = "unselect_child"; marshaller = Widget.Signals.marshal }
+ end
+end
+
+module CList = struct
+ let cast w : clist obj = Object.try_cast w "GtkCList"
+ external create : cols:int -> clist obj = "ml_gtk_clist_new"
+ external create_with_titles : string array -> clist obj
+ = "ml_gtk_clist_new_with_titles"
+ external get_rows : [>`clist] obj -> int = "ml_gtk_clist_get_rows"
+ external get_columns : [>`clist] obj -> int = "ml_gtk_clist_get_columns"
+ external get_focus_row : [>`clist] obj -> int
+ = "ml_gtk_clist_get_focus_row"
+ external set_hadjustment : [>`clist] obj -> [>`adjustment] obj -> unit
+ = "ml_gtk_clist_set_hadjustment"
+ external set_vadjustment : [>`clist] obj -> [>`adjustment] obj -> unit
+ = "ml_gtk_clist_set_vadjustment"
+ external get_hadjustment : [>`clist] obj -> adjustment obj
+ = "ml_gtk_clist_get_hadjustment"
+ external get_vadjustment : [>`clist] obj -> adjustment obj
+ = "ml_gtk_clist_get_vadjustment"
+ external set_shadow_type : [>`clist] obj -> shadow_type -> unit
+ = "ml_gtk_clist_set_shadow_type"
+ external set_selection_mode : [>`clist] obj -> selection_mode -> unit
+ = "ml_gtk_clist_set_selection_mode"
+ external set_reorderable : [>`clist] obj -> bool -> unit
+ = "ml_gtk_clist_set_reorderable"
+ external set_use_drag_icons : [>`clist] obj -> bool -> unit
+ = "ml_gtk_clist_set_use_drag_icons"
+ external set_button_actions :
+ [>`clist] obj -> int -> button_action list -> unit
+ = "ml_gtk_clist_set_button_actions"
+ external freeze : [>`clist] obj -> unit = "ml_gtk_clist_freeze"
+ external thaw : [>`clist] obj -> unit = "ml_gtk_clist_thaw"
+ external column_titles_show : [>`clist] obj -> unit
+ = "ml_gtk_clist_column_titles_show"
+ external column_titles_hide : [>`clist] obj -> unit
+ = "ml_gtk_clist_column_titles_hide"
+ external column_title_active : [>`clist] obj -> int -> unit
+ = "ml_gtk_clist_column_title_active"
+ external column_title_passive : [>`clist] obj -> int -> unit
+ = "ml_gtk_clist_column_title_passive"
+ external column_titles_active : [>`clist] obj -> unit
+ = "ml_gtk_clist_column_titles_active"
+ external column_titles_passive : [>`clist] obj -> unit
+ = "ml_gtk_clist_column_titles_passive"
+ external set_column_title : [>`clist] obj -> int -> string -> unit
+ = "ml_gtk_clist_set_column_title"
+ external get_column_title : [>`clist] obj -> int -> string
+ = "ml_gtk_clist_get_column_title"
+ external set_column_widget : [>`clist] obj -> int -> [>`widget] obj -> unit
+ = "ml_gtk_clist_set_column_widget"
+ external get_column_widget : [>`clist] obj -> int -> widget obj
+ = "ml_gtk_clist_get_column_widget"
+ external set_column_justification :
+ [>`clist] obj -> int -> justification -> unit
+ = "ml_gtk_clist_set_column_justification"
+ external set_column_visibility : [>`clist] obj -> int -> bool -> unit
+ = "ml_gtk_clist_set_column_visibility"
+ external set_column_resizeable : [>`clist] obj -> int -> bool -> unit
+ = "ml_gtk_clist_set_column_resizeable"
+ external set_column_auto_resize : [>`clist] obj -> int -> bool -> unit
+ = "ml_gtk_clist_set_column_auto_resize"
+ external columns_autosize : [>`clist] obj -> unit
+ = "ml_gtk_clist_columns_autosize"
+ external optimal_column_width : [>`clist] obj -> int -> int
+ = "ml_gtk_clist_optimal_column_width"
+ external set_column_width : [>`clist] obj -> int -> int -> unit
+ = "ml_gtk_clist_set_column_width"
+ external set_column_min_width : [>`clist] obj -> int -> int -> unit
+ = "ml_gtk_clist_set_column_min_width"
+ external set_column_max_width : [>`clist] obj -> int -> int -> unit
+ = "ml_gtk_clist_set_column_max_width"
+ external set_row_height : [>`clist] obj -> int -> unit
+ = "ml_gtk_clist_set_row_height"
+ external moveto :
+ [>`clist] obj ->
+ int -> int -> row_align:clampf -> col_align:clampf -> unit
+ = "ml_gtk_clist_moveto"
+ external row_is_visible : [>`clist] obj -> int -> visibility
+ = "ml_gtk_clist_row_is_visible"
+ external get_cell_type : [>`clist] obj -> int -> int -> cell_type
+ = "ml_gtk_clist_get_cell_type"
+ external set_text : [>`clist] obj -> int -> int -> string -> unit
+ = "ml_gtk_clist_set_text"
+ external get_text : [>`clist] obj -> int -> int -> string
+ = "ml_gtk_clist_get_text"
+ external set_pixmap :
+ [>`clist] obj ->
+ int -> int -> Gdk.pixmap -> Gdk.bitmap Gpointer.optboxed -> unit
+ = "ml_gtk_clist_set_pixmap"
+ external get_pixmap :
+ [>`clist] obj -> int -> int -> Gdk.pixmap option * Gdk.bitmap option
+ = "ml_gtk_clist_get_pixmap"
+ external set_pixtext :
+ [>`clist] obj -> int -> int ->
+ string -> int -> Gdk.pixmap -> Gdk.bitmap Gpointer.optboxed -> unit
+ = "ml_gtk_clist_set_pixtext_bc" "ml_gtk_clist_set_pixtext"
+ external set_foreground :
+ [>`clist] obj -> row:int -> Gdk.Color.t Gpointer.optboxed -> unit
+ = "ml_gtk_clist_set_foreground"
+ external set_background :
+ [>`clist] obj -> row:int -> Gdk.Color.t Gpointer.optboxed -> unit
+ = "ml_gtk_clist_set_background"
+ external get_cell_style : [>`clist] obj -> int -> int -> Gtk.style
+ = "ml_gtk_clist_get_cell_style"
+ external set_cell_style : [>`clist] obj -> int -> int -> Gtk.style -> unit
+ = "ml_gtk_clist_set_cell_style"
+ external get_row_style : [>`clist] obj -> row:int -> Gtk.style
+ = "ml_gtk_clist_get_row_style"
+ external set_row_style : [>`clist] obj -> row:int -> Gtk.style -> unit
+ = "ml_gtk_clist_set_row_style"
+ external set_selectable : [>`clist] obj -> row:int -> bool -> unit
+ = "ml_gtk_clist_set_selectable"
+ external get_selectable : [>`clist] obj -> row:int -> bool
+ = "ml_gtk_clist_get_selectable"
+ external set_shift :
+ [>`clist] obj -> int -> int -> vertical:int -> horizontal:int -> unit
+ = "ml_gtk_clist_set_shift"
+ external insert : [>`clist] obj -> row:int -> Gpointer.optstring array -> int
+ = "ml_gtk_clist_insert"
+ let insert w ~row texts =
+ let len = get_columns w in
+ if List.length texts > len then invalid_arg "CList.insert";
+ let arr = Array.create (get_columns w) None in
+ List.fold_left texts ~init:0
+ ~f:(fun pos text -> arr.(pos) <- text; pos+1);
+ let r = insert w ~row (Array.map ~f:Gpointer.optstring arr) in
+ if r = -1 then invalid_arg "GtkCList::insert";
+ r
+ external remove : [>`clist] obj -> row:int -> unit
+ = "ml_gtk_clist_remove"
+ external set_row_data : [>`clist] obj -> row:int -> Obj.t -> unit
+ = "ml_gtk_clist_set_row_data"
+ external get_row_data : [>`clist] obj -> row:int -> Obj.t
+ = "ml_gtk_clist_get_row_data"
+ external select : [>`clist] obj -> int -> int -> unit
+ = "ml_gtk_clist_select_row"
+ external unselect : [>`clist] obj -> int -> int -> unit
+ = "ml_gtk_clist_unselect_row"
+ external clear : [>`clist] obj -> unit = "ml_gtk_clist_clear"
+ external get_row_column : [>`clist] obj -> x:int -> y:int -> int * int
+ = "ml_gtk_clist_get_selection_info"
+ external select_all : [>`clist] obj -> unit = "ml_gtk_clist_select_all"
+ external unselect_all : [>`clist] obj -> unit = "ml_gtk_clist_unselect_all"
+ external swap_rows : [>`clist] obj -> int -> int -> unit
+ = "ml_gtk_clist_swap_rows"
+ external row_move : [>`clist] obj -> int -> dst:int -> unit
+ = "ml_gtk_clist_row_move"
+ external set_sort_column : [>`clist] obj -> int -> unit
+ = "ml_gtk_clist_set_sort_column"
+ external set_sort_type : [>`clist] obj -> sort_type -> unit
+ = "ml_gtk_clist_set_sort_type"
+ external sort : [>`clist] obj -> unit
+ = "ml_gtk_clist_sort"
+ external set_auto_sort : [>`clist] obj -> bool -> unit
+ = "ml_gtk_clist_set_auto_sort"
+ let set_titles_show w = function
+ true -> column_titles_show w
+ | false -> column_titles_hide w
+ let set_titles_active w = function
+ true -> column_titles_active w
+ | false -> column_titles_passive w
+ let set ?hadjustment ?vadjustment ?shadow_type
+ ?(button_actions=[]) ?selection_mode ?reorderable
+ ?use_drag_icons ?row_height ?titles_show ?titles_active w =
+ let may_set f param = may param ~f:(f w) in
+ may_set set_hadjustment hadjustment;
+ may_set set_vadjustment vadjustment;
+ may_set set_shadow_type shadow_type;
+ List.iter button_actions ~f:(fun (n,act) -> set_button_actions w n act);
+ may_set set_selection_mode selection_mode;
+ may_set set_reorderable reorderable;
+ may_set set_use_drag_icons use_drag_icons;
+ may_set set_row_height row_height;
+ may_set set_titles_show titles_show;
+ may_set set_titles_active titles_active
+ let set_sort w ?auto ?column ?dir:sort_type () =
+ may auto ~f:(set_auto_sort w);
+ may column ~f:(set_sort_column w);
+ may sort_type ~f:(set_sort_type w)
+ let set_cell w ?text ?pixmap ?mask ?(spacing=0) ?style row col =
+ begin match text, pixmap with
+ | Some text, None ->
+ set_text w row col text
+ | None, Some pm ->
+ set_pixmap w row col pm (Gpointer.optboxed mask)
+ | Some text, Some pm ->
+ set_pixtext w row col text spacing pm (Gpointer.optboxed mask)
+ | _ -> ()
+ end;
+ may style ~f:(set_cell_style w row col)
+ let set_column w ?widget ?title ?title_active ?justification
+ ?visibility ?resizeable ?auto_resize ?width ?min_width ?max_width
+ col =
+ let may_set f param = may param ~f:(f w col) in
+ may_set set_column_widget widget;
+ may_set set_column_title title;
+ may title_active
+ ~f:(fun active -> if active then column_title_active w col
+ else column_title_passive w col);
+ may_set set_column_justification justification;
+ may_set set_column_visibility visibility;
+ may_set set_column_resizeable resizeable;
+ may_set set_column_auto_resize auto_resize;
+ may_set set_column_width width;
+ may_set set_column_min_width min_width;
+ may_set set_column_max_width max_width
+ let set_row w ?foreground ?background ?selectable ?style row =
+ let may_set f = may ~f:(f w ~row) in
+ may_set set_foreground foreground;
+ may_set set_background background;
+ may_set set_selectable selectable;
+ may_set set_row_style style
+ module Signals = struct
+ open GtkArgv
+ open GtkSignal
+ let marshal_select f argv = function
+ | INT row :: INT column :: POINTER p :: _ ->
+ let event : GdkEvent.Button.t option =
+ may_map ~f:GdkEvent.unsafe_copy p
+ in
+ f ~row ~column ~event
+ | _ -> invalid_arg "GtkList.CList.Signals.marshal_select"
+ let select_row : ([>`clist],_) t =
+ { name = "select_row"; marshaller = marshal_select }
+ let unselect_row : ([>`clist],_) t =
+ { name = "unselect_row"; marshaller = marshal_select }
+ let click_column : ([>`clist],_) t =
+ { name = "click_column"; marshaller = marshal_int }
+ external val_scroll_type : int -> scroll_type = "ml_Val_scroll_type"
+ let marshal_scroll f argv = function
+ | INT st :: FLOAT (pos : clampf) :: _ ->
+ f (val_scroll_type st) ~pos
+ | _ -> invalid_arg "GtkList.CList.Signals.marshal_scroll"
+ let scroll_horizontal : ([>`clist],_) t =
+ { name = "scroll_horizontal"; marshaller = marshal_scroll }
+ let scroll_vertical : ([>`clist],_) t =
+ { name = "scroll_vertical"; marshaller = marshal_scroll }
+ external emit_scroll :
+ 'a obj -> name:string -> Tags.scroll_type -> pos:clampf -> unit
+ = "ml_gtk_signal_emit_scroll"
+ let emit_scroll = emit ~emitter:emit_scroll
+ end
+end