Mercurial > pidgin.yaz
diff console/libgnt/gntbindable.c @ 15304:7a52dce840b4
[gaim-migrate @ 18094]
Fix a crash which happens when you rebind some key-bindings.
committer: Tailor Script <tailor@pidgin.im>
author | Sadrul Habib Chowdhury <imadil@gmail.com> |
---|---|
date | Tue, 09 Jan 2007 00:29:45 +0000 |
parents | 7d682fc9098f |
children | c2c2a854f5b3 |
line wrap: on
line diff
--- a/console/libgnt/gntbindable.c Tue Jan 09 00:24:55 2007 +0000 +++ b/console/libgnt/gntbindable.c Tue Jan 09 00:29:45 2007 +0000 @@ -19,15 +19,35 @@ GNTDEBUG; } +static gpointer +bindable_clone(GntBindableAction *action) +{ + GntBindableAction *ret = g_new0(GntBindableAction, 1); + ret->name = g_strdup(action->name); + ret->u = action->u; + return ret; +} + +static gpointer +binding_clone(GntBindableActionParam *param) +{ + GntBindableActionParam *p = g_new0(GntBindableActionParam, 1); + p->list = g_list_copy(param->list); + p->action = param->action; + return p; +} + static void duplicate_hashes(GntBindableClass *klass) { /* Duplicate the bindings from parent class */ if (klass->actions) { klass->actions = g_hash_table_duplicate(klass->actions, g_str_hash, - g_str_equal, g_free, (GDestroyNotify)gnt_bindable_action_free); + g_str_equal, g_free, (GDestroyNotify)gnt_bindable_action_free, + (GDupFunc)g_strdup, (GDupFunc)bindable_clone); klass->bindings = g_hash_table_duplicate(klass->bindings, g_str_hash, - g_str_equal, g_free, (GDestroyNotify)gnt_bindable_action_param_free); + g_str_equal, g_free, (GDestroyNotify)gnt_bindable_action_param_free, + (GDupFunc)g_strdup, (GDupFunc)binding_clone); } else { klass->actions = g_hash_table_new_full(g_str_hash, g_str_equal, g_free, (GDestroyNotify)gnt_bindable_action_free);