From 4d60b8da9cdcd4716fe65c8872ec60a14d2c1e48 Mon Sep 17 00:00:00 2001 From: Oskar Date: Sun, 2 Jun 2024 21:32:41 +0200 Subject: listen-DGRAM which is basically a version of listen but with UDP --- client.c | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) (limited to 'client.c') diff --git a/client.c b/client.c index 5977713..9be43ae 100644 --- a/client.c +++ b/client.c @@ -10,14 +10,14 @@ #include #include #include +#include -// int listen(int sockfd, int backlog); #define __FAIL EXIT_FAILURE #define BACKLOG 2 #define __PORT "62000" #define BUF_SZ_2 2048 -int talk_to_server (int sockfd) { +void talk_to_server (int sockfd) { while (1) { char editbuffer[BUF_SZ_2]; @@ -26,7 +26,7 @@ int talk_to_server (int sockfd) { char *fgs = fgets(editbuffer, BUF_SZ_2, stdin); socklen_t fgs_len = strlen(editbuffer); if (fgs == NULL) { - return 0; + continue; } if (editbuffer[0] == '\n') { @@ -37,7 +37,13 @@ int talk_to_server (int sockfd) { continue; } } - return 0; +} + +void INThandler(int sockfd) { + + fprintf(stderr, "\n"); + close(sockfd); + exit(0); } int main (int argc, char *argv[]) { @@ -54,7 +60,6 @@ int main (int argc, char *argv[]) { struct addrinfo *res; struct addrinfo *p; memset(&hints, 0, sizeof(hints)); - //hints.ai_flags = ; hints.ai_family = AF_INET; hints.ai_socktype = SOCK_STREAM; @@ -80,9 +85,11 @@ int main (int argc, char *argv[]) { } if (connect_result == -1 || sockfd == -1) { + close(sockfd); exit(__FAIL); } + signal(SIGINT, INThandler); freeaddrinfo(res); talk_to_server(sockfd); -- cgit v1.2.3