3 /* linker: color.o debug.o server.o signal.o */
19 #define BUFFER_SIZE 4096
25 char *progname
= NULL
;
27 socket_t sock
= INVALID_SOCKET
;
28 socket_t conn
= INVALID_SOCKET
;
34 FILE *fid
= ret
? stderr
: stdout
;
35 fprintf (fid
, "usage: %s\n", progname
);
36 fprintf (fid
, " -h : help message\n");
37 fprintf (fid
, " -p : port number (%d)\n", port
);
38 fprintf (fid
, " -v : verbose level (%d)\n", verbose
);
43 void stop_server (__attribute__((unused
)) int sig
)
45 if (conn
!= INVALID_SOCKET
) {
48 if (sock
!= INVALID_SOCKET
) {
51 terminate_network_context ();
57 int main (int argc
, char *argv
[])
64 while (progname
[i
] != '\0') {
65 if ((progname
[i
] == '/') || (progname
[i
] == '\\')) {
73 /* argument processing */
76 char *arg
= *(++argv
);
78 VERBOSE (ERROR
, PERROR ("%s: invalid option -- '%s'\n", progname
, arg
); usage (1));
84 arg
= (arg
[2]) ? arg
+ 2 : (--argc
> 0) ? *(++argv
) : NULL
;
86 VERBOSE (ERROR
, PERROR ("%s: missing port number\n", progname
); usage (1));
91 VERBOSE (ERROR
, PERROR ("%s: incorrect port number (%s)\n", progname
, arg
); usage (1));
96 arg
= (arg
[2]) ? arg
+ 2 : (--argc
> 0) ? *(++argv
) : NULL
;
98 VERBOSE (ERROR
, PERROR ("%s: missing verbose level\n", progname
); usage (1));
101 verbose
= atoi (arg
);
105 return usage (c
!= 'h');
109 VERBOSE (DEBUG
, PRINT ("Initializing socket\n"));
110 init_network_context ();
111 sock
= open_listening_socket (port
);
112 if (sock
== INVALID_SOCKET
) {
113 VERBOSE (ERROR
, PERROR ("Can't open listening socket\n"));
116 VERBOSE (INFO
, PRINT ("Listening socket on port %d\n", port
));
118 signal (SIGTERM
, &stop_server
);
122 conn
= accept_incoming_connection (sock
);
123 if (conn
== INVALID_SOCKET
) {
128 VERBOSE (DEBUG
, PRINT ("Server connected, waiting for data\n"));
130 unsigned char *data
= {0};
132 int len
= receive_data (conn
, &data
);
134 VERBOSE (WARNING
, PRINT ("Connection closed by peer (rx)\n"));
135 } else if (len
< 0) {
136 VERBOSE (WARNING
, PRINT ("Connection in error (rx)\n"));
140 VERBOSE (DEBUG
, PRINT ("Received:\n%s\n", data
));
142 int rc
= send_data (conn
, data
, len
);
144 VERBOSE (WARNING
, PRINT ("Connection closed by peer (tx)\n"));
146 VERBOSE (WARNING
, PRINT ("Connection in error (tx)\n"));
150 VERBOSE (DEBUG
, PRINT ("Closing connection\n"));
155 conn
= INVALID_SOCKET
;
158 VERBOSE (DEBUG
, PRINT ("Closing socket\n"));
160 terminate_network_context ();
165 // test: webserver.exe -h
166 // test: webserver.exe -h | awk '/usage:/ { rc=1 } END { exit (1-rc) }'
167 // test: webserver.exe -_ 2> /dev/null | wc -l | xargs test 0 =
168 // test: webserver.exe -_ 2>&1 | awk '/usage:/ { rc=1 } END { exit (1-rc) }'
169 // test: webserver.exe error 2>&1 | grep -q 'invalid option'
170 // test: webserver.exe -v 2>&1 | grep -q 'missing verbose level'
171 // test: webserver.exe -p 2>&1 | grep -q 'missing port number'
172 // test: webserver.exe -p -1 2>&1 | grep -q 'incorrect port number'
173 // test: webserver.exe > test.log & pid=$!; sleep 1; kill -9 $pid; grep -q 'Listening socket on port 8080' test.log
174 // test: webserver.exe -p 8000 > test.log & pid=$!; sleep 1; kill -9 $pid; grep -q 'Listening socket on port 8000' test.log
175 // test: webserver.exe & pid=$!; sleep 1; kill -TERM $pid; ps aux | grep -q [w]ebserver.exe && kill -9 $pid || rc=1; test x$rc = x1
177 /* vim: set ts=4 sw=4 et: */