Varie correzioni, completata revisione capitolo sull'I/O su file
[gapil.git] / sources / TCP_echod.c
index cca49332ade78b32be343a7d57dea39f64cc4f67..333a5450b9df067e62444a8e36b646e112982e7c 100644 (file)
  *
  * Usage: echod -h give all info
  *
- * $Id$ 
- *
  ****************************************************************/
 /* 
  * Include needed headers
  */
-#include <sys/types.h>   /* predefined types */
-#include <unistd.h>      /* include unix standard library */
-#include <arpa/inet.h>   /* IP addresses conversion utiliites */
-#include <sys/socket.h>  /* socket library */
-#include <stdio.h>      /* include standard I/O library */
-#include <time.h>
+#include <sys/types.h>   /* primitive system data types */
+#include <unistd.h>      /* unix standard library */
+#include <arpa/inet.h>   /* IP addresses conversion utilities */
+#include <sys/socket.h>  /* socket constants, types and functions */
+#include <stdio.h>      /* standard I/O library */
+#include <time.h>        /* date and time constants, types and functions */
 #include <syslog.h>      /* syslog system functions */
-#include <signal.h>      /* signal functions */
-#include <errno.h>       /* error code */
-#include <string.h>      /* error strings */
-#include <stdlib.h>
+#include <signal.h>      /* signal constants, types and functions */
+#include <errno.h>       /* error definitions and routines */
+#include <string.h>      /* C strings library */
+#include <stdlib.h>      /* C standard library */ 
 
 #include "Gapil.h"
 
@@ -62,6 +60,8 @@ int main(int argc, char *argv[])
  */
     int list_fd, conn_fd;
     int waiting = 0;
+    int keepalive = 0; 
+    int reuse = 0;
     int compat = 0;
     pid_t pid;
     struct sockaddr_in cli_add;
@@ -73,7 +73,7 @@ int main(int argc, char *argv[])
      */
     int i;
     opterr = 0;         /* don't want writing to stderr */
-    while ( (i = getopt(argc, argv, "hdicw:")) != -1) {
+    while ( (i = getopt(argc, argv, "hkrdicw:")) != -1) {
        switch (i) {
        /* 
         * Handling options 
@@ -86,6 +86,12 @@ int main(int argc, char *argv[])
        case 'i':
            demonize = 0;
            break;
+       case 'k':
+           keepalive = 1;
+           break;
+       case 'r':
+           reuse = 1;
+           break;
        case 'c':
            compat = 1;
            break;
@@ -116,7 +122,8 @@ int main(int argc, char *argv[])
        SignalRestart(SIGCHLD, HandSigCHLD);  /* restarting handler */
     }
     /* create and bind socket */
-    if ( (list_fd = sockbind(argv[optind], "echo", 6, SOCK_STREAM)) < 0) {
+    if ( (list_fd = sockbindopt(argv[optind], "echo", 6, 
+                               SOCK_STREAM, reuse)) < 0) {
        return 1;
     }   
     /* release privileges and go daemon */
@@ -167,6 +174,10 @@ int main(int argc, char *argv[])
        }
        if (pid == 0) {      /* child */
            close(list_fd);          /* close listening socket */   
+           if (keepalive) {         /* enable keepalive ? */
+               setsockopt(conn_fd, SOL_SOCKET, SO_KEEPALIVE, 
+                          &keepalive, sizeof(keepalive));
+           }
            ServEcho(conn_fd);       /* handle echo */
            if (debugging) {
                snprintf(debug, MAXLINE, "Closed connection %s\n", ipaddr);
@@ -193,6 +204,8 @@ void usage(void) {
     printf("  echod [-h] \n");
     printf("  -h          print this help\n");
     printf("  -d          write debug info\n");
+    printf("  -k          enable SO_KEEPALIVE\n");
+    printf("  -r          enable SO_REUSEADDR\n");
     printf("  -i          use interactively\n");
     printf("  -c          disable BSD semantics\n");
     printf("  -w N        wait N sec. before calling accept\n");