forked from AuroraMiddleware/gtk
caf8ebc6f1
Mon Aug 24 18:37:15 1998 Owen Taylor <otaylor@redhat.com> * gtk/gtktext.c: Reference count the fonts used in the text widget. * gdk/gdk.h gdk/gdkcolor.c: Rename the color allocation freeing functions to be more consistent, and more convenient; leave the old names in for backwards compatibility. * gdk/gdkcolor.c gdk/gdkprivate.h: Reference count the allocations in pseudo-color colormaps to greatly reduce calls to XAllocColor. Keep a per-colormap hashtable to speed up finding if there is an already-allocated matching color. * gdk/gdkcolor.c: Don't just match read the system colormap when the colormap is created, but synchronize our copy with the system colormap periodically. * gdk/gdk.c gdk/gdktypes.h gtk/gtkentry.c gtk/gtktext.c: Change XIM constants names to match GDK conventions * gtk/testinput.c: Allow the drawing area to get the focus. * gtk/testgtk.c: Change around the Text test to demonstrates multiple fonts, use more colors. * gtk/gtkwidget.c: Improve gtk_widget_get_colormap()/visual() so they work after a widget is unrealized. * gtk/gtktext.[ch]: Remove the requirement that the text widget be realized before adding text (!) Allocate colors ourself, instead of requiring the caller allocate them. Allow changing styles to work properly by keeping track of the values for a certain property are default or set explicitely. * gtk/gtkmenu.h: Added some comments. * gtk/gtkentry.c: Changes to match XIM constants. * gtk/gdk.h gdk/gdkwindow.c: Add gdk_drawable_set_data(), for adding keyed data to drawables. (Uses g_dataset internally) * gdk/gdkpixmap.c: Keep track of the colors we allocate, when creating an XPM - store them as user data for the GdkPixmap, so we don't leak colors when we create pixmaps from XPM's. Allocate memory for color information in large blocks instead of as many little pieces.
137 lines
4.1 KiB
C
137 lines
4.1 KiB
C
/* GTK - The GIMP Toolkit
|
|
* Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
|
|
*
|
|
* This library 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; 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
|
|
* Library General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Library 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.
|
|
*/
|
|
#ifndef __GTK_MENU_H__
|
|
#define __GTK_MENU_H__
|
|
|
|
|
|
#include <gdk/gdk.h>
|
|
#include <gtk/gtkaccelgroup.h>
|
|
#include <gtk/gtkmenushell.h>
|
|
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#pragma }
|
|
#endif /* __cplusplus */
|
|
|
|
|
|
#define GTK_TYPE_MENU (gtk_menu_get_type ())
|
|
#define GTK_MENU(obj) (GTK_CHECK_CAST ((obj), GTK_TYPE_MENU, GtkMenu))
|
|
#define GTK_MENU_CLASS(klass) (GTK_CHECK_CLASS_CAST ((klass), GTK_TYPE_MENU, GtkMenuClass))
|
|
#define GTK_IS_MENU(obj) (GTK_CHECK_TYPE ((obj), GTK_TYPE_MENU))
|
|
#define GTK_IS_MENU_CLASS(klass) (GTK_CHECK_CLASS_TYPE ((klass), GTK_TYPE_MENU))
|
|
|
|
|
|
typedef struct _GtkMenu GtkMenu;
|
|
typedef struct _GtkMenuClass GtkMenuClass;
|
|
|
|
typedef void (*GtkMenuPositionFunc) (GtkMenu *menu,
|
|
gint *x,
|
|
gint *y,
|
|
gpointer user_data);
|
|
typedef void (*GtkMenuDetachFunc) (GtkWidget *attach_widget,
|
|
GtkMenu *menu);
|
|
|
|
struct _GtkMenu
|
|
{
|
|
GtkMenuShell menu_shell;
|
|
|
|
GtkWidget *parent_menu_item;
|
|
GtkWidget *old_active_menu_item;
|
|
|
|
GtkAccelGroup *accel_group;
|
|
GtkMenuPositionFunc position_func;
|
|
gpointer position_func_data;
|
|
|
|
GtkWidget *toplevel;
|
|
GtkWidget *tearoff_window;
|
|
|
|
guint torn_off : 1;
|
|
};
|
|
|
|
struct _GtkMenuClass
|
|
{
|
|
GtkMenuShellClass parent_class;
|
|
};
|
|
|
|
|
|
GtkType gtk_menu_get_type (void);
|
|
GtkWidget* gtk_menu_new (void);
|
|
|
|
/* Wrappers for the Menu Shell operations */
|
|
void gtk_menu_append (GtkMenu *menu,
|
|
GtkWidget *child);
|
|
void gtk_menu_prepend (GtkMenu *menu,
|
|
GtkWidget *child);
|
|
void gtk_menu_insert (GtkMenu *menu,
|
|
GtkWidget *child,
|
|
gint position);
|
|
|
|
/* Display the menu onscreen */
|
|
void gtk_menu_popup (GtkMenu *menu,
|
|
GtkWidget *parent_menu_shell,
|
|
GtkWidget *parent_menu_item,
|
|
GtkMenuPositionFunc func,
|
|
gpointer data,
|
|
guint button,
|
|
guint32 activate_time);
|
|
|
|
/* Position the menu according to it's position function. Called
|
|
* from gtkmenuitem.c when a menu-item changes its allocation
|
|
*/
|
|
void gtk_menu_reposition (GtkMenu *menu);
|
|
|
|
void gtk_menu_popdown (GtkMenu *menu);
|
|
|
|
/* Keep track of the last menu item selected. (For the purposes
|
|
* of the option menu
|
|
*/
|
|
GtkWidget* gtk_menu_get_active (GtkMenu *menu);
|
|
void gtk_menu_set_active (GtkMenu *menu,
|
|
guint index);
|
|
|
|
void gtk_menu_set_accel_group (GtkMenu *menu,
|
|
GtkAccelGroup *accel_group);
|
|
|
|
/* A reference count is kept for a widget when it is attached to
|
|
* a particular widget. This is typically a menu item; it may also
|
|
* be a widget with a popup menu - for instance, the Notebook widget.
|
|
*/
|
|
void gtk_menu_attach_to_widget (GtkMenu *menu,
|
|
GtkWidget *attach_widget,
|
|
GtkMenuDetachFunc detacher);
|
|
void gtk_menu_detach (GtkMenu *menu);
|
|
|
|
/* This should be dumped in favor of data set when the menu is popped
|
|
* up - that is currently in the ItemFactory code, but should be
|
|
* in the Menu code.
|
|
*/
|
|
GtkWidget* gtk_menu_get_attach_widget (GtkMenu *menu);
|
|
|
|
void gtk_menu_detach (GtkMenu *menu);
|
|
void gtk_menu_set_tearoff_state (GtkMenu *menu,
|
|
gboolean torn_off);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif /* __cplusplus */
|
|
|
|
|
|
#endif /* __GTK_MENU_H__ */
|