From 65268f66f1ddd3c110c1161278cb4cb943f8cfa0 Mon Sep 17 00:00:00 2001 From: Matthias Schiffer Date: Tue, 8 Oct 2013 14:47:57 +0200 Subject: Ensure the ulock window is not shown when we wait for another instance --- ulock.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) (limited to 'ulock.c') diff --git a/ulock.c b/ulock.c index 7edfb05..9ac8ac8 100644 --- a/ulock.c +++ b/ulock.c @@ -33,7 +33,7 @@ enum lock_state { static enum lock_state state = LOCKED; static GtkWidget *window, *unlockWindow, *lockLabel, *promptEntry, *messageLabel, *logoutButton, *unlockButton; -static gboolean enablePromptEntry = TRUE, enableLogoutButton = FALSE, enableUnlockButton = TRUE; +static gboolean present = FALSE, enablePromptEntry = TRUE, enableLogoutButton = FALSE, enableUnlockButton = TRUE; static char *username; static char *logoutCommand = NULL; @@ -213,7 +213,7 @@ static GdkFilterReturn xevent_filter(GdkXEvent *xevent, GdkEvent *event, gpointe switch (ev->xany.type) { case MapNotify: case ConfigureNotify: - if (ev->xany.window != gdk_x11_window_get_xid(gtk_widget_get_window(window))) + if (present && ev->xany.window != gdk_x11_window_get_xid(gtk_widget_get_window(window))) gtk_window_present(GTK_WINDOW(window)); break; @@ -346,6 +346,8 @@ int main(int argc, char *argv[]) { load_config(); create_lock_window(); + + present = TRUE; gtk_widget_show(window); gtk_main(); -- cgit v1.2.3