From d5c7775113e61dc23254fa8a986469f83f12b8c5 Mon Sep 17 00:00:00 2001 From: Sam Hocevar Date: Tue, 19 Oct 2021 15:58:00 +0200 Subject: [PATCH] Minor IPv6 tweaks and credit to original author --- NEWS | 1 + THANKS | 1 + src/cacaserver.c | 23 +++++++++++------------ 3 files changed, 13 insertions(+), 12 deletions(-) diff --git a/NEWS b/NEWS index c50e22a2..683d1905 100644 --- a/NEWS +++ b/NEWS @@ -2,6 +2,7 @@ \section news0_99_beta20 Changes between 0.99.beta20 and 0.99.beta19 + - IPv6 support in cacaserver - fixed a bug from 2004 that caused PDF documentation generation to fail - memory allocation functions are now more robust - numerous fixes for memory leaks and invalid memory accesses: diff --git a/THANKS b/THANKS index f12b5b4e..8ae4ad5c 100644 --- a/THANKS +++ b/THANKS @@ -5,6 +5,7 @@ - Gildas Bazin - win32 driver improvements - Jari Komppa - win32 speed improvements - Bastian Märkisch - bugfixes and win32 driver improvements +- Denis Fondras - IPv6 support in cacaserver \section thanks2 Reused code diff --git a/src/cacaserver.c b/src/cacaserver.c index 9210c9e3..e195cf71 100644 --- a/src/cacaserver.c +++ b/src/cacaserver.c @@ -1,6 +1,7 @@ /* * cacaserver Colour ASCII-Art library * Copyright © 2006-2021 Sam Hocevar + * 2016 Denis Fondras * 2006 Jean-Yves Lamoureux * All Rights Reserved * @@ -100,7 +101,7 @@ struct client struct sock { int sockfd; struct sockaddr_in my_addr; -}; +}; struct server { @@ -125,7 +126,7 @@ struct server void (*sigpipe_handler)(int); }; -void print_ip(struct sockaddr *ai); +void fprint_ip(FILE *stream, struct sockaddr *ai); static void manage_connections(struct server *server, int sockfd); static int send_data(struct server *server, struct client *c); ssize_t nonblock_write(int fd, void *buf, size_t len); @@ -209,7 +210,7 @@ int main(void) server->socks[server->sock_count].sockfd = fd; server->sock_count++; fprintf(stderr, "listening on "); - print_ip(res->ai_addr); + fprint_ip(stderr, res->ai_addr); fprintf(stderr, "\n"); } freeaddrinfo(ai); @@ -337,7 +338,7 @@ int main(void) * XXX: The following functions are local */ -void print_ip(struct sockaddr *ai) +void fprint_ip(FILE *stream, struct sockaddr *ai) { char buffer[INET6_ADDRSTRLEN]; socklen_t len = sizeof(struct sockaddr_in6); @@ -345,15 +346,13 @@ void print_ip(struct sockaddr *ai) if (ai->sa_family == AF_INET) len = sizeof(struct sockaddr_in); - int err = getnameinfo(ai, len, buffer, sizeof(buffer), NULL, 0, - NI_NUMERICHOST); - if (err != 0) { - fprintf(stderr, "n/a"); - } - fprintf(stderr, "%s",buffer); + int err = getnameinfo(ai, len, buffer, sizeof(buffer), NULL, 0, NI_NUMERICHOST); + if (err != 0) + fprintf(stream, "n/a"); + else + fprintf(stream, "%s", buffer); } - static void manage_connections(struct server *server, int sockfd) { int fd, flags; @@ -365,7 +364,7 @@ static void manage_connections(struct server *server, int sockfd) return; fprintf(stderr, "[%i] connected from ", fd); - print_ip((struct sockaddr*)&remote_addr); + fprint_ip(stderr, (struct sockaddr*)&remote_addr); fprintf(stderr, "\n"); /* Non blocking socket */