3 /* linker: color.o debug.o server.o signal.o */
17 #define BUFFER_SIZE 4096
23 char *progname
= NULL
;
25 socket_t sock
= INVALID_SOCKET
;
31 FILE *fid
= ret
? stderr
: stdout
;
32 fprintf (fid
, "usage: %s\n", progname
);
33 fprintf (fid
, " -h : help message\n");
34 fprintf (fid
, " -p : port number (%d)\n", port
);
35 fprintf (fid
, " -v : verbose level (%d)\n", verbose
);
40 void stop_server (__attribute__((unused
)) int sig
)
42 if (sock
!= INVALID_SOCKET
) {
43 close_listening_socket (sock
);
50 int main (int argc
, char *argv
[])
57 while (progname
[i
] != '\0') {
58 if ((progname
[i
] == '/') || (progname
[i
] == '\\')) {
66 /* argument processing */
69 char *arg
= *(++argv
);
71 VERBOSE (ERROR
, fprintf (stderr
, "%s: invalid option -- '%s'\n", progname
, arg
); usage (1));
77 arg
= (arg
[2]) ? arg
+ 2 : (--argc
> 0) ? *(++argv
) : NULL
;
79 VERBOSE (ERROR
, fprintf (stderr
, "%s: missing port number\n", progname
); usage (1));
84 VERBOSE (ERROR
, fprintf (stderr
, "%s: incorrect port number (%s)\n", progname
, arg
); usage (1));
89 arg
= (arg
[2]) ? arg
+ 2 : (--argc
> 0) ? *(++argv
) : NULL
;
91 VERBOSE (ERROR
, fprintf (stderr
, "%s: missing verbose level\n", progname
); usage (1));
98 return usage (c
!= 'h');
102 VERBOSE (DEBUG
, fprintf (stdout
, "Initializing socket\n"));
103 sock
= open_listening_socket (port
);
104 if (sock
== INVALID_SOCKET
) {
105 VERBOSE (ERROR
, fprintf (stderr
, "Can't open listening socket\n"));
108 VERBOSE (INFO
, fprintf (stdout
, "Listening socket on port %d\n", port
));
112 int connection
= accept_incoming_connection (sock
);
113 if ((connection
< 0) && (errno
== EAGAIN
)) {
114 accept_nonblock_ok
= 1;
116 if (connection
< 0) {
121 VERBOSE (DEBUG
, fprintf (stdout
, "Server connected, waiting for data\n"));
124 unsigned char data
[BUFFER_SIZE
] = {0};
127 len
= receive_data (connection
, data
, size (data
));
129 // nonblocking connection
134 VERBOSE (WARNING
, fprintf (stdout
, "Connection closed by peer\n"));
135 close_connection (connection
);
141 len
= send_data (connection
, data
, size (data
));
143 VERBOSE (WARNING
, fprintf (stdout
, "Connection closed by peer\n"));
144 close_connection (connection
);
148 /* sleep so that we go trhough remaining data in receive buffer */
153 VERBOSE (DEBUG
, fprintf (stdout
, "Closing socket\n"));
154 close_listening_socket (sock
);
159 // test: webserver.exe -h
160 // test: webserver.exe -h | awk '/usage:/ { rc=1 } END { exit (1-rc) }'
161 // test: webserver.exe -_ 2> /dev/null | wc -l | xargs test 0 =
162 // test: webserver.exe -_ 2>&1 | awk '/usage:/ { rc=1 } END { exit (1-rc) }'
163 // test: webserver.exe error 2>&1 | grep -q 'invalid option'
164 // test: webserver.exe -v 2>&1 | grep -q 'missing verbose level'
165 // test: webserver.exe -p 2>&1 | grep -q 'missing port number'
166 // test: webserver.exe -p -1 2>&1 | grep -q 'incorrect port number'
167 // test: ( webserver.exe & pid=$!; ( sleep 1; kill -TERM $pid ) ) | grep -q 'Listening socket on port 8080'
168 // test: ( webserver.exe -p 8008 & pid=$!; ( sleep 1; kill -TERM $pid ) ) | grep -q 'Listening socket on port 8008'
169 // test: webserver.exe & pid=$!; sleep 1; kill -INT $pid; ps aux | grep -q [w]ebserver.exe && kill -TERM $pid || rc=1; test x$rc = x1
171 /* vim: set ts=4 sw=4 et: */