Mercurial > geeqie
changeset 1664:c7415c58435b
test if an accelerator can be stored
gtk_accel_map_change_entry can't change accelerators
to keys like arrows. Test this and show the keys in the list
only if they can be really changed.
https://sourceforge.net/tracker/?func=detail&aid=2805139&group_id=222125&atid=1054680
author | nadvornik |
---|---|
date | Wed, 24 Jun 2009 20:31:30 +0000 |
parents | c59e8385328d |
children | 9a081164e6e3 |
files | src/preferences.c |
diffstat | 1 files changed, 14 insertions(+), 1 deletions(-) [+] |
line wrap: on
line diff
--- a/src/preferences.c Tue Jun 23 19:20:48 2009 +0000 +++ b/src/preferences.c Wed Jun 24 20:31:30 2009 +0000 @@ -994,11 +994,24 @@ GtkTreeModel *model = (GtkTreeModel *)accel_store; GtkTreeIter iter; gchar *acc; + gchar *accel_path; + GtkAccelKey old_key, key; GtkTreePath *path = gtk_tree_path_new_from_string(path_string); gtk_tree_model_get_iter(model, &iter, path); - acc = gtk_accelerator_name(accel_key, accel_mods); + gtk_tree_model_get(model, &iter, AE_ACCEL, &accel_path, -1); + + /* test if the accelerator can be stored without conflicts*/ + gtk_accel_map_lookup_entry(accel_path, &old_key); + /* change the key and read it back (change may fail on keys hardcoded in gtk)*/ + gtk_accel_map_change_entry(accel_path, accel_key, accel_mods, TRUE); + gtk_accel_map_lookup_entry(accel_path, &key); + + /* restore the original for now, the key will be really changed when the changes are confirmed */ + gtk_accel_map_change_entry(accel_path, old_key.accel_key, old_key.accel_mods, TRUE); + + acc = gtk_accelerator_name(key.accel_key, key.accel_mods); gtk_tree_model_foreach(GTK_TREE_MODEL(accel_store), accel_remove_key_cb, acc); gtk_tree_store_set(accel_store, &iter, AE_KEY, acc, -1);