Built upon nenieiri's version (here), with some hacks and improvements of mine.
Good to know:
- It uses a linked list as data structure for managing the clients.
- The Mac version (depends on the server OS your exams are run on) uses
FD_ZERO(&lala)
as an abbreviation ofbzero(&lala, sizeof(lala))
. - The newlines in the functions are intentional for better chunking.
make run
compiles mini_serv.c
and starts the server. The server, although, isn't supposed to do anything on its own.
All it's doing is broadcasting incoming messages to all clients that are already connected. So, to test whether everything's working:
- Open 3 terminal windows.
- In one of them, run
make run
. - In the other (at least) two, run
nc 127.0.0.1 8080
.
You should see something similar to this:
$ make run
/Applications/Xcode.app/Contents/Developer/usr/bin/make all
cc -Wall -Wextra -Werror mini_serv.c -o mini_serv
./mini_serv 8080
|
$ nc 127.0.0.1 8080
server: client 1 just arrived
lala
client 1: hohoho
^C
$ |
$ nc 127.0.0.1 8080
client 0: lala
hohoho
server: client 0 just left
|
Assignment name : mini_serv
Expected files : mini_serv.c
Allowed functions: write, close, select, socket, accept, listen, send, recv, bind, strstr, malloc, realloc, free, calloc, bzero, atoi, sprintf, strlen, exit, strcpy, strcat, memset
Write a program that will listen for client to connect on a certain port on 127.0.0.1 and will let clients to speak with each other
This program will take as first argument the port to bind to
If no argument is given, it should write in stderr "Wrong number of arguments" followed by a \n and exit with status 1
If a System Calls returns an error before the program start accepting connection, it should write in stderr "Fatal error" followed by a \n and exit with status 1
If you cant allocate memory it should write in stderr "Fatal error" followed by a \n and exit with status 1
Your program must be non-blocking but client can be lazy and if they don't read your message you must NOT disconnect them...
Your program must not contains #define preproc
Your program must only listen to 127.0.0.1
The fd that you will receive will already be set to make 'recv' or 'send' to block if select hasn't be called before calling them, but will not block otherwise.
When a client connect to the server:
- the client will be given an id. the first client will receive the id 0 and each new client will received the last client id + 1
- %d will be replace by this number
- a message is sent to all the client that was connected to the server: "server: client %d just arrived\n"
Clients must be able to send messages to your program.
- message will only be printable characters, no need to check
- a single message can contains multiple \n
- when the server receive a message, it must resend it to all the other client with "client %d: " before every line!
When a client disconnect from the server:
- a message is sent to all the client that was connected to the server: "server: client %d just left\n"
Memory or fd leaks are forbidden
To help you, you will find the file main.c with the beginning of a server and maybe some useful functions. (Beware this file use forbidden functions or write things that must not be there in your final program)
Warning our tester is expecting that you send the messages as fast as you can. Don't do un-necessary buffer.
Evaluation can be a bit longer than usual...
Hint: you can use nc to test your program
Hint: you should use nc to test your program
Hint: To test you can use fcntl(fd, F_SETFL, O_NONBLOCK) but use select and NEVER check EAGAIN (man 2 send)