-----------------------------------------------------------------------
-- GtkAda - Ada95 binding for Gtk+/Gnome --
-- --
-- Copyright (C) 1998-2000 E. Briot, J. Brobecker and A. Charlet --
-- Copyright (C) 2000-2003 ACT-Europe --
-- --
-- This library is free software; you can redistribute it and/or --
-- modify it under the terms of the GNU General Public --
-- License as published by the Free Software Foundation; either --
-- version 2 of the License, or (at your option) any later version. --
-- --
-- This library 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 --
-- General Public License for more details. --
-- --
-- You should have received a copy of the GNU General Public --
-- License along with this library; if not, write to the --
-- Free Software Foundation, Inc., 59 Temple Place - Suite 330, --
-- Boston, MA 02111-1307, USA. --
-- --
-- As a special exception, if other files instantiate generics from --
-- this unit, or you link this unit with other files to produce an --
-- executable, this unit does not by itself cause the resulting --
-- executable to be covered by the GNU General Public License. This --
-- exception does not however invalidate any other reasons why the --
-- executable file might be covered by the GNU Public License. --
-----------------------------------------------------------------------
--
-- This widget represents one of the lines in a menu, on which the user can
-- click to execute an action. The menu items can be bound to a submenu, so
-- that clicking on them will in fact display the submenu on the screen.
--
-- They can also be associated with key shortcuts (called accelerators). See
-- the subprogram Set_Accel_Path, and the subprograms in the package
-- Gtk.Accel_Map.
--
-- Activating the proper options in the theme files will allow the user to
-- interactively modify the shortcuts.
--
--
-- 1.3.11
with Gtk.Item;
with Gtk.Widget;
package Gtk.Menu_Item is
type Gtk_Menu_Item_Record is new Item.Gtk_Item_Record with private;
type Gtk_Menu_Item is access all Gtk_Menu_Item_Record'Class;
procedure Gtk_New
(Menu_Item : out Gtk_Menu_Item; Label : UTF8_String := "");
procedure Gtk_New_With_Mnemonic
(Menu_Item : out Gtk_Menu_Item;
Label : UTF8_String);
-- Create a new Gtk_Menu_Item containing a label.
-- The label is created using Gtk.Label.Gtk_New_With_Mnemonic, so
-- underscores in Label indicate the mnemonic for the menu item.
-- Warning: the menu_item will not be properly destroyed when you remove
-- it from its parent menu, if you created it with a non-empty Label. In
-- this case, you first need to destroy the child of the Menu_Item, and
-- then remove it from its parent menu.
procedure Initialize
(Menu_Item : access Gtk_Menu_Item_Record'Class; Label : UTF8_String);
-- Internal initialization procedure.
procedure Initialize_With_Mnemonic
(Menu_Item : access Gtk_Menu_Item_Record'Class;
Label : UTF8_String);
-- Internal initialization procedure.
function Get_Type return Gtk.Gtk_Type;
-- Return the internal value associated with a Gtk_Menu_Item.
procedure Set_Submenu
(Menu_Item : access Gtk_Menu_Item_Record;
Submenu : access Widget.Gtk_Widget_Record'Class);
-- Set the submenu underneath Menu_Item.
function Get_Submenu
(Menu_Item : access Gtk_Menu_Item_Record) return Gtk.Widget.Gtk_Widget;
-- Get the submenu underneath this menu item, if any, null otherwise.
procedure Remove_Submenu (Menu_Item : access Gtk_Menu_Item_Record);
procedure Gtk_Select (Menu_Item : access Gtk_Menu_Item_Record);
procedure Deselect (Menu_Item : access Gtk_Menu_Item_Record);
procedure Activate (Menu_Item : access Gtk_Menu_Item_Record);
procedure Right_Justify (Menu_Item : access Gtk_Menu_Item_Record);
-- Deprecated. Use Set_Right_Justified with Justify = True instead.
procedure Set_Right_Justified
(Menu_Item : access Gtk_Menu_Item_Record;
Justify : Boolean := True);
function Get_Right_Justified
(Menu_Item : access Gtk_Menu_Item_Record) return Boolean;
procedure Set_Right_Justify
(Menu_Item : access Gtk_Menu_Item_Record;
Justify : Boolean) renames Set_Right_Justified;
-- This procedure is needed by Gate to automate the code generation.
procedure Set_Accel_Path
(Menu_Item : access Gtk_Menu_Item_Record;
Accel_Path : UTF8_String);
-- Set the path that will be used to reference the widget in calls to the
-- subprograms in Gtk.Accel_Map. This means, for instance, that the widget
-- is fully setup for interactive modification of the shortcuts by the
-- user, should he choose to activate this possibility in his themes (see
-- gtk-accel_map.ads for more information).
-------------
-- Signals --
-------------
-- activate
-- activate_item
-- toggle_size_request
-- toggle_size_allocate
----------------
-- Properties --
----------------
--
-- The following properties are defined for this widget. See
-- Glib.Properties for more information on properties.
--
--
private
type Gtk_Menu_Item_Record is new Item.Gtk_Item_Record with null record;
pragma Import (C, Get_Type, "gtk_menu_item_get_type");
end Gtk.Menu_Item;
-- missing:
-- procedure Toggle_Size_Request
-- (Menu_Item : access Gtk_Menu_Item_Record;
-- Requisition : int*);
-- Emit the signal "toggle_size_request"
-- procedure Toggle_Size_Allocate
-- (Menu_Item : access Gtk_Menu_Item_Record;
-- Allocation : Gint);
-- Emit the signal "toggle_size_allocate"