Move gtkrc-utils from capplets/theme-switcher to capplets/common.

2007-03-04  Thomas Wood  <thos@gnome.org>

	* Makefile.am:
	* gtkrc-utils.c: (gtkrc_get_details):
	* gtkrc-utils.h:
	Move gtkrc-utils from capplets/theme-switcher to capplets/common.

	* gnome-theme-info.c: (gnome_theme_read_meta_theme): Search the gtkrc for
	the colour scheme if none was found in the metatheme file. Fixes a problem
	when comparing two metathemes which only differ by the colour scheme setting.


svn path=/trunk/; revision=7356
This commit is contained in:
Thomas Wood 2007-03-04 17:17:47 +00:00 committed by Thomas Wood
parent 77f371143b
commit 3a4bd9578d
7 changed files with 89 additions and 6 deletions

View file

@ -1,3 +1,14 @@
2007-03-04 Thomas Wood <thos@gnome.org>
* Makefile.am:
* gtkrc-utils.c: (gtkrc_get_details):
* gtkrc-utils.h:
Move gtkrc-utils from theme-switcher to here.
* gnome-theme-info.c: (gnome_theme_read_meta_theme): Search the gtkrc for
the colour scheme if none was found in the metatheme file. Fixes a problem
when comparing two metathemes which only differ by the colour scheme setting.
2007-02-28 Thomas Wood <thos@gnome.org>
* gnome-theme-apply.c: (gnome_meta_theme_set): Set the gtk-color-scheme even

View file

@ -28,7 +28,8 @@ libcommon_la_SOURCES = \
wm-common.c wm-common.h \
capplet-stock-icons.c capplet-stock-icons.h \
theme-thumbnail.c theme-thumbnail.h \
gnome-theme-apply.c gnome-theme-apply.h
gnome-theme-apply.c gnome-theme-apply.h \
gtkrc-utils.c gtkrc-utils.h
libcommon_la_LIBADD = $(top_builddir)/libbackground/libbackground.la \
$(top_builddir)/libwindow-settings/libgnome-window-settings.la \

View file

@ -6,6 +6,7 @@
#include <string.h>
#include <libgnome/gnome-desktop-item.h>
#include "gnome-theme-info.h"
#include "gtkrc-utils.h"
#define THEME_NAME "X-GNOME-Metatheme/Name"
#define THEME_COMMENT "X-GNOME-Metatheme/Comment"
@ -354,6 +355,13 @@ gnome_theme_read_meta_theme (GnomeVFSURI *meta_theme_uri)
meta_theme_info->gtk_theme_name = g_strdup (str);
str = gnome_desktop_item_get_string (meta_theme_ditem, GTK_COLOR_SCHEME_KEY);
if (str == NULL)
{
/* try to find the color scheme from the gtkrc */
gchar *gtkrc_file = gtkrc_find_named (meta_theme_info->gtk_theme_name);
str = gtkrc_get_color_scheme (gtkrc_file);
g_free (gtkrc_file);
}
if (str != NULL)
{
gchar *a;

View file

@ -5,7 +5,7 @@
#define INCLUDE_SYMBOL ((gpointer) 1)
#define ENGINE_SYMBOL ((gpointer) 2)
#define SYMBOLIC_COLOR_SYMBOL ((gpointer) 3)
#define COLOR_SCHEME_SYMBOL ((gpointer) 3)
static gint
str_nequal (gchar *a, gchar *b)
@ -135,4 +135,62 @@ gtkrc_get_details (gchar *filename, GSList **engines, GSList **symbolic_colors)
}
gchar *
gtkrc_get_color_scheme (gchar *filename)
{
gint file = -1;
gchar *result = NULL;
GSList *files = NULL;
GSList *read_files = NULL;
GTokenType token;
GScanner *scanner = g_scanner_new (NULL);
g_scanner_scope_add_symbol (scanner, 0, "include", INCLUDE_SYMBOL);
g_scanner_scope_add_symbol (scanner, 0, "gtk_color_scheme", COLOR_SCHEME_SYMBOL);
files = g_slist_prepend (files, g_strdup (filename));
while (files != NULL)
{
filename = files->data;
files = g_slist_delete_link (files, files);
if (g_slist_find_custom (read_files, filename, (GCompareFunc) str_nequal))
{
g_warning ("Recursion in the gtkrc detected!");
continue; /* skip this file since we've done it before... */
}
read_files = g_slist_prepend (read_files, filename);
file = g_open (filename, O_RDONLY);
if (file == -1)
{
g_warning ("Could not open file \"%s\"", filename);
}
else
{
g_scanner_input_file (scanner, file);
while ((token = g_scanner_get_next_token (scanner)) != G_TOKEN_EOF)
{
GTokenType string_token;
if (token != G_TOKEN_SYMBOL)
continue;
if (scanner->value.v_symbol == COLOR_SCHEME_SYMBOL)
{
if (g_scanner_get_next_token (scanner) != '=')
continue;
string_token = g_scanner_get_next_token (scanner);
if (string_token != G_TOKEN_STRING)
continue;
if (result)
g_free (result);
result = g_strdup (scanner->value.v_string);
}
}
}
}
return result;
}

View file

@ -2,4 +2,4 @@
void gtkrc_get_details (gchar *filename, GSList **engines, GSList **symbolic_colors);
gchar * gtkrc_find_named (const gchar *name);
gchar * gtkrc_get_color_scheme (gchar *filename);

View file

@ -1,3 +1,10 @@
2007-03-04 Thomas Wood <thos@gnome.org>
* Makefile.am:
* gtkrc-utils.c:
* gtkrc-utils.h:
Move gtkrc-utils into capplets/common
2007-02-28 Thomas Wood <thos@gnome.org>
* gnome-theme-details.c: (load_theme_names): Replace a deprecated function

View file

@ -21,9 +21,7 @@ gnome_theme_manager_SOURCES = \
gnome-theme-details.c \
gnome-theme-details.h \
gnome-theme-installer.c \
gnome-theme-installer.h \
gtkrc-utils.c \
gtkrc-utils.h
gnome-theme-installer.h
gnome_theme_manager_LDFLAGS = -export-dynamic