diff options
author | hiro <hiro@ee746299-78ed-0310-b773-934348b2243d> | 2005-03-10 07:13:02 +0000 |
---|---|---|
committer | hiro <hiro@ee746299-78ed-0310-b773-934348b2243d> | 2005-03-10 07:13:02 +0000 |
commit | 12a4b898947c48863b41a29b5005fc0bc8d989d1 (patch) | |
tree | c4919743419de0380ae61ae58815f5842227df94 | |
parent | 07a20040ea5e41414b6cbfe9f3152a40b7fe9d1f (diff) |
partially fixed grab input of passphrase dialog.
git-svn-id: svn://sylpheed.sraoss.jp/sylpheed/trunk@160 ee746299-78ed-0310-b773-934348b2243d
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | ChangeLog.ja | 5 | ||||
-rw-r--r-- | src/passphrase.c | 45 |
3 files changed, 34 insertions, 21 deletions
@@ -1,3 +1,8 @@ +2005-03-10 + + * src/passphrase.c: partially fixed grab input of passphrase dialog. + Confine pointer to window. + 2005-03-09 * src/compose.c: fixed wrapping of quote when auto-wrapping is diff --git a/ChangeLog.ja b/ChangeLog.ja index d3e36d02..237c937f 100644 --- a/ChangeLog.ja +++ b/ChangeLog.ja @@ -1,3 +1,8 @@ +2005-03-10 + + * src/passphrase.c: パスフレーズダイアログの入力捕捉を部分的に修正。 + ポインタをウィンドウ内に制限するようにした。 + 2005-03-09 * src/compose.c: 自動整形が有効になっていた場合の引用部の整形を diff --git a/src/passphrase.c b/src/passphrase.c index 39eee9ed..c567046f 100644 --- a/src/passphrase.c +++ b/src/passphrase.c @@ -24,9 +24,11 @@ #include <glib.h> #include <glib/gi18n.h> +#include <gdk/gdktypes.h> #include <gdk/gdkkeysyms.h> +#include <gdk/gdkdisplay.h> #ifdef GDK_WINDOWING_X11 -# include <gdk/gdkx.h> /* GDK_DISPLAY() */ +# include <gdk/gdkx.h> #endif /* GDK_WINDOWING_X11 */ #include <gtk/gtkmain.h> #include <gtk/gtkwidget.h> @@ -48,7 +50,7 @@ #include "manage_window.h" #include "utils.h" -static int grab_all = 0; +static gboolean grab_all = FALSE; static gboolean pass_ack; static gchar *last_pass = NULL; @@ -123,37 +125,37 @@ passphrase_mbox(const gchar *uid_hint, const gchar *pass_hint, gint prev_bad) g_signal_connect(G_OBJECT(cancel_button), "clicked", G_CALLBACK(passphrase_cancel_cb), NULL); - if (grab_all) - g_object_set (G_OBJECT(window), "type", GTK_WINDOW_POPUP, NULL); gtk_window_set_position (GTK_WINDOW(window), GTK_WIN_POS_CENTER); if (grab_all) gtk_window_set_policy (GTK_WINDOW(window), FALSE, FALSE, TRUE); gtk_widget_show_all(window); - /* don't use XIM on entering passphrase */ - gtkut_editable_disable_im(GTK_EDITABLE(pass_entry)); - if (grab_all) { + /* make sure that window is viewable + * FIXME: this is still not enough */ + gtk_widget_show_now(window); + gdk_flush(); #ifdef GDK_WINDOWING_X11 - //XGrabServer(GDK_DISPLAY()); + gdk_x11_display_grab(gdk_display_get_default()); #endif /* GDK_WINDOWING_X11 */ - if ( gdk_pointer_grab ( window->window, TRUE, 0, - NULL, NULL, GDK_CURRENT_TIME)) { + if (gdk_pointer_grab(window->window, TRUE, 0, + window->window, NULL, GDK_CURRENT_TIME)) { #ifdef GDK_WINDOWING_X11 - //XUngrabServer ( GDK_DISPLAY() ); + gdk_x11_display_ungrab(gdk_display_get_default()); #endif /* GDK_WINDOWING_X11 */ - g_warning ("OOPS: Could not grab mouse\n"); - gtk_widget_destroy (window); + g_warning("OOPS: Could not grab mouse\n"); + gtk_widget_destroy(window); return NULL; } - if ( gdk_keyboard_grab( window->window, FALSE, GDK_CURRENT_TIME )) { - gdk_pointer_ungrab (GDK_CURRENT_TIME); + if (gdk_keyboard_grab(window->window, FALSE, GDK_CURRENT_TIME)) { + gdk_display_pointer_ungrab(gdk_display_get_default(), + GDK_CURRENT_TIME); #ifdef GDK_WINDOWING_X11 - //XUngrabServer ( GDK_DISPLAY() ); + gdk_x11_display_ungrab(gdk_display_get_default()); #endif /* GDK_WINDOWING_X11 */ - g_warning ("OOPS: Could not grab keyboard\n"); - gtk_widget_destroy (window); + g_warning("OOPS: Could not grab keyboard\n"); + gtk_widget_destroy(window); return NULL; } } @@ -161,11 +163,12 @@ passphrase_mbox(const gchar *uid_hint, const gchar *pass_hint, gint prev_bad) gtk_main(); if (grab_all) { + gdk_display_keyboard_ungrab(gdk_display_get_default(), + GDK_CURRENT_TIME); + gdk_display_pointer_ungrab(gdk_display_get_default(), GDK_CURRENT_TIME); #ifdef GDK_WINDOWING_X11 - //XUngrabServer (GDK_DISPLAY()); + gdk_x11_display_ungrab(gdk_display_get_default()); #endif /* GDK_WINDOWING_X11 */ - gdk_pointer_ungrab (GDK_CURRENT_TIME); - gdk_keyboard_ungrab (GDK_CURRENT_TIME); gdk_flush(); } |