#include "gtkwidget.h"
#include "gtkprivate.h"
#include "gtkcssproviderprivate.h"
+#include "gtkstyleproviderprivate.h"
#include "gtksymboliccolor.h"
#include "gtktypebuiltins.h"
#include "gtkversion.h"
GdkScreen *screen;
GtkCssProvider *theme_provider;
GtkCssProvider *key_theme_provider;
+ GtkStyleProperties *style;
};
typedef enum
PROP_COLOR_PALETTE,
PROP_IM_PREEDIT_STYLE,
PROP_IM_STATUS_STYLE,
- PROP_SHELL_SHOWS_APP_MENU
+ PROP_SHELL_SHOWS_APP_MENU,
+ PROP_SHELL_SHOWS_MENUBAR
};
/* --- prototypes --- */
static void gtk_settings_provider_iface_init (GtkStyleProviderIface *iface);
+static void gtk_settings_provider_private_init (GtkStyleProviderPrivateInterface *iface);
static void gtk_settings_finalize (GObject *object);
static void gtk_settings_get_property (GObject *object,
G_DEFINE_TYPE_EXTENDED (GtkSettings, gtk_settings, G_TYPE_OBJECT, 0,
G_IMPLEMENT_INTERFACE (GTK_TYPE_STYLE_PROVIDER,
- gtk_settings_provider_iface_init));
+ gtk_settings_provider_iface_init)
+ G_IMPLEMENT_INTERFACE (GTK_TYPE_STYLE_PROVIDER_PRIVATE,
+ gtk_settings_provider_private_init));
/* --- functions --- */
static void
NULL);
g_assert (result == PROP_SHELL_SHOWS_APP_MENU);
+ result = settings_install_property_parser (class,
+ g_param_spec_boolean ("gtk-shell-shows-menubar",
+ P_("Desktop shell shows the menubar"),
+ P_("Set to TRUE if the desktop environment "
+ "is displaying the menubar, FALSE if "
+ "the app should display it itself."),
+ FALSE, GTK_PARAM_READWRITE),
+ NULL);
+ g_assert (result == PROP_SHELL_SHOWS_MENUBAR);
g_type_class_add_private (class, sizeof (GtkSettingsPrivate));
}
-static GtkStyleProperties *
-gtk_settings_get_style (GtkStyleProvider *provider,
- GtkWidgetPath *path)
+static void
+settings_ensure_style (GtkSettings *settings)
{
+ GtkSettingsPrivate *priv = settings->priv;
PangoFontDescription *font_desc;
gchar *font_name, *color_scheme;
- GtkSettings *settings;
- GtkStyleProperties *props;
gchar **colors;
guint i;
- settings = GTK_SETTINGS (provider);
- props = gtk_style_properties_new ();
+ if (priv->style)
+ return;
+
+ priv->style = gtk_style_properties_new ();
g_object_get (settings,
"gtk-font-name", &font_name,
continue;
color = gtk_symbolic_color_new_literal (&col);
- gtk_style_properties_map_color (props, name, color);
+ gtk_style_properties_map_color (priv->style, name, color);
gtk_symbolic_color_unref (color);
}
pango_font_description_unset_fields (font_desc,
PANGO_FONT_MASK_STYLE);
- gtk_style_properties_set (props, 0,
+ gtk_style_properties_set (priv->style, 0,
"font", font_desc,
NULL);
g_strfreev (colors);
g_free (color_scheme);
g_free (font_name);
+}
+
+static GtkStyleProperties *
+gtk_settings_get_style (GtkStyleProvider *provider,
+ GtkWidgetPath *path)
+{
+ GtkSettings *settings;
+
+ settings = GTK_SETTINGS (provider);
+
+ settings_ensure_style (settings);
- return props;
+ return g_object_ref (settings->priv->style);
}
static void
iface->get_style = gtk_settings_get_style;
}
+static GtkSymbolicColor *
+gtk_settings_style_provider_get_color (GtkStyleProviderPrivate *provider,
+ const char *name)
+{
+ GtkSettings *settings = GTK_SETTINGS (provider);
+
+ settings_ensure_style (settings);
+
+ return _gtk_style_provider_private_get_color (GTK_STYLE_PROVIDER_PRIVATE (settings->priv->style), name);
+}
+
+static void
+gtk_settings_style_provider_lookup (GtkStyleProviderPrivate *provider,
+ GtkWidgetPath *path,
+ GtkStateFlags state,
+ GtkCssLookup *lookup)
+{
+ GtkSettings *settings = GTK_SETTINGS (provider);
+
+ settings_ensure_style (settings);
+
+ _gtk_style_provider_private_lookup (GTK_STYLE_PROVIDER_PRIVATE (settings->priv->style),
+ path,
+ state,
+ lookup);
+}
+
+static void
+gtk_settings_provider_private_init (GtkStyleProviderPrivateInterface *iface)
+{
+ iface->get_color = gtk_settings_style_provider_get_color;
+ iface->lookup = gtk_settings_style_provider_lookup;
+}
+
static void
gtk_settings_finalize (GObject *object)
{
if (priv->key_theme_provider)
g_object_unref (priv->key_theme_provider);
+ if (priv->style)
+ g_object_unref (priv->style);
+
G_OBJECT_CLASS (gtk_settings_parent_class)->finalize (object);
}
{
#ifdef GDK_WINDOWING_QUARTZ
if (GDK_IS_QUARTZ_SCREEN (screen))
- settings = g_object_new (GTK_TYPE_SETTINGS, "gtk-key-theme-name", "Mac", NULL);
+ settings = g_object_new (GTK_TYPE_SETTINGS,
+ "gtk-key-theme-name", "Mac",
+ "gtk-shell-shows-app-menu", TRUE,
+ "gtk-shell-shows-menubar", TRUE,
+ NULL);
else
#endif
settings = g_object_new (GTK_TYPE_SETTINGS, NULL);
}
}
+static void
+settings_invalidate_style (GtkSettings *settings)
+{
+ GtkSettingsPrivate *priv = settings->priv;
+
+ if (priv->style)
+ {
+ g_object_unref (priv->style);
+ priv->style = NULL;
+ }
+}
+
static void
gtk_settings_notify (GObject *object,
GParamSpec *pspec)
break;
case PROP_COLOR_SCHEME:
settings_update_color_scheme (settings);
+ settings_invalidate_style (settings);
gtk_style_context_reset_widgets (priv->screen);
break;
case PROP_FONT_NAME:
+ settings_invalidate_style (settings);
gtk_style_context_reset_widgets (priv->screen);
break;
case PROP_KEY_THEME_NAME: