Hook up cursor code.
Tue Feb 19 23:52:17 2002 Jonathan Blandford <jrb@redhat.com> * gnome-mouse-properties.c (cursor_font_changed): Hook up cursor code. Tue Feb 19 23:53:06 2002 Jonathan Blandford <jrb@redhat.com> * gnome-settings-font.c: set the font path and handle cursors.
This commit is contained in:
parent
57cb400a75
commit
03509906b6
12 changed files with 419 additions and 13 deletions
|
@ -1,3 +1,7 @@
|
||||||
|
Tue Feb 19 23:52:17 2002 Jonathan Blandford <jrb@redhat.com>
|
||||||
|
|
||||||
|
* gnome-mouse-properties.c (cursor_font_changed): Hook up cursor code.
|
||||||
|
|
||||||
Fri Feb 8 01:41:40 2002 Jonathan Blandford <jrb@redhat.com>
|
Fri Feb 8 01:41:40 2002 Jonathan Blandford <jrb@redhat.com>
|
||||||
|
|
||||||
* Makefile.am (pixmap_DATA): install cursor images.
|
* Makefile.am (pixmap_DATA): install cursor images.
|
||||||
|
|
|
@ -17,6 +17,13 @@ pixmap_DATA = \
|
||||||
mouse-cursor-normal-large.png \
|
mouse-cursor-normal-large.png \
|
||||||
mouse-cursor-white-large.png
|
mouse-cursor-white-large.png
|
||||||
|
|
||||||
|
|
||||||
|
cursorfontdir = $(datadir)/gnome/cursor-fonts
|
||||||
|
cursorfont_DATA = \
|
||||||
|
cursor-large.pcf.gz \
|
||||||
|
cursor-white.pcf.gz \
|
||||||
|
cursor-large-white.pcf.gz
|
||||||
|
|
||||||
Gladedir = $(GNOMECC_GLADE_DIR)
|
Gladedir = $(GNOMECC_GLADE_DIR)
|
||||||
Glade_DATA = gnome-mouse-properties.glade
|
Glade_DATA = gnome-mouse-properties.glade
|
||||||
|
|
||||||
|
@ -32,5 +39,5 @@ desktop_DATA = $(Desktop_in_files:.desktop.in=.desktop)
|
||||||
|
|
||||||
INCLUDES = $(GNOMECC_CAPPLETS_CFLAGS)
|
INCLUDES = $(GNOMECC_CAPPLETS_CFLAGS)
|
||||||
CLEANFILES = $(GNOMECC_CAPPLETS_CLEANFILES)
|
CLEANFILES = $(GNOMECC_CAPPLETS_CLEANFILES)
|
||||||
EXTRA_DIST = $(Glade_DATA) $(icons_DATA) $(Desktop_in_files) $(pixmap_DATA)
|
EXTRA_DIST = $(Glade_DATA) $(icons_DATA) $(Desktop_in_files) $(pixmap_DATA) $(cursorfont_DATA)
|
||||||
|
|
||||||
|
|
BIN
capplets/mouse/cursor-large-white.pcf.gz
Normal file
BIN
capplets/mouse/cursor-large-white.pcf.gz
Normal file
Binary file not shown.
BIN
capplets/mouse/cursor-large.pcf.gz
Normal file
BIN
capplets/mouse/cursor-large.pcf.gz
Normal file
Binary file not shown.
BIN
capplets/mouse/cursor-white.pcf.gz
Normal file
BIN
capplets/mouse/cursor-white.pcf.gz
Normal file
Binary file not shown.
|
@ -34,6 +34,9 @@
|
||||||
|
|
||||||
#include "capplet-util.h"
|
#include "capplet-util.h"
|
||||||
#include "gconf-property-editor.h"
|
#include "gconf-property-editor.h"
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <dirent.h>
|
||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
|
@ -46,6 +49,7 @@ enum
|
||||||
{
|
{
|
||||||
COLUMN_PIXBUF,
|
COLUMN_PIXBUF,
|
||||||
COLUMN_TEXT,
|
COLUMN_TEXT,
|
||||||
|
COLUMN_FONT_PATH,
|
||||||
N_COLUMNS
|
N_COLUMNS
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -53,7 +57,7 @@ enum
|
||||||
* define the macro */
|
* define the macro */
|
||||||
|
|
||||||
#define DOUBLE_CLICK_KEY "/desktop/gnome/peripherals/mouse/double_click"
|
#define DOUBLE_CLICK_KEY "/desktop/gnome/peripherals/mouse/double_click"
|
||||||
|
#define CURSOR_FONT_KEY "/desktop/gnome/peripherals/mouse/cursor_font"
|
||||||
/* Write-once data; global for convenience. Set only by load_pixbufs */
|
/* Write-once data; global for convenience. Set only by load_pixbufs */
|
||||||
|
|
||||||
GdkPixbuf *left_handed_pixbuf;
|
GdkPixbuf *left_handed_pixbuf;
|
||||||
|
@ -318,13 +322,128 @@ load_pixbufs (void)
|
||||||
called = TRUE;
|
called = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Set up the property editors in the dialog. */
|
static gchar *
|
||||||
|
read_cursor_font (void)
|
||||||
|
{
|
||||||
|
DIR *dir;
|
||||||
|
gchar *dir_name;
|
||||||
|
struct dirent *file_dirent;
|
||||||
|
|
||||||
|
dir_name = g_build_path (G_DIR_SEPARATOR_S, g_get_home_dir (), ".gnome/share/cursor-fonts", NULL);
|
||||||
|
if (! g_file_test (dir_name, G_FILE_TEST_EXISTS))
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
dir = opendir (dir_name);
|
||||||
|
|
||||||
|
while ((file_dirent = readdir (dir)) != NULL) {
|
||||||
|
struct stat st;
|
||||||
|
gchar *link_name;
|
||||||
|
|
||||||
|
link_name = g_build_filename (dir_name, file_dirent->d_name, NULL);
|
||||||
|
if (lstat (link_name, &st)) {
|
||||||
|
g_free (link_name);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (S_ISLNK (st.st_mode)) {
|
||||||
|
gint length;
|
||||||
|
gchar target[256];
|
||||||
|
|
||||||
|
length = readlink (link_name, target, 255);
|
||||||
|
if (length > 0) {
|
||||||
|
gchar *retval;
|
||||||
|
target[length] = '\0';
|
||||||
|
retval = g_strdup (target);
|
||||||
|
g_free (link_name);
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
g_free (link_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
cursor_font_changed (GConfClient *client,
|
||||||
|
guint cnxn_id,
|
||||||
|
GConfEntry *entry,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
GtkTreeView *tree_view;
|
||||||
|
gchar *cursor_font;
|
||||||
|
gchar *cursor_text;
|
||||||
|
GtkTreeIter iter;
|
||||||
|
GtkTreeModel *model;
|
||||||
|
GtkTreeSelection *selection;
|
||||||
|
|
||||||
|
tree_view = GTK_TREE_VIEW (user_data);
|
||||||
|
selection = gtk_tree_view_get_selection (tree_view);
|
||||||
|
model = gtk_tree_view_get_model (tree_view);
|
||||||
|
|
||||||
|
cursor_font = gconf_client_get_string (client, CURSOR_FONT_KEY, NULL);
|
||||||
|
gtk_tree_model_get_iter_root (model, &iter);
|
||||||
|
|
||||||
|
do {
|
||||||
|
gchar *temp_cursor_font;
|
||||||
|
gtk_tree_model_get (model, &iter,
|
||||||
|
COLUMN_FONT_PATH, &temp_cursor_font,
|
||||||
|
-1);
|
||||||
|
if ((temp_cursor_font == NULL && cursor_font == NULL) ||
|
||||||
|
((temp_cursor_font != NULL && cursor_font != NULL) &&
|
||||||
|
(!strcmp (cursor_font, temp_cursor_font)))) {
|
||||||
|
if (!gtk_tree_selection_iter_is_selected (selection, &iter))
|
||||||
|
gtk_tree_selection_select_iter (selection, &iter);
|
||||||
|
g_free (temp_cursor_font);
|
||||||
|
g_free (cursor_font);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
g_free (temp_cursor_font);
|
||||||
|
} while (gtk_tree_model_iter_next (model, &iter));
|
||||||
|
|
||||||
|
/* we didn't find it; we add it to the end. */
|
||||||
|
gtk_list_store_append (GTK_LIST_STORE (model), &iter);
|
||||||
|
cursor_text = g_strdup_printf (_("<b>Unknown Cursor</b>\n%s"), cursor_font);
|
||||||
|
gtk_list_store_set (GTK_LIST_STORE (model), &iter,
|
||||||
|
COLUMN_TEXT, cursor_text,
|
||||||
|
COLUMN_FONT_PATH, cursor_font,
|
||||||
|
-1);
|
||||||
|
gtk_tree_selection_select_iter (selection, &iter);
|
||||||
|
|
||||||
|
g_free (cursor_font);
|
||||||
|
g_free (cursor_text);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
cursor_changed (GtkTreeSelection *selection,
|
||||||
|
gpointer data)
|
||||||
|
{
|
||||||
|
GtkTreeModel *model = NULL;
|
||||||
|
GtkTreeIter iter;
|
||||||
|
gchar *cursor_font = NULL;
|
||||||
|
|
||||||
|
if (! gtk_tree_selection_get_selected (selection, &model, &iter))
|
||||||
|
return;
|
||||||
|
|
||||||
|
gtk_tree_model_get (model, &iter,
|
||||||
|
COLUMN_FONT_PATH, &cursor_font,
|
||||||
|
-1);
|
||||||
|
if (cursor_font != NULL)
|
||||||
|
gconf_client_set_string (gconf_client_get_default (),
|
||||||
|
CURSOR_FONT_KEY, cursor_font, NULL);
|
||||||
|
else
|
||||||
|
gconf_client_unset (gconf_client_get_default (),
|
||||||
|
CURSOR_FONT_KEY, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set up the property editors in the dialog. */
|
||||||
static void
|
static void
|
||||||
setup_dialog (GladeXML *dialog, GConfChangeSet *changeset)
|
setup_dialog (GladeXML *dialog, GConfChangeSet *changeset)
|
||||||
{
|
{
|
||||||
GObject *peditor;
|
GObject *peditor;
|
||||||
GtkWidget *tree_view;
|
GtkWidget *tree_view;
|
||||||
|
GtkTreeSelection *selection;
|
||||||
GtkTreeModel *model;
|
GtkTreeModel *model;
|
||||||
GtkCellRenderer *renderer;
|
GtkCellRenderer *renderer;
|
||||||
GtkTreeViewColumn *column;
|
GtkTreeViewColumn *column;
|
||||||
|
@ -332,10 +451,15 @@ setup_dialog (GladeXML *dialog, GConfChangeSet *changeset)
|
||||||
GConfValue *value;
|
GConfValue *value;
|
||||||
gchar *filename;
|
gchar *filename;
|
||||||
GdkPixbuf *pixbuf;
|
GdkPixbuf *pixbuf;
|
||||||
GnomeProgram *program;
|
GnomeProgram *program;
|
||||||
|
gchar *cursor_font;
|
||||||
|
gchar *font_path;
|
||||||
|
gchar *cursor_string;
|
||||||
|
gboolean found_default;
|
||||||
|
|
||||||
program = gnome_program_get ();
|
program = gnome_program_get ();
|
||||||
|
found_default = FALSE;
|
||||||
|
|
||||||
/* Buttons page */
|
/* Buttons page */
|
||||||
/* Left-handed toggle */
|
/* Left-handed toggle */
|
||||||
peditor = gconf_peditor_new_boolean
|
peditor = gconf_peditor_new_boolean
|
||||||
|
@ -352,8 +476,13 @@ setup_dialog (GladeXML *dialog, GConfChangeSet *changeset)
|
||||||
|
|
||||||
/* Cursors page */
|
/* Cursors page */
|
||||||
tree_view = WID ("cursor_tree");
|
tree_view = WID ("cursor_tree");
|
||||||
model = (GtkTreeModel *) gtk_list_store_new (N_COLUMNS, GDK_TYPE_PIXBUF, G_TYPE_STRING);
|
cursor_font = read_cursor_font ();
|
||||||
|
|
||||||
|
model = (GtkTreeModel *) gtk_list_store_new (N_COLUMNS, GDK_TYPE_PIXBUF, G_TYPE_STRING, G_TYPE_STRING);
|
||||||
gtk_tree_view_set_model (GTK_TREE_VIEW (tree_view), model);
|
gtk_tree_view_set_model (GTK_TREE_VIEW (tree_view), model);
|
||||||
|
selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (tree_view));
|
||||||
|
gtk_tree_selection_set_mode (selection, GTK_SELECTION_BROWSE);
|
||||||
|
g_signal_connect (G_OBJECT (selection), "changed", G_CALLBACK (cursor_changed), NULL);
|
||||||
column = gtk_tree_view_column_new ();
|
column = gtk_tree_view_column_new ();
|
||||||
renderer = gtk_cell_renderer_pixbuf_new ();
|
renderer = gtk_cell_renderer_pixbuf_new ();
|
||||||
gtk_tree_view_column_pack_start (column, renderer, FALSE);
|
gtk_tree_view_column_pack_start (column, renderer, FALSE);
|
||||||
|
@ -366,44 +495,91 @@ setup_dialog (GladeXML *dialog, GConfChangeSet *changeset)
|
||||||
"markup", COLUMN_TEXT,
|
"markup", COLUMN_TEXT,
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
|
/* Default cursor */
|
||||||
filename = gnome_program_locate_file (program, GNOME_FILE_DOMAIN_APP_PIXMAP, "mouse-cursor-normal.png", TRUE, NULL);
|
filename = gnome_program_locate_file (program, GNOME_FILE_DOMAIN_APP_PIXMAP, "mouse-cursor-normal.png", TRUE, NULL);
|
||||||
pixbuf = gdk_pixbuf_new_from_file (filename, NULL);
|
pixbuf = gdk_pixbuf_new_from_file (filename, NULL);
|
||||||
g_free (filename);
|
g_free (filename);
|
||||||
|
|
||||||
gtk_list_store_append (GTK_LIST_STORE (model), &iter);
|
gtk_list_store_append (GTK_LIST_STORE (model), &iter);
|
||||||
|
if (cursor_font == NULL) {
|
||||||
|
cursor_string = _("<b>Default Cursor - Current</b>\nThe default cursor that ships with X");
|
||||||
|
found_default = TRUE;
|
||||||
|
} else {
|
||||||
|
cursor_string = _("<b>Default Cursor</b>\nThe default cursor that ships with X");
|
||||||
|
}
|
||||||
|
|
||||||
gtk_list_store_set (GTK_LIST_STORE (model), &iter,
|
gtk_list_store_set (GTK_LIST_STORE (model), &iter,
|
||||||
COLUMN_PIXBUF, pixbuf,
|
COLUMN_PIXBUF, pixbuf,
|
||||||
COLUMN_TEXT, "<b>Default Cursor</b>\nThe default cursor that ships with X",
|
COLUMN_TEXT, cursor_string,
|
||||||
|
COLUMN_FONT_PATH, NULL,
|
||||||
-1);
|
-1);
|
||||||
|
|
||||||
|
|
||||||
|
/* Inverted cursor */
|
||||||
filename = gnome_program_locate_file (program, GNOME_FILE_DOMAIN_APP_PIXMAP, "mouse-cursor-white.png", TRUE, NULL);
|
filename = gnome_program_locate_file (program, GNOME_FILE_DOMAIN_APP_PIXMAP, "mouse-cursor-white.png", TRUE, NULL);
|
||||||
pixbuf = gdk_pixbuf_new_from_file (filename, NULL);
|
pixbuf = gdk_pixbuf_new_from_file (filename, NULL);
|
||||||
g_free (filename);
|
g_free (filename);
|
||||||
|
font_path = gnome_program_locate_file (program, GNOME_FILE_DOMAIN_DATADIR, "gnome/cursor-fonts/cursor-white.pcf.gz", FALSE, NULL);
|
||||||
|
|
||||||
gtk_list_store_append (GTK_LIST_STORE (model), &iter);
|
gtk_list_store_append (GTK_LIST_STORE (model), &iter);
|
||||||
|
if (cursor_font && ! strcmp (cursor_font, font_path)) {
|
||||||
|
cursor_string = _("<b>White Cursor - Current</b>\nThe default cursor inverted");
|
||||||
|
found_default = TRUE;
|
||||||
|
} else {
|
||||||
|
cursor_string = _("<b>White Cursor</b>\nThe default cursor inverted");
|
||||||
|
}
|
||||||
|
|
||||||
gtk_list_store_set (GTK_LIST_STORE (model), &iter,
|
gtk_list_store_set (GTK_LIST_STORE (model), &iter,
|
||||||
COLUMN_PIXBUF, pixbuf,
|
COLUMN_PIXBUF, pixbuf,
|
||||||
COLUMN_TEXT, "<b>White Cursor</b>\nThe default cursor inverted",
|
COLUMN_TEXT, cursor_string,
|
||||||
|
COLUMN_FONT_PATH, font_path,
|
||||||
-1);
|
-1);
|
||||||
|
g_free (font_path);
|
||||||
|
|
||||||
|
/* Large cursor */
|
||||||
filename = gnome_program_locate_file (program, GNOME_FILE_DOMAIN_APP_PIXMAP, "mouse-cursor-normal-large.png", TRUE, NULL);
|
filename = gnome_program_locate_file (program, GNOME_FILE_DOMAIN_APP_PIXMAP, "mouse-cursor-normal-large.png", TRUE, NULL);
|
||||||
pixbuf = gdk_pixbuf_new_from_file (filename, NULL);
|
pixbuf = gdk_pixbuf_new_from_file (filename, NULL);
|
||||||
g_free (filename);
|
g_free (filename);
|
||||||
|
font_path = gnome_program_locate_file (program, GNOME_FILE_DOMAIN_DATADIR, "gnome/cursor-fonts/cursor-large.pcf.gz", FALSE, NULL);
|
||||||
|
|
||||||
gtk_list_store_append (GTK_LIST_STORE (model), &iter);
|
gtk_list_store_append (GTK_LIST_STORE (model), &iter);
|
||||||
|
if (cursor_font && ! strcmp (cursor_font, font_path)) {
|
||||||
|
cursor_string = _("<b>Large Cursor - Current</b>\nLarge version of normal cursor");
|
||||||
|
found_default = TRUE;
|
||||||
|
} else {
|
||||||
|
cursor_string = _("<b>Large Cursor</b>\nLarge version of normal cursor");
|
||||||
|
}
|
||||||
|
|
||||||
gtk_list_store_set (GTK_LIST_STORE (model), &iter,
|
gtk_list_store_set (GTK_LIST_STORE (model), &iter,
|
||||||
COLUMN_PIXBUF, pixbuf,
|
COLUMN_PIXBUF, pixbuf,
|
||||||
COLUMN_TEXT, "<b>Large Cursor</b>\nLarge version of normal cursor",
|
COLUMN_TEXT, cursor_string,
|
||||||
|
COLUMN_FONT_PATH, font_path,
|
||||||
-1);
|
-1);
|
||||||
|
g_free (font_path);
|
||||||
|
|
||||||
|
/* Large inverted cursor */
|
||||||
filename = gnome_program_locate_file (program, GNOME_FILE_DOMAIN_APP_PIXMAP, "mouse-cursor-white-large.png", TRUE, NULL);
|
filename = gnome_program_locate_file (program, GNOME_FILE_DOMAIN_APP_PIXMAP, "mouse-cursor-white-large.png", TRUE, NULL);
|
||||||
pixbuf = gdk_pixbuf_new_from_file (filename, NULL);
|
pixbuf = gdk_pixbuf_new_from_file (filename, NULL);
|
||||||
g_free (filename);
|
g_free (filename);
|
||||||
|
font_path = gnome_program_locate_file (program, GNOME_FILE_DOMAIN_DATADIR, "gnome/cursor-fonts/cursor-large-white.pcf.gz", FALSE, NULL);
|
||||||
|
|
||||||
gtk_list_store_append (GTK_LIST_STORE (model), &iter);
|
gtk_list_store_append (GTK_LIST_STORE (model), &iter);
|
||||||
|
if (cursor_font && ! strcmp (cursor_font, font_path)) {
|
||||||
|
cursor_string = _("<b>Large White Cursor - Current</b>\nLarge version of white cursor");
|
||||||
|
found_default = TRUE;
|
||||||
|
} else {
|
||||||
|
cursor_string = _("<b>Large White Cursor</b>\nLarge version of white cursor");
|
||||||
|
}
|
||||||
|
|
||||||
gtk_list_store_set (GTK_LIST_STORE (model), &iter,
|
gtk_list_store_set (GTK_LIST_STORE (model), &iter,
|
||||||
COLUMN_PIXBUF, pixbuf,
|
COLUMN_PIXBUF, pixbuf,
|
||||||
COLUMN_TEXT, "<b>Large White Cursor</b>\nLarge version of white cursor",
|
COLUMN_TEXT, cursor_string,
|
||||||
|
COLUMN_FONT_PATH, font_path,
|
||||||
-1);
|
-1);
|
||||||
|
g_free (font_path);
|
||||||
|
|
||||||
gtk_tree_view_append_column (GTK_TREE_VIEW (tree_view), column);
|
gtk_tree_view_append_column (GTK_TREE_VIEW (tree_view), column);
|
||||||
|
|
||||||
|
|
||||||
gconf_peditor_new_boolean
|
gconf_peditor_new_boolean
|
||||||
(changeset, "/desktop/gnome/peripherals/mouse/locate_pointer_id", WID ("locate_pointer_toggle"), NULL);
|
(changeset, "/desktop/gnome/peripherals/mouse/locate_pointer_id", WID ("locate_pointer_toggle"), NULL);
|
||||||
/* Motion page */
|
/* Motion page */
|
||||||
|
@ -432,6 +608,15 @@ setup_dialog (GladeXML *dialog, GConfChangeSet *changeset)
|
||||||
"conv-to-widget-cb", threshold_from_gconf,
|
"conv-to-widget-cb", threshold_from_gconf,
|
||||||
"conv-from-widget-cb", gconf_value_float_to_int,
|
"conv-from-widget-cb", gconf_value_float_to_int,
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
|
/* listen to cursors changing */
|
||||||
|
gconf_client_notify_add (gconf_client_get_default (),
|
||||||
|
CURSOR_FONT_KEY, /* dir or key to listen to */
|
||||||
|
cursor_font_changed,
|
||||||
|
tree_view, NULL, NULL);
|
||||||
|
|
||||||
|
/* and set it up initially... */
|
||||||
|
cursor_font_changed (gconf_client_get_default (), 0, NULL, tree_view);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Construct the dialog */
|
/* Construct the dialog */
|
||||||
|
|
|
@ -352,7 +352,9 @@
|
||||||
</child>
|
</child>
|
||||||
<child>
|
<child>
|
||||||
<widget class="GtkLabel" id="label19">
|
<widget class="GtkLabel" id="label19">
|
||||||
<property name="label" translatable="yes"><b>Note:</b> You will need to logout for this setting to take effect.</property>
|
<property name="label"
|
||||||
|
translatable="yes"><b>Note:</b>
|
||||||
|
You will need to logout and log back in for this setting to take effect.</property>
|
||||||
<property name="justify">GTK_JUSTIFY_LEFT</property>
|
<property name="justify">GTK_JUSTIFY_LEFT</property>
|
||||||
<property name="wrap">yes</property>
|
<property name="wrap">yes</property>
|
||||||
<property name="use_markup">yes</property>
|
<property name="use_markup">yes</property>
|
||||||
|
|
|
@ -1,3 +1,7 @@
|
||||||
|
Tue Feb 19 23:53:06 2002 Jonathan Blandford <jrb@redhat.com>
|
||||||
|
|
||||||
|
* gnome-settings-font.c: set the font path and handle cursors.
|
||||||
|
|
||||||
2002-02-13 Lauris Kaplinski <lauris@ximian.com>
|
2002-02-13 Lauris Kaplinski <lauris@ximian.com>
|
||||||
|
|
||||||
* gnome-settings-xsettings.c: #include <string.h> to kill warning
|
* gnome-settings-xsettings.c: #include <string.h> to kill warning
|
||||||
|
|
|
@ -5,6 +5,8 @@ bin_PROGRAMS=gnome2-settings-daemon
|
||||||
gnome2_settings_daemon_SOURCES = \
|
gnome2_settings_daemon_SOURCES = \
|
||||||
gnome-settings-daemon.h \
|
gnome-settings-daemon.h \
|
||||||
gnome-settings-daemon.c \
|
gnome-settings-daemon.c \
|
||||||
|
gnome-settings-font.h \
|
||||||
|
gnome-settings-font.c \
|
||||||
gnome-settings-mouse.h \
|
gnome-settings-mouse.h \
|
||||||
gnome-settings-mouse.c \
|
gnome-settings-mouse.c \
|
||||||
gnome-settings-keyboard.h \
|
gnome-settings-keyboard.h \
|
||||||
|
|
|
@ -36,6 +36,7 @@
|
||||||
#include "gnome-settings-daemon.h"
|
#include "gnome-settings-daemon.h"
|
||||||
|
|
||||||
#include "gnome-settings-xsettings.h"
|
#include "gnome-settings-xsettings.h"
|
||||||
|
#include "gnome-settings-font.h"
|
||||||
#include "gnome-settings-mouse.h"
|
#include "gnome-settings-mouse.h"
|
||||||
#include "gnome-settings-keyboard.h"
|
#include "gnome-settings-keyboard.h"
|
||||||
#include "gnome-settings-background.h"
|
#include "gnome-settings-background.h"
|
||||||
|
@ -168,6 +169,7 @@ main (int argc, char **argv)
|
||||||
*/
|
*/
|
||||||
client = gconf_client_get_default ();
|
client = gconf_client_get_default ();
|
||||||
gnome_settings_xsettings_init (client);
|
gnome_settings_xsettings_init (client);
|
||||||
|
gnome_settings_font_init (client);
|
||||||
gnome_settings_mouse_init (client);
|
gnome_settings_mouse_init (client);
|
||||||
gnome_settings_keyboard_init (client);
|
gnome_settings_keyboard_init (client);
|
||||||
gnome_settings_background_init (client);
|
gnome_settings_background_init (client);
|
||||||
|
@ -200,6 +202,7 @@ main (int argc, char **argv)
|
||||||
|
|
||||||
gdk_window_add_filter (NULL, manager_event_filter, NULL);
|
gdk_window_add_filter (NULL, manager_event_filter, NULL);
|
||||||
gnome_settings_xsettings_load (client);
|
gnome_settings_xsettings_load (client);
|
||||||
|
gnome_settings_font_load (client);
|
||||||
gnome_settings_mouse_load (client);
|
gnome_settings_mouse_load (client);
|
||||||
gnome_settings_sound_load (client);
|
gnome_settings_sound_load (client);
|
||||||
gnome_settings_background_load (client);
|
gnome_settings_background_load (client);
|
||||||
|
|
174
gnome-settings-daemon/gnome-settings-font.c
Normal file
174
gnome-settings-daemon/gnome-settings-font.c
Normal file
|
@ -0,0 +1,174 @@
|
||||||
|
#include <gdk/gdkx.h>
|
||||||
|
#include <gconf/gconf.h>
|
||||||
|
#include "gnome-settings-daemon.h"
|
||||||
|
#include <dirent.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <dirent.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
load_cursor (GConfClient *client)
|
||||||
|
{
|
||||||
|
DIR *dir;
|
||||||
|
gchar *font_dir_name;
|
||||||
|
gchar *dir_name;
|
||||||
|
struct dirent *file_dirent;
|
||||||
|
gchar *cursor_font;
|
||||||
|
gchar **font_path;
|
||||||
|
gchar **new_font_path;
|
||||||
|
gint n_fonts;
|
||||||
|
gint new_n_fonts;
|
||||||
|
gint i;
|
||||||
|
gchar *mkfontdir_cmd;
|
||||||
|
|
||||||
|
/* setting up the dir */
|
||||||
|
font_dir_name = g_build_path (G_DIR_SEPARATOR_S, g_get_home_dir (), ".gnome", NULL);
|
||||||
|
if (! g_file_test (font_dir_name, G_FILE_TEST_EXISTS))
|
||||||
|
mkdir (font_dir_name, 0755);
|
||||||
|
g_free (font_dir_name);
|
||||||
|
|
||||||
|
font_dir_name = g_build_path (G_DIR_SEPARATOR_S, g_get_home_dir (), ".gnome/share", NULL);
|
||||||
|
if (! g_file_test (font_dir_name, G_FILE_TEST_EXISTS))
|
||||||
|
mkdir (font_dir_name, 0755);
|
||||||
|
g_free (font_dir_name);
|
||||||
|
|
||||||
|
font_dir_name = g_build_path (G_DIR_SEPARATOR_S, g_get_home_dir (), ".gnome/share/fonts", NULL);
|
||||||
|
if (! g_file_test (font_dir_name, G_FILE_TEST_EXISTS))
|
||||||
|
mkdir (font_dir_name, 0755);
|
||||||
|
|
||||||
|
if (! g_file_test (font_dir_name, G_FILE_TEST_IS_DIR))
|
||||||
|
{
|
||||||
|
GtkWidget *dialog;
|
||||||
|
|
||||||
|
dialog = gtk_message_dialog_new (NULL,
|
||||||
|
0,
|
||||||
|
GTK_MESSAGE_ERROR,
|
||||||
|
GTK_BUTTONS_CLOSE,
|
||||||
|
"Cannot create the directory \"%s\".\n"\
|
||||||
|
"This is needed to allow changing cursors.",
|
||||||
|
font_dir_name);
|
||||||
|
gtk_dialog_run (GTK_DIALOG (dialog));
|
||||||
|
gtk_widget_destroy (dialog);
|
||||||
|
g_free (font_dir_name);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
dir_name = g_build_path (G_DIR_SEPARATOR_S, g_get_home_dir (), ".gnome/share/cursor-fonts", NULL);
|
||||||
|
if (! g_file_test (dir_name, G_FILE_TEST_EXISTS))
|
||||||
|
mkdir (dir_name, 0755);
|
||||||
|
|
||||||
|
if (! g_file_test (dir_name, G_FILE_TEST_IS_DIR))
|
||||||
|
{
|
||||||
|
GtkWidget *dialog;
|
||||||
|
|
||||||
|
dialog = gtk_message_dialog_new (NULL,
|
||||||
|
0,
|
||||||
|
GTK_MESSAGE_ERROR,
|
||||||
|
GTK_BUTTONS_CLOSE,
|
||||||
|
"Cannot create the directory \"%s\".\n"\
|
||||||
|
"This is needed to allow changing cursors.",
|
||||||
|
dir_name);
|
||||||
|
gtk_dialog_run (GTK_DIALOG (dialog));
|
||||||
|
gtk_widget_destroy (dialog);
|
||||||
|
g_free (dir_name);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
dir = opendir (dir_name);
|
||||||
|
|
||||||
|
while ((file_dirent = readdir (dir)) != NULL)
|
||||||
|
{
|
||||||
|
struct stat st;
|
||||||
|
gchar *link_name;
|
||||||
|
|
||||||
|
link_name = g_build_filename (dir_name, file_dirent->d_name, NULL);
|
||||||
|
if (lstat (link_name, &st))
|
||||||
|
{
|
||||||
|
g_free (link_name);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (S_ISLNK (st.st_mode))
|
||||||
|
unlink (link_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
closedir (dir);
|
||||||
|
|
||||||
|
cursor_font = gconf_client_get_string (client,
|
||||||
|
"/desktop/gnome/peripherals/mouse/cursor_font",
|
||||||
|
NULL);
|
||||||
|
|
||||||
|
if ((cursor_font != NULL) &&
|
||||||
|
(g_file_test (cursor_font, G_FILE_TEST_IS_REGULAR)) &&
|
||||||
|
(g_path_is_absolute (cursor_font)))
|
||||||
|
{
|
||||||
|
gchar *newpath;
|
||||||
|
gchar *font_name;
|
||||||
|
|
||||||
|
font_name = strrchr (cursor_font, G_DIR_SEPARATOR);
|
||||||
|
newpath = g_build_filename (dir_name, font_name);
|
||||||
|
symlink (cursor_font, newpath);
|
||||||
|
g_free (newpath);
|
||||||
|
}
|
||||||
|
g_free (cursor_font);
|
||||||
|
|
||||||
|
|
||||||
|
/* run mkfontdir */
|
||||||
|
mkfontdir_cmd = g_strdup_printf ("mkfontdir %s %s", dir_name, font_dir_name);
|
||||||
|
g_spawn_command_line_async (mkfontdir_cmd, NULL);
|
||||||
|
g_free (mkfontdir_cmd);
|
||||||
|
|
||||||
|
/* Set the font path */
|
||||||
|
font_path = XGetFontPath (gdk_x11_get_default_xdisplay (), &n_fonts);
|
||||||
|
new_n_fonts = n_fonts;
|
||||||
|
if (n_fonts == 0 || strcmp (font_path[0], dir_name))
|
||||||
|
new_n_fonts++;
|
||||||
|
if (n_fonts == 0 || strcmp (font_path[n_fonts-1], font_dir_name))
|
||||||
|
new_n_fonts++;
|
||||||
|
|
||||||
|
new_font_path = g_new0 (gchar*, new_n_fonts);
|
||||||
|
if (n_fonts == 0 || strcmp (font_path[0], dir_name))
|
||||||
|
{
|
||||||
|
new_font_path[0] = dir_name;
|
||||||
|
for (i = 0; i < n_fonts; i++)
|
||||||
|
new_font_path [i+1] = font_path [i];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (i = 0; i < n_fonts; i++)
|
||||||
|
new_font_path [i] = font_path [i];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (n_fonts == 0 || strcmp (font_path[n_fonts-1], font_dir_name))
|
||||||
|
{
|
||||||
|
new_font_path[new_n_fonts-1] = font_dir_name;
|
||||||
|
}
|
||||||
|
|
||||||
|
gdk_error_trap_push ();
|
||||||
|
XSetFontPath (gdk_display, new_font_path, new_n_fonts);
|
||||||
|
gdk_flush ();
|
||||||
|
gdk_error_trap_pop ();
|
||||||
|
|
||||||
|
XFreeFontPath (font_path);
|
||||||
|
|
||||||
|
g_free (new_font_path);
|
||||||
|
g_free (font_dir_name);
|
||||||
|
g_free (dir_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
gnome_settings_font_init (GConfClient *client)
|
||||||
|
{
|
||||||
|
load_cursor (client);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
gnome_settings_font_load (GConfClient *client)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
25
gnome-settings-daemon/gnome-settings-font.h
Normal file
25
gnome-settings-daemon/gnome-settings-font.h
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
/*
|
||||||
|
* Copyright © 2001 Jonathan Blandford <jrb@gnome.org>
|
||||||
|
*
|
||||||
|
* Permission to use, copy, modify, distribute, and sell this software and its
|
||||||
|
* documentation for any purpose is hereby granted without fee, provided that
|
||||||
|
* the above copyright notice appear in all copies and that both that
|
||||||
|
* copyright notice and this permission notice appear in supporting
|
||||||
|
* documentation, and that the name of Red Hat not be used in advertising or
|
||||||
|
* publicity pertaining to distribution of the software without specific,
|
||||||
|
* written prior permission. Red Hat makes no representations about the
|
||||||
|
* suitability of this software for any purpose. It is provided "as is"
|
||||||
|
* without express or implied warranty.
|
||||||
|
*
|
||||||
|
* Authors: Jonathan Blandford
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef FONT_SETTINGS_H
|
||||||
|
#define FONT_SETTINGS_H
|
||||||
|
|
||||||
|
#include <gconf/gconf.h>
|
||||||
|
|
||||||
|
void gnome_settings_font_init (GConfClient *client);
|
||||||
|
void gnome_settings_font_load (GConfClient *client);
|
||||||
|
|
||||||
|
#endif
|
Loading…
Add table
Add a link
Reference in a new issue