#143487 Calls the modmap load dialog. Loads the modmap files. Added newly
2005-01-29 Shakti Sen <shprasad@novell.com> #143487 * gnome-settings-keyboard-xkb.c (gnome_settings_keyboard_xkb_chk_lcl_xmm): Calls the modmap load dialog. * gnome-settings-daemon.c (gnome_settings_daemon_new): Loads the modmap files. * gnome-settings-xmodmap.h: Added newly * gnome-settings-xmodmap.c: Also added newly which handles the modmap settings. * modmap-dialog.glade: Added newly.
This commit is contained in:
parent
0bfbf3610a
commit
0c21cb9f45
5 changed files with 93 additions and 40 deletions
|
@ -1,3 +1,17 @@
|
||||||
|
2005-01-29 Shakti Sen <shprasad@novell.com>
|
||||||
|
|
||||||
|
* gnome-settings-keyboard-xkb.c
|
||||||
|
(gnome_settings_keyboard_xkb_chk_lcl_xmm): Calls the modmap load
|
||||||
|
dialog.
|
||||||
|
* gnome-settings-daemon.c (gnome_settings_daemon_new):
|
||||||
|
Loads the modmap files.
|
||||||
|
* gnome-settings-xmodmap.h: Added newly
|
||||||
|
* gnome-settings-xmodmap.c: Also added newly which handles the modmap
|
||||||
|
settings.
|
||||||
|
* modmap-dialog.glade: Added newly.
|
||||||
|
|
||||||
|
Solved bug #143487
|
||||||
|
|
||||||
2005-01-12 Sebastien Bacher <seb128@debian.org>
|
2005-01-12 Sebastien Bacher <seb128@debian.org>
|
||||||
|
|
||||||
* gnome-settings-accessibility-keyboard.c: (warning_dialog_post):
|
* gnome-settings-accessibility-keyboard.c: (warning_dialog_post):
|
||||||
|
|
|
@ -53,6 +53,8 @@ gnome_settings_daemon_SOURCES = \
|
||||||
gnome-settings-typing-break.h \
|
gnome-settings-typing-break.h \
|
||||||
reaper.c \
|
reaper.c \
|
||||||
reaper.h \
|
reaper.h \
|
||||||
|
gnome-settings-xmodmap.c \
|
||||||
|
gnome-settings-xmodmap.h \
|
||||||
$(CORBA_GENERATED)
|
$(CORBA_GENERATED)
|
||||||
|
|
||||||
# $(AccessX_files)
|
# $(AccessX_files)
|
||||||
|
@ -92,13 +94,16 @@ IDL_FLAGS = -D__GNOME_SettingsDaemon_COMPILATION -I $(idl_dir) -I $(datadir)/idl
|
||||||
$(CORBA_GENERATED): $(idl_dir)/GNOME_SettingsDaemon.idl $(ORBIT_IDL)
|
$(CORBA_GENERATED): $(idl_dir)/GNOME_SettingsDaemon.idl $(ORBIT_IDL)
|
||||||
$(ORBIT_IDL) $(IDL_FLAGS) $(idl_dir)/GNOME_SettingsDaemon.idl
|
$(ORBIT_IDL) $(IDL_FLAGS) $(idl_dir)/GNOME_SettingsDaemon.idl
|
||||||
|
|
||||||
|
Gladedir = $(GNOMECC_GLADE_DIR)
|
||||||
|
Glade_DATA = modmap-dialog.glade
|
||||||
|
|
||||||
serverfile = GNOME_SettingsDaemon.server.in
|
serverfile = GNOME_SettingsDaemon.server.in
|
||||||
serverdir = $(libdir)/bonobo/servers
|
serverdir = $(libdir)/bonobo/servers
|
||||||
install-data-hook :
|
install-data-hook :
|
||||||
$(mkinstalldirs) $(DESTDIR)$(serverdir)
|
$(mkinstalldirs) $(DESTDIR)$(serverdir)
|
||||||
sed -e "s|\@LIBEXECDIR\@|$(libexecdir)|" $(srcdir)/$(serverfile) > $(DESTDIR)$(serverdir)/$(serverfile:.in=)
|
sed -e "s|\@LIBEXECDIR\@|$(libexecdir)|" $(srcdir)/$(serverfile) > $(DESTDIR)$(serverdir)/$(serverfile:.in=)
|
||||||
|
|
||||||
EXTRA_DIST = $(serverfile)
|
EXTRA_DIST = $(serverfile) $(Glade_DATA)
|
||||||
CLEANFILES = $(BUILT_SOURCES)
|
CLEANFILES = $(BUILT_SOURCES)
|
||||||
|
|
||||||
uninstall-local:
|
uninstall-local:
|
||||||
|
|
|
@ -39,6 +39,7 @@
|
||||||
|
|
||||||
#include "xsettings-manager.h"
|
#include "xsettings-manager.h"
|
||||||
#include "gnome-settings-daemon.h"
|
#include "gnome-settings-daemon.h"
|
||||||
|
#include "gnome-settings-xmodmap.h"
|
||||||
|
|
||||||
/*#include "gnome-settings-disk.h"*/
|
/*#include "gnome-settings-disk.h"*/
|
||||||
#include "gnome-settings-font.h"
|
#include "gnome-settings-font.h"
|
||||||
|
@ -275,6 +276,7 @@ gnome_settings_daemon_new (void)
|
||||||
gnome_settings_xsettings_init (client);
|
gnome_settings_xsettings_init (client);
|
||||||
gnome_settings_mouse_init (client);
|
gnome_settings_mouse_init (client);
|
||||||
/* Essential - xkb initialization should happen before */
|
/* Essential - xkb initialization should happen before */
|
||||||
|
gnome_settings_keyboard_xkb_set_post_activation_callback (gnome_settings_load_modmap_files, NULL);
|
||||||
gnome_settings_keyboard_xkb_init (client);
|
gnome_settings_keyboard_xkb_init (client);
|
||||||
gnome_settings_keyboard_init (client);
|
gnome_settings_keyboard_init (client);
|
||||||
gnome_settings_multimedia_keys_init (client);
|
gnome_settings_multimedia_keys_init (client);
|
||||||
|
|
|
@ -30,6 +30,7 @@
|
||||||
#include <gdk/gdk.h>
|
#include <gdk/gdk.h>
|
||||||
#include <gdk/gdkx.h>
|
#include <gdk/gdkx.h>
|
||||||
#include <gconf/gconf-client.h>
|
#include <gconf/gconf-client.h>
|
||||||
|
#include "gnome-settings-xmodmap.h"
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
@ -56,6 +57,8 @@ static void *paCallbackUserData = NULL;
|
||||||
|
|
||||||
static const char DISABLE_XMM_WARNING_KEY[] =
|
static const char DISABLE_XMM_WARNING_KEY[] =
|
||||||
"/desktop/gnome/peripherals/keyboard/disable_xmm_and_xkb_warning";
|
"/desktop/gnome/peripherals/keyboard/disable_xmm_and_xkb_warning";
|
||||||
|
static const char KNOWN_FILES_KEY[] =
|
||||||
|
"/desktop/gnome/peripherals/keyboard/general/known_file_list";
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
RESPONSE_USE_X,
|
RESPONSE_USE_X,
|
||||||
|
@ -229,55 +232,70 @@ gnome_settings_keyboard_xkb_analyze_sysconfig (void)
|
||||||
GSwitchItKbdConfigTerm (&backupGConfKbdConfig);
|
GSwitchItKbdConfigTerm (&backupGConfKbdConfig);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static gboolean
|
||||||
gnome_settings_keyboard_xkb_chk_lcl_xmm_response (GtkDialog * dlg,
|
gnome_settings_chk_file_list (void)
|
||||||
gint response)
|
|
||||||
{
|
{
|
||||||
|
GDir *homeDir;
|
||||||
|
G_CONST_RETURN gchar *fname;
|
||||||
|
GSList *file_list = NULL;
|
||||||
|
GSList *last_login_file_list = NULL;
|
||||||
|
GSList *tmp = NULL;
|
||||||
|
GSList *tmp_l = NULL;
|
||||||
|
gboolean new_file_exist = FALSE;
|
||||||
GConfClient *confClient = gconf_client_get_default ();
|
GConfClient *confClient = gconf_client_get_default ();
|
||||||
switch (response) {
|
|
||||||
case GTK_RESPONSE_OK:
|
homeDir = g_dir_open (g_get_home_dir (), 0, NULL);
|
||||||
gconf_client_set_bool (confClient, DISABLE_XMM_WARNING_KEY, TRUE,
|
while ((fname = g_dir_read_name (homeDir)) != NULL) {
|
||||||
NULL);
|
if (g_strrstr (fname, "modmap")) {
|
||||||
break;
|
file_list = g_slist_append (file_list, g_strdup (fname));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
last_login_file_list = gconf_client_get_list (confClient, KNOWN_FILES_KEY, GCONF_VALUE_STRING, NULL);
|
||||||
|
|
||||||
|
/* Compare between the two file list, currently available modmap files
|
||||||
|
and the files available in the last log in */
|
||||||
|
tmp = file_list;
|
||||||
|
while (tmp != NULL) {
|
||||||
|
tmp_l = last_login_file_list;
|
||||||
|
new_file_exist = TRUE;
|
||||||
|
while (tmp_l != NULL) {
|
||||||
|
if (strcmp (tmp->data, tmp_l->data) == 0) {
|
||||||
|
new_file_exist = FALSE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
tmp_l = tmp_l->next;
|
||||||
|
}
|
||||||
|
if (new_file_exist)
|
||||||
|
break;
|
||||||
|
else
|
||||||
|
tmp = tmp->next;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (new_file_exist)
|
||||||
|
gconf_client_set_list (confClient, KNOWN_FILES_KEY, GCONF_VALUE_STRING, file_list, NULL);
|
||||||
|
|
||||||
|
g_slist_foreach (file_list, (GFunc) g_free, NULL);
|
||||||
|
g_slist_free (file_list);
|
||||||
|
|
||||||
|
g_slist_foreach (last_login_file_list, (GFunc) g_free, NULL);
|
||||||
|
g_slist_free (last_login_file_list);
|
||||||
|
|
||||||
g_object_unref (G_OBJECT (confClient));
|
g_object_unref (G_OBJECT (confClient));
|
||||||
gtk_widget_destroy (GTK_WIDGET (dlg));
|
|
||||||
|
return new_file_exist;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gnome_settings_keyboard_xkb_chk_lcl_xmm (void)
|
gnome_settings_keyboard_xkb_chk_lcl_xmm (void)
|
||||||
{
|
{
|
||||||
GConfClient *confClient = gconf_client_get_default ();
|
if (gnome_settings_chk_file_list ())
|
||||||
gboolean disableWarning =
|
gnome_settings_modmap_dialog_call ();
|
||||||
gconf_client_get_bool (confClient, DISABLE_XMM_WARNING_KEY, NULL);
|
gnome_settings_load_modmap_files ();
|
||||||
GDir *homeDir;
|
|
||||||
G_CONST_RETURN gchar *fname;
|
|
||||||
g_object_unref (G_OBJECT (confClient));
|
|
||||||
if (disableWarning)
|
|
||||||
return;
|
|
||||||
|
|
||||||
homeDir = g_dir_open (g_get_home_dir (), 0, NULL);
|
|
||||||
if (homeDir == NULL)
|
|
||||||
return;
|
|
||||||
while ((fname = g_dir_read_name (homeDir)) != NULL)
|
|
||||||
if (strlen (fname) >= 8
|
|
||||||
&& !g_ascii_strncasecmp (fname, ".xmodmap", 8)) {
|
|
||||||
GtkWidget *msg =
|
|
||||||
gtk_message_dialog_new_with_markup (NULL, 0,
|
|
||||||
GTK_MESSAGE_WARNING,
|
|
||||||
GTK_BUTTONS_OK,
|
|
||||||
_
|
|
||||||
("You have a keyboard remapping file (%s) in your home directory whose contents will now be ignored."
|
|
||||||
" You can use the keyboard preferences to restore them."),
|
|
||||||
fname);
|
|
||||||
g_signal_connect (msg, "response",
|
|
||||||
G_CALLBACK
|
|
||||||
(gnome_settings_keyboard_xkb_chk_lcl_xmm_response),
|
|
||||||
NULL);
|
|
||||||
gtk_widget_show (msg);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
g_dir_close (homeDir);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
|
@ -65,6 +65,20 @@
|
||||||
</locale>
|
</locale>
|
||||||
</schema>
|
</schema>
|
||||||
|
|
||||||
|
<schema>
|
||||||
|
<key>/schemas/desktop/gnome/peripherals/keyboard/general/known_file_list</key>
|
||||||
|
<applyto>/desktop/gnome/peripherals/keyboard/general/known_file_list</applyto>
|
||||||
|
<owner>gnome</owner>
|
||||||
|
<type>list</type>
|
||||||
|
<list_type>string</list_type>
|
||||||
|
<default>[]</default>
|
||||||
|
<locale name="C">
|
||||||
|
<short>modmap file list</short>
|
||||||
|
<long>A list of modmap files available in the $HOME directory.</long>
|
||||||
|
</locale>
|
||||||
|
</schema>
|
||||||
|
|
||||||
|
|
||||||
<schema>
|
<schema>
|
||||||
<key>/schemas/desktop/gnome/peripherals/keyboard/general/defaultGroup</key>
|
<key>/schemas/desktop/gnome/peripherals/keyboard/general/defaultGroup</key>
|
||||||
<applyto>/desktop/gnome/peripherals/keyboard/general/defaultGroup</applyto>
|
<applyto>/desktop/gnome/peripherals/keyboard/general/defaultGroup</applyto>
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue