X-Git-Url: http://git.madism.org/?p=apps%2Fmadmutt.git;a=blobdiff_plain;f=mutt_tunnel.c;h=92fcea56171388cce556957de065480c93d9353e;hp=4a012f06da0c81fb6778d5541f684577b3bbb8b5;hb=2ea77d3b2827ba23feb756ce2fb936565ae38998;hpb=df70e07e24add1869bcc9b7af2277d9d0c09a281 diff --git a/mutt_tunnel.c b/mutt_tunnel.c index 4a012f0..92fcea5 100644 --- a/mutt_tunnel.c +++ b/mutt_tunnel.c @@ -1,30 +1,26 @@ /* + * Copyright notice from original mutt: * Copyright (C) 2000 Manoj Kasichainula - * Copyright (C) 2001 Brendan Cully + * Copyright (C) 2001,2005 Brendan Cully * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA. + * This file is part of mutt-ng, see http://www.muttng.org/. + * It's licensed under the GNU General Public License, + * please see the file GPL in the top level source directory. */ #if HAVE_CONFIG_H # include "config.h" #endif +#include +#include +#include + #include "mutt.h" #include "mutt_socket.h" #include "mutt_tunnel.h" + #include #include #include @@ -64,7 +60,7 @@ static int tunnel_socket_open (CONNECTION * conn) int rc; int pin[2], pout[2]; - tunnel = (TUNNEL_DATA *) safe_malloc (sizeof (TUNNEL_DATA)); + tunnel = p_new(TUNNEL_DATA, 1); conn->sockdata = tunnel; mutt_message (_("Connecting with \"%s\"..."), Tunnel); @@ -123,12 +119,18 @@ static int tunnel_socket_open (CONNECTION * conn) static int tunnel_socket_close (CONNECTION * conn) { TUNNEL_DATA *tunnel = (TUNNEL_DATA *) conn->sockdata; + int status; close (tunnel->readfd); close (tunnel->writefd); - waitpid (tunnel->pid, NULL, 0); - FREE (&conn->sockdata); - + waitpid (tunnel->pid, &status, 0); + if (!WIFEXITED(status) || WEXITSTATUS(status)) { + mutt_error(_("Tunnel to %s returned error %d (%s)"), + conn->account.host, WEXITSTATUS(status), + NONULL(mutt_strsysexit(WEXITSTATUS(status)))); + mutt_sleep (2); + } + p_delete(&conn->sockdata); return 0; }