diff options
author | Christian Persch <chpe@cvs.gnome.org> | 2004-04-10 05:10:13 +0800 |
---|---|---|
committer | Christian Persch <chpe@src.gnome.org> | 2004-04-10 05:10:13 +0800 |
commit | 23b63c1cd2fafb38cdbb404577e2639570118d8b (patch) | |
tree | 90684223917b25e88a6b41bd1a5da0383739b645 | |
parent | 09013d85af029a40525cc7e6768f7840dfb4d064 (diff) | |
download | gsoc2013-epiphany-23b63c1cd2fafb38cdbb404577e2639570118d8b.tar gsoc2013-epiphany-23b63c1cd2fafb38cdbb404577e2639570118d8b.tar.gz gsoc2013-epiphany-23b63c1cd2fafb38cdbb404577e2639570118d8b.tar.bz2 gsoc2013-epiphany-23b63c1cd2fafb38cdbb404577e2639570118d8b.tar.lz gsoc2013-epiphany-23b63c1cd2fafb38cdbb404577e2639570118d8b.tar.xz gsoc2013-epiphany-23b63c1cd2fafb38cdbb404577e2639570118d8b.tar.zst gsoc2013-epiphany-23b63c1cd2fafb38cdbb404577e2639570118d8b.zip |
Sort the actions in the location entry autocompletion dropdown. Fixes bug
2004-04-09 Christian Persch <chpe@cvs.gnome.org>
* src/ephy-location-action.c: (compare_actions),
(init_actions_list):
Sort the actions in the location entry autocompletion dropdown.
Fixes bug #139575.
-rw-r--r-- | ChangeLog | 8 | ||||
-rw-r--r-- | src/ephy-location-action.c | 39 |
2 files changed, 46 insertions, 1 deletions
@@ -1,3 +1,11 @@ +2004-04-09 Christian Persch <chpe@cvs.gnome.org> + + * src/ephy-location-action.c: (compare_actions), + (init_actions_list): + + Sort the actions in the location entry autocompletion dropdown. + Fixes bug #139575. + 2004-04-07 Christian Persch <chpe@cvs.gnome.org> * lib/eel-gconf-extensions.c: (eel_gconf_handle_error): diff --git a/src/ephy-location-action.c b/src/ephy-location-action.c index dd2de1431..fc29581fe 100644 --- a/src/ephy-location-action.c +++ b/src/ephy-location-action.c @@ -400,6 +400,40 @@ ephy_location_action_class_init (EphyLocationActionClass *class) g_type_class_add_private (object_class, sizeof (EphyLocationActionPrivate)); } +static int +compare_actions (gconstpointer a, + gconstpointer b) +{ + EphyNode *node_a = (EphyNode *)a; + EphyNode *node_b = (EphyNode *)b; + const char *title1, *title2; + int retval; + + title1 = ephy_node_get_property_string (node_a, EPHY_NODE_BMK_PROP_TITLE); + title2 = ephy_node_get_property_string (node_b, EPHY_NODE_BMK_PROP_TITLE); + + if (title1 == NULL) + { + retval = -1; + } + else if (title2 == NULL) + { + retval = 1; + } + else + { + char *str_a, *str_b; + + str_a = g_utf8_casefold (title1, -1); + str_b = g_utf8_casefold (title2, -1); + retval = g_utf8_collate (str_a, str_b); + g_free (str_a); + g_free (str_b); + } + + return retval; +} + static void init_actions_list (EphyLocationAction *action) { @@ -413,9 +447,12 @@ init_actions_list (EphyLocationAction *action) kid = g_ptr_array_index (children, i); - action->priv->actions = g_list_append + action->priv->actions = g_list_prepend (action->priv->actions, kid); } + + action->priv->actions = + g_list_sort (action->priv->actions, (GCompareFunc) compare_actions); } static void |