masqmail

changeset 384:4848c16ed1c1

Beautifying.
author markus schnalke <meillo@marmaro.de>
date Thu, 16 Feb 2012 11:22:31 +0100 (2012-02-16)
parents a2909de1818b
children 01769f722a18
files src/listen.c
diffstat 1 files changed, 52 insertions(+), 36 deletions(-) [+]
line diff
     1.1 --- a/src/listen.c	Thu Feb 16 11:12:39 2012 +0100
     1.2 +++ b/src/listen.c	Thu Feb 16 11:22:31 2012 +0100
     1.3 @@ -39,10 +39,14 @@
     1.4  
     1.5  	pid = waitpid(0, &status, 0);
     1.6  	if (pid > 0) {
     1.7 -		if (WEXITSTATUS(status) != 0)
     1.8 -			logwrite(LOG_WARNING, "process %d exited with %d\n", pid, WEXITSTATUS(status));
     1.9 -		if (WIFSIGNALED(status))
    1.10 -			logwrite(LOG_WARNING, "process with pid %d got signal: %d\n", pid, WTERMSIG(status));
    1.11 +		if (WEXITSTATUS(status) != 0) {
    1.12 +			logwrite(LOG_WARNING, "process %d exited with %d\n",
    1.13 +					pid, WEXITSTATUS(status));
    1.14 +		}
    1.15 +		if (WIFSIGNALED(status)) {
    1.16 +			logwrite(LOG_WARNING, "process %d got signal: %d\n",
    1.17 +					pid, WTERMSIG(status));
    1.18 +		}
    1.19  	}
    1.20  	signal(SIGCHLD, sigchld_handler);
    1.21  }
    1.22 @@ -63,16 +67,16 @@
    1.23  	/* start child for connection: */
    1.24  	signal(SIGCHLD, sigchld_handler);
    1.25  	pid = fork();
    1.26 -	if (pid == 0) {
    1.27 +	if (pid < 0) {
    1.28 +		logwrite(LOG_WARNING, "could not fork for incoming smtp "
    1.29 +				"connection: %s\n", strerror(errno));
    1.30 +	} else if (pid == 0) {
    1.31 +		/* child */
    1.32  		close(listen_sock);
    1.33  		out = fdopen(sock, "w");
    1.34  		in = fdopen(dup_sock, "r");
    1.35 -
    1.36  		smtp_in(in, out, rem_host, ident);
    1.37 -
    1.38  		_exit(0);
    1.39 -	} else if (pid < 0) {
    1.40 -		logwrite(LOG_WARNING, "could not fork for incoming smtp connection: %s\n", strerror(errno));
    1.41  	}
    1.42  
    1.43  	close(sock);
    1.44 @@ -104,10 +108,12 @@
    1.45  			continue;
    1.46  		}
    1.47  		if (listen(sock, 1) < 0) {
    1.48 -			logwrite(LOG_ALERT, "listen: (terminating): %s\n", strerror(errno));
    1.49 +			logwrite(LOG_ALERT, "listen: (terminating): %s\n",
    1.50 +					strerror(errno));
    1.51  			exit(1);
    1.52  		}
    1.53 -		logwrite(LOG_NOTICE, "listening on interface %s:%d\n", iface->address, iface->port);
    1.54 +		logwrite(LOG_NOTICE, "listening on interface %s:%d\n",
    1.55 +				iface->address, iface->port);
    1.56  		DEBUG(5) debugf("sock = %d\n", sock);
    1.57  		FD_SET(sock, &active_fd_set);
    1.58  	}
    1.59 @@ -136,7 +142,8 @@
    1.60  		*/
    1.61  		if (qival > 0) {
    1.62  			time(&time_now);
    1.63 -			if (sel_ret == 0) {  /* we are either just starting or did a queue run */
    1.64 +			if (!sel_ret) {
    1.65 +				/* either just starting or after a queue run */
    1.66  				tm.tv_sec = qival;
    1.67  				tm.tv_usec = 0;
    1.68  				time_before = time_now;
    1.69 @@ -144,9 +151,10 @@
    1.70  				tm.tv_sec = qival - (time_now - time_before);
    1.71  				tm.tv_usec = 0;
    1.72  
    1.73 -				/* race condition, very unlikely (but possible): */
    1.74 -				if (tm.tv_sec < 0)
    1.75 +				/* race condition, unlikely (but possible): */
    1.76 +				if (tm.tv_sec < 0) {
    1.77  					tm.tv_sec = 0;
    1.78 +				}
    1.79  			}
    1.80  		}
    1.81  		/*
    1.82 @@ -155,34 +163,41 @@
    1.83  		**  (if qival > 0)
    1.84  		*/
    1.85  		read_fd_set = active_fd_set;
    1.86 -		if ((sel_ret = select(FD_SETSIZE, &read_fd_set, NULL, NULL, qival > 0 ? &tm : NULL)) < 0) {
    1.87 +		if ((sel_ret = select(FD_SETSIZE, &read_fd_set, NULL, NULL,
    1.88 +				qival > 0 ? &tm : NULL)) < 0) {
    1.89  			if (errno != EINTR) {
    1.90 -				logwrite(LOG_ALERT, "select: (terminating): %s\n", strerror(errno));
    1.91 +				logwrite(LOG_ALERT, "select: (terminating): "
    1.92 +						"%s\n", strerror(errno));
    1.93  				exit(1);
    1.94 -			} else {
    1.95 -				if (sighup_seen) {
    1.96 -					logwrite(LOG_NOTICE, "HUP signal received. Restarting daemon\n");
    1.97 +			} else if (sighup_seen) {
    1.98 +				logwrite(LOG_NOTICE, "HUP signal received. "
    1.99 +						"Restarting daemon\n");
   1.100  
   1.101 -					for (i = 0; i < FD_SETSIZE; i++)
   1.102 -						if (FD_ISSET(i, &active_fd_set))
   1.103 -							close(i);
   1.104 +				for (i = 0; i < FD_SETSIZE; i++)
   1.105 +					if (FD_ISSET(i, &active_fd_set))
   1.106 +						close(i);
   1.107  
   1.108 -					execv(argv[0], &(argv[0]));
   1.109 -					logwrite(LOG_ALERT, "restarting failed: %s\n", strerror(errno));
   1.110 -					exit(1);
   1.111 -				}
   1.112 +				execv(argv[0], &(argv[0]));
   1.113 +				logwrite(LOG_ALERT, "restarting failed: %s\n",
   1.114 +						strerror(errno));
   1.115 +				exit(1);
   1.116  			}
   1.117  		} else if (sel_ret > 0) {
   1.118  			for (i = 0; i < FD_SETSIZE; i++) {
   1.119 -				if (FD_ISSET(i, &read_fd_set)) {
   1.120 -					int sock = i;
   1.121 -					int new;
   1.122 -					size = sizeof(clientname);
   1.123 -					new = accept(sock, (struct sockaddr *) &clientname, &size);
   1.124 -					if (new < 0) {
   1.125 -						logwrite(LOG_ALERT, "accept: (ignoring): %s\n", strerror(errno));
   1.126 -					} else
   1.127 -						accept_connect(sock, new, &clientname);
   1.128 +				int sock = i;
   1.129 +				int new;
   1.130 +
   1.131 +				if (!FD_ISSET(i, &read_fd_set)) {
   1.132 +					continue;
   1.133 +				}
   1.134 +				size = sizeof(clientname);
   1.135 +				new = accept(sock, (struct sockaddr *)
   1.136 +						&clientname, &size);
   1.137 +				if (new < 0) {
   1.138 +					logwrite(LOG_ALERT, "accept: (ignoring): %s\n", strerror(errno));
   1.139 +				} else {
   1.140 +					accept_connect(sock, new,
   1.141 +							&clientname);
   1.142  				}
   1.143  			}
   1.144  		} else {
   1.145 @@ -197,7 +212,8 @@
   1.146  
   1.147  				_exit(0);
   1.148  			} else if (pid < 0) {
   1.149 -				logwrite(LOG_ALERT, "could not fork for queue run");
   1.150 +				logwrite(LOG_ALERT, "could not fork for "
   1.151 +						"queue run");
   1.152  			}
   1.153  		}
   1.154  	}