mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 09:12:24 +00:00
Handle error messages even before session startup.
I carefully put a flag in the new Ssh structure so that I could tell the difference between ssh->base_layer being NULL because it hasn't been set up yet, and being NULL because it's been and gone and the session is terminated. And did I check that flag in all the error routines? I did not. Result: an early socket error, while we're still in the verstring BPP, doesn't get reported as an error message and doesn't cause the socket to be cleaned up.
This commit is contained in:
parent
07313e9466
commit
c912d0936d
10
ssh.c
10
ssh.c
@ -387,7 +387,7 @@ static void ssh_initiate_connection_close(Ssh ssh)
|
|||||||
|
|
||||||
void ssh_remote_error(Ssh ssh, const char *fmt, ...)
|
void ssh_remote_error(Ssh ssh, const char *fmt, ...)
|
||||||
{
|
{
|
||||||
if (ssh->base_layer) {
|
if (ssh->base_layer || !ssh->session_started) {
|
||||||
GET_FORMATTED_MSG;
|
GET_FORMATTED_MSG;
|
||||||
|
|
||||||
/* Error messages sent by the remote don't count as clean exits */
|
/* Error messages sent by the remote don't count as clean exits */
|
||||||
@ -405,7 +405,7 @@ void ssh_remote_error(Ssh ssh, const char *fmt, ...)
|
|||||||
|
|
||||||
void ssh_remote_eof(Ssh ssh, const char *fmt, ...)
|
void ssh_remote_eof(Ssh ssh, const char *fmt, ...)
|
||||||
{
|
{
|
||||||
if (ssh->base_layer) {
|
if (ssh->base_layer || !ssh->session_started) {
|
||||||
GET_FORMATTED_MSG;
|
GET_FORMATTED_MSG;
|
||||||
|
|
||||||
/* EOF from the remote, if we were expecting it, does count as
|
/* EOF from the remote, if we were expecting it, does count as
|
||||||
@ -428,7 +428,7 @@ void ssh_remote_eof(Ssh ssh, const char *fmt, ...)
|
|||||||
|
|
||||||
void ssh_proto_error(Ssh ssh, const char *fmt, ...)
|
void ssh_proto_error(Ssh ssh, const char *fmt, ...)
|
||||||
{
|
{
|
||||||
if (ssh->base_layer) {
|
if (ssh->base_layer || !ssh->session_started) {
|
||||||
GET_FORMATTED_MSG;
|
GET_FORMATTED_MSG;
|
||||||
|
|
||||||
ssh->exitcode = 128;
|
ssh->exitcode = 128;
|
||||||
@ -445,7 +445,7 @@ void ssh_proto_error(Ssh ssh, const char *fmt, ...)
|
|||||||
|
|
||||||
void ssh_sw_abort(Ssh ssh, const char *fmt, ...)
|
void ssh_sw_abort(Ssh ssh, const char *fmt, ...)
|
||||||
{
|
{
|
||||||
if (ssh->base_layer) {
|
if (ssh->base_layer || !ssh->session_started) {
|
||||||
GET_FORMATTED_MSG;
|
GET_FORMATTED_MSG;
|
||||||
|
|
||||||
ssh->exitcode = 128;
|
ssh->exitcode = 128;
|
||||||
@ -462,7 +462,7 @@ void ssh_sw_abort(Ssh ssh, const char *fmt, ...)
|
|||||||
|
|
||||||
void ssh_user_close(Ssh ssh, const char *fmt, ...)
|
void ssh_user_close(Ssh ssh, const char *fmt, ...)
|
||||||
{
|
{
|
||||||
if (ssh->base_layer) {
|
if (ssh->base_layer || !ssh->session_started) {
|
||||||
GET_FORMATTED_MSG;
|
GET_FORMATTED_MSG;
|
||||||
|
|
||||||
/* Closing the connection due to user action, even if the
|
/* Closing the connection due to user action, even if the
|
||||||
|
Loading…
Reference in New Issue
Block a user