- (djm) Made GNOME askpass programs return non-zero if cancel button is

pressed.
This commit is contained in:
Damien Miller 2002-09-12 14:49:00 +10:00
parent 1d87176749
commit 10f3085137
3 changed files with 21 additions and 13 deletions

View File

@ -1,4 +1,6 @@
20020912 20020912
- (djm) Made GNOME askpass programs return non-zero if cancel button is
pressed.
- (djm) Added getpeereid() replacement. Properly implemented for systems - (djm) Added getpeereid() replacement. Properly implemented for systems
with SO_PEERCRED support. Faked for systems which lack it. with SO_PEERCRED support. Faked for systems which lack it.
- (djm) Sync sys/tree.h with OpenBSD -current. Rename tree.h and - (djm) Sync sys/tree.h with OpenBSD -current. Rename tree.h and
@ -645,4 +647,4 @@
save auth method before monitor_reset_key_state(); bugzilla bug #284; save auth method before monitor_reset_key_state(); bugzilla bug #284;
ok provos@ ok provos@
$Id: ChangeLog,v 1.2462 2002/09/12 00:45:32 djm Exp $ $Id: ChangeLog,v 1.2463 2002/09/12 04:49:00 djm Exp $

View File

@ -38,7 +38,7 @@
* Compile with: * Compile with:
* *
* cc `gnome-config --cflags gnome gnomeui` \ * cc `gnome-config --cflags gnome gnomeui` \
* gnome-ssh-askpass.c -o gnome-ssh-askpass \ * gnome-ssh-askpass1.c -o gnome-ssh-askpass \
* `gnome-config --libs gnome gnomeui` * `gnome-config --libs gnome gnomeui`
* *
*/ */
@ -64,7 +64,7 @@ report_failed_grab (void)
gnome_dialog_run_and_close(GNOME_DIALOG(err)); gnome_dialog_run_and_close(GNOME_DIALOG(err));
} }
void int
passphrase_dialog(char *message) passphrase_dialog(char *message)
{ {
char *passphrase; char *passphrase;
@ -135,7 +135,7 @@ passphrase_dialog(char *message)
gtk_entry_set_text(GTK_ENTRY(entry), passphrase); gtk_entry_set_text(GTK_ENTRY(entry), passphrase);
gnome_dialog_close(GNOME_DIALOG(dialog)); gnome_dialog_close(GNOME_DIALOG(dialog));
return; return (result == 0 ? 0 : -1);
/* At least one grab failed - ungrab what we got, and report /* At least one grab failed - ungrab what we got, and report
the failure to the user. Note that XGrabServer() cannot the failure to the user. Note that XGrabServer() cannot
@ -148,13 +148,15 @@ passphrase_dialog(char *message)
gnome_dialog_close(GNOME_DIALOG(dialog)); gnome_dialog_close(GNOME_DIALOG(dialog));
report_failed_grab(); report_failed_grab();
return (-1);
} }
int int
main(int argc, char **argv) main(int argc, char **argv)
{ {
char *message; char *message;
int result;
gnome_init("GNOME ssh-askpass", "0.1", argc, argv); gnome_init("GNOME ssh-askpass", "0.1", argc, argv);
if (argc == 2) if (argc == 2)
@ -163,6 +165,7 @@ main(int argc, char **argv)
message = "Enter your OpenSSH passphrase:"; message = "Enter your OpenSSH passphrase:";
setvbuf(stdout, 0, _IONBF, 0); setvbuf(stdout, 0, _IONBF, 0);
passphrase_dialog(message); result = passphrase_dialog(message);
return 0;
return (result);
} }

View File

@ -40,7 +40,7 @@
* Compile with: * Compile with:
* *
* cc `pkg-config --cflags gtk+-2.0` \ * cc `pkg-config --cflags gtk+-2.0` \
* gnome-ssh-askpass.c -o gnome-ssh-askpass \ * gnome-ssh-askpass2.c -o gnome-ssh-askpass \
* `pkg-config --libs gtk+-2.0` * `pkg-config --libs gtk+-2.0`
* *
*/ */
@ -79,7 +79,7 @@ ok_dialog(GtkWidget *entry, gpointer dialog)
gtk_dialog_response(GTK_DIALOG(dialog), GTK_RESPONSE_OK); gtk_dialog_response(GTK_DIALOG(dialog), GTK_RESPONSE_OK);
} }
static void static int
passphrase_dialog(char *message) passphrase_dialog(char *message)
{ {
const char *failed; const char *failed;
@ -165,7 +165,7 @@ passphrase_dialog(char *message)
g_free(passphrase); g_free(passphrase);
gtk_widget_destroy(dialog); gtk_widget_destroy(dialog);
return; return (result == GTK_RESPONSE_OK ? 0 : -1);
/* At least one grab failed - ungrab what we got, and report /* At least one grab failed - ungrab what we got, and report
the failure to the user. Note that XGrabServer() cannot the failure to the user. Note that XGrabServer() cannot
@ -178,13 +178,16 @@ passphrase_dialog(char *message)
gtk_widget_destroy(dialog); gtk_widget_destroy(dialog);
report_failed_grab(failed); report_failed_grab(failed);
return (-1);
} }
int int
main(int argc, char **argv) main(int argc, char **argv)
{ {
char *message; char *message;
int result;
gtk_init(&argc, &argv); gtk_init(&argc, &argv);
if (argc > 1) { if (argc > 1) {
@ -194,8 +197,8 @@ main(int argc, char **argv)
} }
setvbuf(stdout, 0, _IONBF, 0); setvbuf(stdout, 0, _IONBF, 0);
passphrase_dialog(message); result = passphrase_dialog(message);
g_free(message); g_free(message);
return 0; return (result);
} }