X-Git-Url: https://gapil.gnulinux.it/gitweb/?p=gapil.git;a=blobdiff_plain;f=sources%2FUDP_echo.c;h=cc9e3ae786a378d0a1b2cbb2c57fb804c2f51b2b;hp=8de90878235dc7fee1fd217dfdfbe5a55e31c724;hb=eefeeaee57a56cfe1ff8c02a26c44d6f87f1368c;hpb=a0184b68ca9dced41be95342ffd8a8ee04d2b861 diff --git a/sources/UDP_echo.c b/sources/UDP_echo.c index 8de9087..cc9e3ae 100644 --- a/sources/UDP_echo.c +++ b/sources/UDP_echo.c @@ -26,7 +26,7 @@ * * Usage: echo -h give all info's * - * $Id: UDP_echo.c,v 1.1 2004/05/01 17:53:42 piccardi Exp $ + * $Id: UDP_echo.c,v 1.4 2004/06/04 00:31:33 piccardi Exp $ * ****************************************************************/ /* @@ -44,7 +44,7 @@ #define MAXLINE 256 void usage(void); -void ClientEcho(FILE * filein, int socket, struct sockaddr_in *serv_add); +void ClientEcho(FILE * filein, int socket); void SigTERM_hand(int sig); /* Program begin */ @@ -54,7 +54,7 @@ int main(int argc, char *argv[]) * Variables definition */ int sock, i; - struct sockaddr_in serv_add; + struct sockaddr_in dst_addr; /* * Input section: decode parameters passed in the calling * Use getopt function @@ -90,16 +90,17 @@ int main(int argc, char *argv[]) return 1; } /* initialize address */ - memset((void *) &serv_add, 0, sizeof(serv_add)); /* clear server address */ - serv_add.sin_family = AF_INET; /* address type is INET */ - serv_add.sin_port = htons(7); /* echo port is 7 */ + memset((void *) &dst_addr, 0, sizeof(dst_addr)); /* clear address */ + dst_addr.sin_family = AF_INET; /* address type is INET */ + dst_addr.sin_port = htons(7); /* echo port is 7 */ /* build address using inet_pton */ - if ( (inet_pton(AF_INET, argv[optind], &serv_add.sin_addr)) <= 0) { + if ( (inet_pton(AF_INET, argv[optind], &dst_addr.sin_addr)) <= 0) { perror("Address creation error"); return 1; } + connect(sock, (struct sockaddr *) &dst_addr, sizeof(dst_addr)); /* do read/write operations */ - ClientEcho(stdin, sock, &serv_add); + ClientEcho(stdin, sock); /* normal exit */ return 0; } @@ -116,7 +117,7 @@ void usage(void) { exit(1); } -void ClientEcho(FILE * filein, int socket, struct sockaddr_in * serv_addr) +void ClientEcho(FILE * filein, int socket) { char sendbuff[MAXLINE+1], recvbuff[MAXLINE+1]; int nread, nwrite; @@ -125,21 +126,17 @@ void ClientEcho(FILE * filein, int socket, struct sockaddr_in * serv_addr) if (fgets(sendbuff, MAXLINE, filein) == NULL) { return; /* if no input just return */ } else { /* else we have to write to socket */ - nwrite = sendto(socket, sendbuff, strlen(sendbuff), 0, - (struct sockaddr *) serv_addr, sizeof(*serv_addr)); + nwrite = write(socket, sendbuff, strlen(sendbuff)); if (nwrite < 0) { /* on error stop */ printf("Errore in scrittura: %s", strerror(errno)); return; } } - nread = recvfrom(socket, recvbuff, strlen(sendbuff), 0, NULL, NULL); + nread = read(socket, recvbuff, strlen(sendbuff)); if (nread < 0) { /* error condition, stop client */ printf("Errore in lettura: %s\n", strerror(errno)); return; } - if (nread == 0) { /* server closed connection, stop */ - return; - } recvbuff[nread] = 0; /* else read is ok, write on stdout */ if (fputs(recvbuff, stdout) == EOF) { perror("Errore in scrittura su terminale");