Mercurial > pidgin.yaz
view finch/libgnt/gntmenuitem.h @ 27231:e3907cfaeb02
Don't crash when the seemingly impossible occurs.
IOW, try to handle khc's crash, even though I don't see how this is possible.
(gdb) f 4
#4 0x00007f268bd61e11 in jabber_caps_ext_iqcb (js=0x2ac4700,
from=0x4a3c550 "maiku@jabber.org/Telepathy", type=JABBER_IQ_RESULT,
id=0x31b1240 "purpleb9d3d882", packet=0x55e3220, data=0x497d6f0)
at caps.c:552
552 g_hash_table_insert(node_exts->exts, g_strdup(userdata->name), features);
(gdb) p node_exts
$2 = (JabberCapsNodeExts *) 0x0
(gdb) bt
#0 0x00007f2693f53fb5 in raise () from /lib/libc.so.6
#1 0x00007f2693f55bc3 in abort () from /lib/libc.so.6
#2 0x000000000049366b in sighandler (sig=11) at gtkmain.c:195
#3 <signal handler called>
#4 0x00007f268bd61e11 in jabber_caps_ext_iqcb (js=0x2ac4700,
from=0x4a3c550 "maiku@jabber.org/Telepathy", type=JABBER_IQ_RESULT,
id=0x31b1240 "purpleb9d3d882", packet=0x55e3220, data=0x497d6f0)
at caps.c:552
#10 0x00007f268bd56d3d in jabber_parser_process (js=0x2ac4700,
buf=0x7f268bf7a980 "<iq from='maiku@jabber.org/Telepathy' to='khc@hxbc.us/Home' type='result' id='purpleb9d3d882'> <query node='http://telepathy.freedesktop.org/caps#voice-v1' xmlns='http://jabber.org/protocol/disco#info"..., len=279)
at parser.c:227
$4 = (JabberCapsClientInfo *) 0x4a8bcd0
p *((ext_iq_data*)data)->data->info
$6 = {
identities = 0x0,
features = 0x4a41580,
forms = 0x0,
exts = 0x0,
tuple = {
node = 0x3d2ff20 "http://telepathy.freedesktop.org/caps",
ver = 0x31aa850 "0.6.2.1",
hash = 0x0
}
}
author | Paul Aurich <paul@darkrain42.org> |
---|---|
date | Mon, 22 Jun 2009 23:36:56 +0000 |
parents | 6de09629f091 |
children |
line wrap: on
line source
/** * @file gntmenuitem.h Menuitem API * @ingroup gnt */ /* * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 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; char trigger; char *id; }; 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 for GntMenuItem. */ GType gnt_menuitem_get_gtype(void); /** * Create a new menuitem. * * @param text Label for the menuitem. * * @return The newly created menuitem. */ GntMenuItem * gnt_menuitem_new(const char *text); /** * Set a callback function for a menuitem. * * @param item The menuitem. * @param callback The callback function. * @param data Data to send to the callback function. */ void gnt_menuitem_set_callback(GntMenuItem *item, GntMenuItemCallback callback, gpointer data); /** * Set a submenu for a menuitem. A menuitem with a submenu cannot have a callback. * * @param item The menuitem. * @param menu The submenu. */ void gnt_menuitem_set_submenu(GntMenuItem *item, GntMenu *menu); /** * Get the submenu for a menuitem. * * @param item The menuitem. * * @return The submenu, or @c NULL. * * @since 2.3.0 */ GntMenu *gnt_menuitem_get_submenu(GntMenuItem *item); /** * Set a trigger key for the item. * * @param item The menuitem * @param trigger The key that will trigger the item when the parent manu is visible */ void gnt_menuitem_set_trigger(GntMenuItem *item, char trigger); /** * Get the trigger key for a menuitem. * * @param item The menuitem * * @return The trigger key for the menuitem. * * @see gnt_menuitem_set_trigger */ char gnt_menuitem_get_trigger(GntMenuItem *item); /** * Set an ID for the menuitem. * * @param item The menuitem. * @param id The ID for the menuitem. * * @since 2.3.0 */ void gnt_menuitem_set_id(GntMenuItem *item, const char *id); /** * Get the ID of the menuitem. * * @param item The menuitem. * * @return The ID for the menuitem. * * @since 2.3.0 */ const char * gnt_menuitem_get_id(GntMenuItem *item); /** * Activate a menuitem. * Activating the menuitem will first trigger the 'activate' signal for the * menuitem. Then the callback for the menuitem is triggered, if there is one. * * @param item The menuitem. * * @return Whether the callback for the menuitem was called. * * @since 2.3.0 */ gboolean gnt_menuitem_activate(GntMenuItem *item); G_END_DECLS #endif /* GNT_MENUITEM_H */