diff options
-rw-r--r-- | src/messages-service.c | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/src/messages-service.c b/src/messages-service.c index b672489..3f0173a 100644 --- a/src/messages-service.c +++ b/src/messages-service.c @@ -687,6 +687,7 @@ resort_menu (DbusmenuMenuitem * menushell) guint position = 0; GList * serverentry; GList * launcherentry = launcherList; + gboolean sep_hidden = FALSE; g_debug("Reordering Menu:"); @@ -706,6 +707,7 @@ resort_menu (DbusmenuMenuitem * menushell) /* Putting the launcher separator in */ g_debug("\tMoving launcher separator to position %d", position); dbusmenu_menuitem_child_reorder(DBUSMENU_MENUITEM(menushell), DBUSMENU_MENUITEM(li->separator), position); + dbusmenu_menuitem_property_set(li->separator, DBUSMENU_MENUITEM_PROP_VISIBLE, "true"); position++; launcherentry = launcherentry->next; @@ -739,10 +741,20 @@ resort_menu (DbusmenuMenuitem * menushell) if (si->separator != NULL) { g_debug("\tMoving app %s separator to position %d", INDICATE_LISTENER_SERVER_DBUS_NAME(si->server), position); dbusmenu_menuitem_child_reorder(DBUSMENU_MENUITEM(menushell), DBUSMENU_MENUITEM(si->separator), position); + dbusmenu_menuitem_property_set(si->separator, DBUSMENU_MENUITEM_PROP_VISIBLE, "true"); position++; } } + /* If there are no more launchers to add we need to hide the + separator on the last application item */ + if (launcherentry == NULL && serverList != NULL) { + serverentry = g_list_last(serverList); + serverList_t * si = (serverList_t *)serverentry->data; + dbusmenu_menuitem_property_set(si->separator, DBUSMENU_MENUITEM_PROP_VISIBLE, "false"); + sep_hidden = TRUE; + } + /* Put any leftover launchers in at the end of the list. */ while (launcherentry != NULL) { launcherList_t * li = (launcherList_t *)launcherentry->data; @@ -755,11 +767,18 @@ resort_menu (DbusmenuMenuitem * menushell) /* Putting the launcher separator in */ g_debug("\tMoving launcher separator to position %d", position); dbusmenu_menuitem_child_reorder(DBUSMENU_MENUITEM(menushell), DBUSMENU_MENUITEM(li->separator), position); + dbusmenu_menuitem_property_set(li->separator, DBUSMENU_MENUITEM_PROP_VISIBLE, "true"); position++; launcherentry = launcherentry->next; } + if (!sep_hidden && launcherList != NULL) { + launcherentry = g_list_last(launcherList); + launcherList_t * li = (launcherList_t *)launcherentry->data; + dbusmenu_menuitem_property_set(li->separator, DBUSMENU_MENUITEM_PROP_VISIBLE, "false"); + } + return; } |