gtkMenu.ml1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88(**************************************************************************) (* Lablgtk *) (* *) (* This program is free software; you can redistribute it *) (* and/or modify it under the terms of the GNU Library General *) (* Public License as published by the Free Software Foundation *) (* version 2, with the exception described in file COPYING which *) (* comes with the library. *) (* *) (* This program is distributed in the hope that it will be useful, *) (* but WITHOUT ANY WARRANTY; without even the implied warranty of *) (* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *) (* GNU Library General Public License for more details. *) (* *) (* You should have received a copy of the GNU Library General *) (* Public License along with this program; if not, write to the *) (* Free Software Foundation, Inc., 59 Temple Place, Suite 330, *) (* Boston, MA 02111-1307 USA *) (* *) (* *) (**************************************************************************) (* $Id$ *) open Gaux open Gobject open Gtk open GtkMenuProps open GtkBase module MenuItem = struct include MenuItem external create_with_label : string -> menu_item obj = "ml_gtk_menu_item_new_with_label" external create_with_mnemonic : string -> menu_item obj = "ml_gtk_menu_item_new_with_mnemonic" external separator_create : unit -> menu_item obj = "ml_gtk_separator_menu_item_new" let create ?(use_mnemonic=false) ?label () = match label with None -> create [] | Some label -> if use_mnemonic then create_with_mnemonic label else create_with_label label end module CheckMenuItem = struct include CheckMenuItem external create_with_label : string -> check_menu_item obj = "ml_gtk_check_menu_item_new_with_label" external create_with_mnemonic : string -> check_menu_item obj = "ml_gtk_check_menu_item_new_with_mnemonic" let create ?(use_mnemonic=false) ?label () = match label with None -> create [] | Some label -> if use_mnemonic then create_with_mnemonic label else create_with_label label let set ?active w = may active ~f:(set P.active w) end module RadioMenuItem = struct include RadioMenuItem external create : radio_menu_item group -> radio_menu_item obj = "ml_gtk_radio_menu_item_new" external create_with_label : radio_menu_item group -> string -> radio_menu_item obj = "ml_gtk_radio_menu_item_new_with_label" external create_with_mnemonic : radio_menu_item group -> string -> radio_menu_item obj = "ml_gtk_radio_menu_item_new_with_mnemonic" let create ?(group = None) ?(use_mnemonic=false) ?label () = match label with None -> create group | Some label -> if use_mnemonic then create_with_mnemonic group label else create_with_label group label end module MenuShell = MenuShell module Menu = struct include Menu let popup ? ?parent_item w = popup w (Gpointer.optboxed parent_menu) (Gpointer.optboxed parent_item) let set ?active ?accel_group w = may active ~f:(set_active w); may accel_group ~f:(set_accel_group w) end module MenuBar = MenuBar