diff options
author | Ettore Perazzoli <ettore@src.gnome.org> | 2002-08-01 04:54:48 +0800 |
---|---|---|
committer | Ettore Perazzoli <ettore@src.gnome.org> | 2002-08-01 04:54:48 +0800 |
commit | e8d6f8c723401c5251fff6192872fecbca8aaa7c (patch) | |
tree | 4c42d43f801fd76978322b325bd760a2dba5ab9d /shell/e-shell-user-creatable-items-handler.c | |
parent | ec3f54257d3d3ddcd22779547f543ba9a9716f89 (diff) | |
download | gsoc2013-evolution-e8d6f8c723401c5251fff6192872fecbca8aaa7c.tar.gz gsoc2013-evolution-e8d6f8c723401c5251fff6192872fecbca8aaa7c.tar.zst gsoc2013-evolution-e8d6f8c723401c5251fff6192872fecbca8aaa7c.zip |
(ensure_menu_items):
Don't sort the menu_items here.
(create_menu_xml): Instead, sort here, and only sort the
non-default section of the menu.
(get_default_action_for_view): Just get the first item that is
default; since we don't sort anymore, this works.
(find_menu_item_for_verb): Removed since it is not used anymore.
svn path=/trunk/; revision=17659
Diffstat (limited to 'shell/e-shell-user-creatable-items-handler.c')
-rw-r--r-- | shell/e-shell-user-creatable-items-handler.c | 190 |
1 files changed, 80 insertions, 110 deletions
diff --git a/shell/e-shell-user-creatable-items-handler.c b/shell/e-shell-user-creatable-items-handler.c index a10b755329..9e427f5b9f 100644 --- a/shell/e-shell-user-creatable-items-handler.c +++ b/shell/e-shell-user-creatable-items-handler.c @@ -133,6 +133,27 @@ component_free (Component *component) /* Helper functions. */ +static gboolean +item_is_default (const MenuItem *item, + const char *folder_type, + const char *component_id) +{ + if (component_id == NULL || folder_type == NULL) + return FALSE; + + if (item->folder_type != NULL && *item->folder_type != 0) { + if (strcmp (item->folder_type, folder_type) == 0) + return TRUE; + else + return FALSE; + } + + if (strcmp (item->component_id, component_id) == 0) + return TRUE; + else + return FALSE; +} + static char * create_verb_from_component_number_and_type_id (int component_num, const char *type_id) @@ -144,49 +165,6 @@ create_verb_from_component_number_and_type_id (int component_num, /* Setting up menu items for the "File -> New" submenu and the "New" toolbar button. */ -static int -item_types_sort_func (const void *a, - const void *b) -{ - const MenuItem *item_a; - const MenuItem *item_b; - const char *p1, *p2; - - item_a = (const MenuItem *) a; - item_b = (const MenuItem *) b; - - p1 = item_a->label; - p2 = item_b->label; - - while (*p1 != '\0' && *p2 != '\0') { - if (*p1 == '_') { - p1 ++; - continue; - } - - if (*p2 == '_') { - p2 ++; - continue; - } - - if (toupper ((int) *p1) < toupper ((int) *p2)) - return -1; - else if (toupper ((int) *p1) > toupper ((int) *p2)) - return +1; - - p1 ++, p2 ++; - } - - if (*p1 == '\0') { - if (*p2 == '\0') - return 0; - else - return -1; - } else { - return +1; - } -} - static void ensure_menu_items (EShellUserCreatableItemsHandler *handler) { @@ -239,10 +217,7 @@ ensure_menu_items (EShellUserCreatableItemsHandler *handler) component_num ++; } - if (menu_items == NULL) - priv->menu_items = NULL; - else - priv->menu_items = g_slist_sort (menu_items, item_types_sort_func); + priv->menu_items = menu_items; priv->default_menu_item = NULL; if (default_verb != NULL) { @@ -282,66 +257,27 @@ free_menu_items (GSList *menu_items) } static const MenuItem * -find_menu_item_for_verb (EShellUserCreatableItemsHandler *handler, - const char *verb) -{ - EShellUserCreatableItemsHandlerPrivate *priv; - GSList *p; - - priv = handler->priv; - - for (p = priv->menu_items; p != NULL; p = p->next) { - const MenuItem *item; - - item = (const MenuItem *) p->data; - if (strcmp (item->verb, verb) == 0) - return item; - } - - return NULL; -} - -static const MenuItem * get_default_action_for_view (EShellUserCreatableItemsHandler *handler, EShellView *shell_view) { EShellUserCreatableItemsHandlerPrivate *priv; const char *view_component_id; const GSList *p; - int component_num; priv = handler->priv; - /* FIXME-1.2: This should be based on the folder type not the component - that handles it. For this, we are going to have to make the IDL a - little more complex. Also, this is a pretty brutal and ugly hack. */ - view_component_id = e_shell_view_get_current_component_id (shell_view); if (view_component_id == NULL) return NULL; - for (p = priv->components, component_num = 0; p != NULL; p = p->next, component_num ++) { - const Component *component; - const GNOME_Evolution_UserCreatableItemType *type; - const char *component_id; - - component = (const Component *) p->data; - if (component->type_list->_length == 0) - continue; - - type = & component->type_list->_buffer[0]; - component_id = evolution_shell_component_client_get_id (component->component_client); - - if (strcmp (component_id, view_component_id) == 0) { - const MenuItem *item; - char *verb; - - verb = create_verb_from_component_number_and_type_id (component_num, type->id); - item = find_menu_item_for_verb (handler, verb); - g_free (verb); + for (p = priv->menu_items; p != NULL; p = p->next) { + const MenuItem *item; + item = (const MenuItem *) p->data; + if (item_is_default (item, + e_shell_view_get_current_folder_type (shell_view), + e_shell_view_get_current_component_id (shell_view))) return item; - } } return priv->default_menu_item; @@ -382,25 +318,47 @@ append_xml_for_menu_item (GString *xml, g_free (encoded_tooltip); } -static gboolean -item_is_default (const MenuItem *item, - const char *folder_type, - const char *component_id) +static int +item_types_sort_func (const void *a, + const void *b) { - if (component_id == NULL || folder_type == NULL) - return FALSE; + const MenuItem *item_a; + const MenuItem *item_b; + const char *p1, *p2; - if (item->folder_type != NULL && *item->folder_type != 0) { - if (strcmp (item->folder_type, folder_type) == 0) - return TRUE; - else - return FALSE; + item_a = (const MenuItem *) a; + item_b = (const MenuItem *) b; + + p1 = item_a->label; + p2 = item_b->label; + + while (*p1 != '\0' && *p2 != '\0') { + if (*p1 == '_') { + p1 ++; + continue; + } + + if (*p2 == '_') { + p2 ++; + continue; + } + + if (toupper ((int) *p1) < toupper ((int) *p2)) + return -1; + else if (toupper ((int) *p1) > toupper ((int) *p2)) + return +1; + + p1 ++, p2 ++; } - if (strcmp (item->component_id, component_id) == 0) - return TRUE; - else - return FALSE; + if (*p1 == '\0') { + if (*p2 == '\0') + return 0; + else + return -1; + } else { + return +1; + } } static char * @@ -411,6 +369,7 @@ create_menu_xml (EShellUserCreatableItemsHandler *handler, EShellUserCreatableItemsHandlerPrivate *priv; GString *xml; GSList *p; + GSList *non_default_items; char *retval; priv = handler->priv; @@ -423,8 +382,9 @@ create_menu_xml (EShellUserCreatableItemsHandler *handler, g_string_append (xml, "<placeholder name=\"EShellUserCreatableItemsPlaceholder\">"); /* 1. Add all the elements that are default for this component. (Note - that we don't need to do any sorting since the items are already - sorted alphabetically.) */ + that we don't need to do any sorting since the items are already + sorted alphabetically.) */ + if (component_id != NULL) { gboolean first = TRUE; @@ -440,18 +400,28 @@ create_menu_xml (EShellUserCreatableItemsHandler *handler, } /* 2. Add a separator. */ + if (component_id != NULL) g_string_sprintfa (xml, "<separator f=\"\" name=\"EShellUserCreatableItemsHandlerSeparator\"/>"); /* 3. Add the elements that are not default for this component. */ + + non_default_items = NULL; for (p = priv->menu_items; p != NULL; p = p->next) { const MenuItem *item; item = (const MenuItem *) p->data; if (! item_is_default (item, folder_type, component_id)) - append_xml_for_menu_item (xml, item, FALSE); + non_default_items = g_slist_prepend (non_default_items, (void *) item); } + non_default_items = g_slist_sort (non_default_items, item_types_sort_func); + for (p = non_default_items; p != NULL; p = p->next) + append_xml_for_menu_item (xml, (const MenuItem *) p->data, FALSE); + g_slist_free (non_default_items); + + /* Done... */ + g_string_append (xml, "</placeholder>"); /* EShellUserCreatableItemsPlaceholder */ g_string_append (xml, "</placeholder>"); /* ComponentItems */ |