masqmail

changeset 401:885e3d886199

Various minor refactoring.
author markus schnalke <meillo@marmaro.de>
date Tue, 21 Feb 2012 16:11:00 +0100 (2012-02-21)
parents 6500db550a03
children eedc23877cd5
files src/child.c src/connect.c
diffstat 2 files changed, 46 insertions(+), 40 deletions(-) [+]
line diff
     1.1 --- a/src/child.c	Tue Feb 21 15:44:55 2012 +0100
     1.2 +++ b/src/child.c	Tue Feb 21 16:11:00 2012 +0100
     1.3 @@ -41,26 +41,28 @@
     1.4  		pid = fork();
     1.5  		if (pid == -1) {
     1.6  			return -1;
     1.7 +
     1.8  		} else if (pid == 0) {
     1.9  			/* child */
    1.10 +			char *argv[] = { "/bin/sh", "-c", (char *)command,
    1.11 +					NULL };
    1.12  			int i, max_fd = sysconf(_SC_OPEN_MAX);
    1.13 +
    1.14  			dup2(pipe[0], 0);
    1.15  			dup2(pipe[0], 1);
    1.16  			dup2(pipe[0], 2);
    1.17  
    1.18 -			if (max_fd <= 0)
    1.19 +			if (max_fd <= 0) {
    1.20  				max_fd = 64;
    1.21 -			for (i = 3; i < max_fd; i++)
    1.22 +			}
    1.23 +			for (i = 3; i < max_fd; i++) {
    1.24  				close(i);
    1.25 -
    1.26 -			{
    1.27 -				char *argv[] = { "/bin/sh", "-c",
    1.28 -						(char *) command, NULL };
    1.29 -				execve(*argv, argv, NULL);
    1.30  			}
    1.31 +			execve(*argv, argv, NULL);
    1.32  			logwrite(LOG_ALERT, "execve failed: %s\n",
    1.33  					strerror(errno));
    1.34  			_exit(1);
    1.35 +
    1.36  		} else {
    1.37  			/* parent */
    1.38  			close(pipe[0]);
     2.1 --- a/src/connect.c	Tue Feb 21 15:44:55 2012 +0100
     2.2 +++ b/src/connect.c	Tue Feb 21 16:11:00 2012 +0100
     2.3 @@ -39,39 +39,42 @@
     2.4  {
     2.5  	GList *addr_node;
     2.6  	struct sockaddr_in saddr;
     2.7 +	int saved_errno;
     2.8  
     2.9  	DEBUG(5) debugf("connect_hostlist entered\n");
    2.10  
    2.11 -	for (addr_node = g_list_first(addr_list); addr_node; addr_node = g_list_next(addr_node)) {
    2.12 +	for (addr_node = g_list_first(addr_list); addr_node;
    2.13 +			addr_node = g_list_next(addr_node)) {
    2.14  		mxip_addr *addr = (mxip_addr *) (addr_node->data);
    2.15 -
    2.16  		*psockfd = socket(PF_INET, SOCK_STREAM, 0);
    2.17  
    2.18  		memset(&saddr, 0, sizeof(saddr));
    2.19 -
    2.20  		saddr.sin_family = AF_INET;
    2.21  		saddr.sin_port = htons(port);
    2.22 -
    2.23  		/* clumsy, but makes compiler happy: */
    2.24  		saddr.sin_addr = *(struct in_addr *) (&(addr->ip));
    2.25 -		DEBUG(5) debugf("  trying ip %s port %d\n", inet_ntoa(saddr.sin_addr), port);
    2.26 -		if (connect(*psockfd, (struct sockaddr *) (&saddr), sizeof(saddr)) == 0) {
    2.27 -			DEBUG(5) debugf("  connected to %s\n", inet_ntoa(saddr.sin_addr));
    2.28 +
    2.29 +		DEBUG(5) debugf("  trying ip %s port %d\n",
    2.30 +				inet_ntoa(saddr.sin_addr), port);
    2.31 +
    2.32 +		if (connect(*psockfd, (struct sockaddr *) &saddr,
    2.33 +				sizeof(saddr))==0) {
    2.34 +			DEBUG(5) debugf("  connected to %s\n",
    2.35 +					inet_ntoa(saddr.sin_addr));
    2.36  			return addr;
    2.37 -		} else {
    2.38 -			int saved_errno = errno;
    2.39 +		}
    2.40  
    2.41 -			close(*psockfd);
    2.42 +		saved_errno = errno;
    2.43 +		close(*psockfd);
    2.44 +		logwrite(LOG_WARNING, "connection to %s failed: %s\n",
    2.45 +				inet_ntoa(saddr.sin_addr), strerror(errno));
    2.46 +		errno = saved_errno;
    2.47  
    2.48 -			logwrite(LOG_WARNING, "connection to %s failed: %s\n", inet_ntoa(saddr.sin_addr), strerror(errno));
    2.49 -
    2.50 -			errno = saved_errno;
    2.51 -
    2.52 -			if ((saved_errno != ECONNREFUSED)
    2.53 -			    && (saved_errno != ETIMEDOUT)
    2.54 -			    && (saved_errno != ENETUNREACH)
    2.55 -			    && (saved_errno != EHOSTUNREACH))
    2.56 -				return NULL;
    2.57 +		if ((saved_errno != ECONNREFUSED) &&
    2.58 +				(saved_errno != ETIMEDOUT) &&
    2.59 +				(saved_errno != ENETUNREACH) &&
    2.60 +				(saved_errno != EHOSTUNREACH)) {
    2.61 +			return NULL;
    2.62  		}
    2.63  	}
    2.64  	return NULL;
    2.65 @@ -87,7 +90,8 @@
    2.66  **  if attempt failed for one it should not be tried again.
    2.67  */
    2.68  mxip_addr*
    2.69 -connect_resolvelist(int *psockfd, gchar *host, guint port, GList *res_func_list)
    2.70 +connect_resolvelist(int *psockfd, gchar *host, guint port,
    2.71 +		GList *res_func_list)
    2.72  {
    2.73  	GList *res_node;
    2.74  	GList *addr_list;
    2.75 @@ -95,12 +99,12 @@
    2.76  	DEBUG(5) debugf("connect_resolvelist entered\n");
    2.77  
    2.78  	h_errno = 0;
    2.79 -
    2.80  	if (isdigit(*host)) {
    2.81  		mxip_addr *addr;
    2.82  
    2.83  		if ((addr_list = resolve_ip(host))) {
    2.84 -			addr = connect_hostlist(psockfd, host, port, addr_list);
    2.85 +			addr = connect_hostlist(psockfd, host, port,
    2.86 +					addr_list);
    2.87  			g_list_free(addr_list);
    2.88  			return addr;
    2.89  		}
    2.90 @@ -110,18 +114,18 @@
    2.91  		*/
    2.92  	}
    2.93  
    2.94 -	if (res_func_list == NULL) {
    2.95 -		logwrite(LOG_ALERT, "res_funcs == NULL !!!\n");
    2.96 +	if (!res_func_list) {
    2.97 +		logwrite(LOG_ALERT, "res_funcs not set!\n");
    2.98  		exit(1);
    2.99  	}
   2.100  
   2.101  	foreach(res_func_list, res_node) {
   2.102  		resolve_func res_func;
   2.103  		DEBUG(6) debugf("  foreach() body\n");
   2.104 -		res_func = (resolve_func) (res_node->data);
   2.105  
   2.106 -		if (res_func == NULL) {
   2.107 -			logwrite(LOG_ALERT, "res_func == NULL !!!\n");
   2.108 +		res_func = (resolve_func) res_node->data;
   2.109 +		if (!res_func) {
   2.110 +			logwrite(LOG_ALERT, "Empty res_func!\n");
   2.111  			exit(1);
   2.112  		}
   2.113  
   2.114 @@ -129,16 +133,16 @@
   2.115  		if ((addr_list = res_func(NULL, host))) {
   2.116  
   2.117  			mxip_addr *addr;
   2.118 -			if ((addr = connect_hostlist(psockfd, host, port, addr_list)))
   2.119 +			if ((addr = connect_hostlist(psockfd, host, port,
   2.120 +					addr_list))) {
   2.121  				return addr;
   2.122 -
   2.123 -			DEBUG(5) {
   2.124 -				debugf("connect_hostlist failed: %s\n", strerror(errno));
   2.125  			}
   2.126 -
   2.127 +			DEBUG(5) debugf("connect_hostlist failed: %s\n",
   2.128 +					strerror(errno));
   2.129  			g_list_free(addr_list);
   2.130  		} else if (!g_list_next(res_node)) {
   2.131 -			logwrite(LOG_ALERT, "could not resolve %s: %s\n", host, hstrerror(h_errno));
   2.132 +			logwrite(LOG_ALERT, "could not resolve %s: %s\n",
   2.133 +					host, hstrerror(h_errno));
   2.134  		}
   2.135  	}
   2.136  	return NULL;