diff options
author | monsta <[email protected]> | 2016-03-13 18:39:49 +0300 |
---|---|---|
committer | monsta <[email protected]> | 2016-03-13 18:39:49 +0300 |
commit | db46e948f57ad16170afeaf72d418c508ef63d1e (patch) | |
tree | d4fbf2d809f6984d356a28419c7811af3504ddc4 | |
parent | ef8676dad5facfc57a815e07588cd607fb8821a7 (diff) | |
download | mate-panel-db46e948f57ad16170afeaf72d418c508ef63d1e.tar.bz2 mate-panel-db46e948f57ad16170afeaf72d418c508ef63d1e.tar.xz |
menubar: some corrections for new max-items-or-submenu key
- remove check for menubar schema as it's already installed along with panel itself
- properly unref menubar_settings object
- make key type unsigned
- drop obsolete MAX_ITEMS_OR_SUBMENU define
-rw-r--r-- | data/org.mate.panel.menubar.gschema.xml.in | 2 | ||||
-rw-r--r-- | mate-panel/panel-menu-items.c | 26 |
2 files changed, 13 insertions, 15 deletions
diff --git a/data/org.mate.panel.menubar.gschema.xml.in b/data/org.mate.panel.menubar.gschema.xml.in index 343880e9..efcd1d63 100644 --- a/data/org.mate.panel.menubar.gschema.xml.in +++ b/data/org.mate.panel.menubar.gschema.xml.in @@ -45,7 +45,7 @@ <summary>Menu items icon size</summary> <description>Set the size of icons used in the menu. The panel must be restarted for this to take effect.</description> </key> - <key name="max-items-or-submenu" type="i"> + <key name="max-items-or-submenu" type="u"> <default>8</default> <summary>Threshold of menu items before submenu is created</summary> <description>Maximum number of menu items (i.e. bookmarks) that are displayed without being put in a submenu.</description> diff --git a/mate-panel/panel-menu-items.c b/mate-panel/panel-menu-items.c index 8955a018..e16e9edc 100644 --- a/mate-panel/panel-menu-items.c +++ b/mate-panel/panel-menu-items.c @@ -58,7 +58,6 @@ #include "panel-schemas.h" #define BOOKMARKS_FILENAME ".gtk-bookmarks" -#define MAX_ITEMS_OR_SUBMENU 8 #define MAX_BOOKMARK_ITEMS 100 G_DEFINE_TYPE(PanelPlaceMenuItem, panel_place_menu_item, GTK_TYPE_IMAGE_MENU_ITEM) @@ -352,7 +351,7 @@ panel_menu_items_create_action_item (PanelActionButtonType action_type) } static void -panel_place_menu_item_append_gtk_bookmarks (GtkWidget *menu, int max_items_or_submenu) +panel_place_menu_item_append_gtk_bookmarks (GtkWidget *menu, guint max_items_or_submenu) { typedef struct { char *full_uri; @@ -907,7 +906,7 @@ panel_place_menu_item_append_local_gio (PanelPlaceMenuItem *place_item, /* now that we have everything, add the items inline or in a submenu */ items = g_slist_reverse (items); - if (g_slist_length (items) <= g_settings_get_int (place_item->priv->menubar_settings, PANEL_MENU_BAR_MAX_ITEMS_OR_SUBMENU)) { + if (g_slist_length (items) <= g_settings_get_uint (place_item->priv->menubar_settings, PANEL_MENU_BAR_MAX_ITEMS_OR_SUBMENU)) { add_menu = menu; } else { GtkWidget *item; @@ -994,7 +993,7 @@ panel_place_menu_item_append_remote_gio (PanelPlaceMenuItem *place_item, } add_mounts = g_slist_reverse (add_mounts); - if (g_slist_length (add_mounts) <= g_settings_get_int (place_item->priv->menubar_settings, PANEL_MENU_BAR_MAX_ITEMS_OR_SUBMENU)) { + if (g_slist_length (add_mounts) <= g_settings_get_uint (place_item->priv->menubar_settings, PANEL_MENU_BAR_MAX_ITEMS_OR_SUBMENU)) { add_menu = menu; } else { GtkWidget *item; @@ -1070,7 +1069,7 @@ panel_place_menu_item_create_menu (PanelPlaceMenuItem *place_item) g_free (uri); } - panel_place_menu_item_append_gtk_bookmarks (places_menu, g_settings_get_int (place_item->priv->menubar_settings, PANEL_MENU_BAR_MAX_ITEMS_OR_SUBMENU)); + panel_place_menu_item_append_gtk_bookmarks (places_menu, g_settings_get_uint (place_item->priv->menubar_settings, PANEL_MENU_BAR_MAX_ITEMS_OR_SUBMENU)); add_menu_separator (places_menu); if (place_item->priv->caja_desktop_settings != NULL) @@ -1276,6 +1275,9 @@ panel_place_menu_item_finalize (GObject *object) menuitem->priv->caja_prefs_settings = NULL; } + g_object_unref (menuitem->priv->menubar_settings); + menuitem->priv->menubar_settings = NULL; + if (menuitem->priv->bookmarks_monitor != NULL) { g_file_monitor_cancel (menuitem->priv->bookmarks_monitor); g_object_unref (menuitem->priv->bookmarks_monitor); @@ -1378,15 +1380,11 @@ panel_place_menu_item_init (PanelPlaceMenuItem *menuitem) else menuitem->priv->caja_prefs_settings = NULL; - if (mate_gsettings_schema_exists (PANEL_MENU_BAR_SCHEMA)) { - menuitem->priv->menubar_settings = g_settings_new (PANEL_MENU_BAR_SCHEMA); - g_signal_connect (menuitem->priv->menubar_settings, - "changed::" PANEL_MENU_BAR_MAX_ITEMS_OR_SUBMENU, - G_CALLBACK (panel_place_menu_item_key_changed), - G_OBJECT (menuitem)); - } - else - menuitem->priv->menubar_settings = NULL; + menuitem->priv->menubar_settings = g_settings_new (PANEL_MENU_BAR_SCHEMA); + g_signal_connect (menuitem->priv->menubar_settings, + "changed::" PANEL_MENU_BAR_MAX_ITEMS_OR_SUBMENU, + G_CALLBACK (panel_place_menu_item_key_changed), + G_OBJECT (menuitem)); menuitem->priv->recent_manager = gtk_recent_manager_get_default (); |