Mercurial > pidgin.yaz
view finch/libgnt/gntmenuitem.h @ 18302:0d948cac4afa
merge of '152574afac3f14348361a22106e5716b24b844e1'
and '19cc8441b4e757544938bb9c8b45a76ac78f1653'
author | Etan Reisner <pidgin@unreliablesource.net> |
---|---|
date | Wed, 27 Jun 2007 00:31:22 +0000 |
parents | 1cedd520cd18 |
children | 5c6f019e48f8 |
line wrap: on
line source
/** * GNT - The GLib Ncurses Toolkit * * GNT is the legal property of its developers, whose names are too numerous * to list here. Please refer to the COPYRIGHT file distributed with this * source distribution. * * 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 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 General Public License for more details. * * You should have received a copy of the GNU 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 */ #ifndef GNT_MENUITEM_H #define GNT_MENUITEM_H #include <glib.h> #include <glib-object.h> #define GNT_TYPE_MENU_ITEM (gnt_menuitem_get_gtype()) #define GNT_MENU_ITEM(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj), GNT_TYPE_MENU_ITEM, GntMenuItem)) #define GNT_MENU_ITEM_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), GNT_TYPE_MENU_ITEM, GntMenuItemClass)) #define GNT_IS_MENU_ITEM(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), GNT_TYPE_MENU_ITEM)) #define GNT_IS_MENU_ITEM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), GNT_TYPE_MENU_ITEM)) #define GNT_MENU_ITEM_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), GNT_TYPE_MENU_ITEM, GntMenuItemClass)) #define GNT_MENU_ITEM_FLAGS(obj) (GNT_MENU_ITEM(obj)->priv.flags) #define GNT_MENU_ITEM_SET_FLAGS(obj, flags) (GNT_MENU_ITEM_FLAGS(obj) |= flags) #define GNT_MENU_ITEM_UNSET_FLAGS(obj, flags) (GNT_MENU_ITEM_FLAGS(obj) &= ~(flags)) typedef struct _GntMenuItem GntMenuItem; typedef struct _GntMenuItemPriv GntMenuItemPriv; typedef struct _GntMenuItemClass GntMenuItemClass; #include "gntmenu.h" struct _GntMenuItemPriv { /* These will be used to determine the position of the submenu */ int x; int y; }; typedef void (*GntMenuItemCallback)(GntMenuItem *item, gpointer data); struct _GntMenuItem { GObject parent; GntMenuItemPriv priv; char *text; /* A GntMenuItem can have a callback associated with it. * The callback will be activated whenever the suer selects it and presses enter (or clicks). * However, if the GntMenuItem has some child, then the callback and callbackdata will be ignored. */ gpointer callbackdata; GntMenuItemCallback callback; GntMenu *submenu; }; struct _GntMenuItemClass { GObjectClass parent; void (*gnt_reserved1)(void); void (*gnt_reserved2)(void); void (*gnt_reserved3)(void); void (*gnt_reserved4)(void); }; G_BEGIN_DECLS /** * * * @return */ GType gnt_menuitem_get_gtype(void); /** * * @param text * * @return */ GntMenuItem * gnt_menuitem_new(const char *text); /** * * @param item * @param callback * @param data */ void gnt_menuitem_set_callback(GntMenuItem *item, GntMenuItemCallback callback, gpointer data); /** * * @param item * @param menu */ void gnt_menuitem_set_submenu(GntMenuItem *item, GntMenu *menu); G_END_DECLS #endif /* GNT_MENUITEM_H */