X-Git-Url: https://gapil.gnulinux.it/gitweb/?p=gapil.git;a=blobdiff_plain;f=sources%2FTCP_echod.c;h=fd51f982797a745c6d5d2f1e8fc1cf3c5949b45d;hp=d75fd1febc6000fdec5c3dba2cd13a5b0e2755ab;hb=28ac8648240edd35e31f75ae11dbe3e4ac9e109e;hpb=1819cf252941f57e22a4836315c1399626d04bd5 diff --git a/sources/TCP_echod.c b/sources/TCP_echod.c index d75fd1f..fd51f98 100644 --- a/sources/TCP_echod.c +++ b/sources/TCP_echod.c @@ -26,7 +26,7 @@ * * Usage: echod -h give all info * - * $Id: TCP_echod.c,v 1.6 2003/06/19 13:29:03 piccardi Exp $ + * $Id: TCP_echod.c,v 1.12 2003/08/03 18:12:47 piccardi Exp $ * ****************************************************************/ /* @@ -41,6 +41,7 @@ #include /* syslog system functions */ #include /* signal functions */ #include /* error code */ +#include /* error strings */ #include "Gapil.h" #define BACKLOG 10 @@ -59,6 +60,7 @@ int main(int argc, char *argv[]) */ int list_fd, conn_fd; int waiting = 0; + int compat = 0; pid_t pid; struct sockaddr_in serv_add, cli_add; socklen_t len; @@ -69,7 +71,7 @@ int main(int argc, char *argv[]) */ int i; opterr = 0; /* don't want writing to stderr */ - while ( (i = getopt(argc, argv, "hdiw:")) != -1) { + while ( (i = getopt(argc, argv, "hdicw:")) != -1) { switch (i) { /* * Handling options @@ -82,6 +84,9 @@ int main(int argc, char *argv[]) case 'i': demonize = 0; break; + case 'c': + compat = 1; + break; case 'd': debugging = 1; break; @@ -102,8 +107,12 @@ int main(int argc, char *argv[]) * Main code beginning * * ***********************************************************/ - /* install SIGCHLD handler */ - Signal(SIGCHLD, HandSigCHLD); /* establish handler */ + /* Main code begin here */ + if (compat) { /* install signal handler */ + Signal(SIGCHLD, HandSigCHLD); /* non restarting handler */ + } else { + SignalRestart(SIGCHLD, HandSigCHLD); /* restarting handler */ + } /* create socket */ if ( (list_fd = socket(AF_INET, SOCK_STREAM, 0)) < 0) { perror("Socket creation error"); @@ -167,6 +176,14 @@ int main(int argc, char *argv[]) if (pid == 0) { /* child */ close(list_fd); /* close listening socket */ ServEcho(conn_fd); /* handle echo */ + if (debugging) { + snprintf(debug, MAXLINE, "Closed connection %s\n", ipaddr); + if (demonize) { + syslog(LOG_DEBUG, debug); + } else { + printf("%s", debug); + } + } exit(0); } else { /* parent */ close(conn_fd); /* close connected socket */ @@ -183,8 +200,10 @@ void usage(void) { printf("Usage:\n"); printf(" echod [-h] \n"); printf(" -h print this help\n"); - printf(" -d print debug info\n"); + printf(" -d write debug info\n"); printf(" -i use interactively\n"); + printf(" -c disable BSD semantics\n"); + printf(" -w N wait N sec. before calling accept\n"); exit(1); } /* @@ -194,10 +213,17 @@ void ServEcho(int sockfd) { char buffer[MAXLINE]; int nread, nwrite; char debug[MAXLINE+20]; - int size; /* main loop, reading 0 char means client close connection */ while ( (nread = read(sockfd, buffer, MAXLINE)) != 0) { + if (nread < 0) { + PrintErr("Errore in lettura"); + return; + } nwrite = FullWrite(sockfd, buffer, nread); + if (nwrite) { + PrintErr("Errore in scrittura"); + return; + } if (debugging) { buffer[nread] = 0; snprintf(debug, MAXLINE+20, "Letti %d byte, %s", nread, buffer); @@ -214,8 +240,8 @@ void ServEcho(int sockfd) { * routine to print error on stout or syslog */ void PrintErr(char * error) { - if (demonize) { /* daemon mode */ - syslog(LOG_ERR, error); + if (demonize) { /* daemon mode */ + syslog(LOG_ERR, "%s: %m", error); /* log string and error message */ } else { perror(error); }