From f76c35b4b7a22189613593b5e245f86d27108d91 Mon Sep 17 00:00:00 2001 From: Simon Tatham Date: Sat, 5 Mar 2005 17:56:28 +0000 Subject: [PATCH] Make sure we do notify_remote_exit(ssh->frontend) _before_ connection_fatal(), since the latter is entitled to destroy the backend so `ssh' may no longer be valid once it returns. For the Unix port, switch exit(0) to gtk_main_quit() in notify_remote_exit(), so that we don't exit before the subsequent connection_fatal()! [originally from svn r5445] --- ssh.c | 5 +++-- unix/gtkwin.c | 2 +- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/ssh.c b/ssh.c index 0435dd7e..7f3748af 100644 --- a/ssh.c +++ b/ssh.c @@ -2517,6 +2517,9 @@ static int ssh_closing(Plug plug, const char *error_msg, int error_code, error_msg = "Server unexpectedly closed network connection"; } + if (need_notify) + notify_remote_exit(ssh->frontend); + if (error_msg) { /* A socket error has occurred. */ logevent(error_msg); @@ -2524,8 +2527,6 @@ static int ssh_closing(Plug plug, const char *error_msg, int error_code, } else { logevent("Server closed network connection"); } - if (need_notify) - notify_remote_exit(ssh->frontend); return 0; } diff --git a/unix/gtkwin.c b/unix/gtkwin.c index 043f519f..93cc68e9 100644 --- a/unix/gtkwin.c +++ b/unix/gtkwin.c @@ -1169,7 +1169,7 @@ void notify_remote_exit(void *frontend) inst->exited = TRUE; if (inst->cfg.close_on_exit == FORCE_ON || (inst->cfg.close_on_exit == AUTO && exitcode == 0)) - exit(0); /* just go. */ + gtk_main_quit(); /* just go */ if (inst->ldisc) { ldisc_free(inst->ldisc); inst->ldisc = NULL;