aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--desiredata/src/u_pdreceive.c36
1 files changed, 7 insertions, 29 deletions
diff --git a/desiredata/src/u_pdreceive.c b/desiredata/src/u_pdreceive.c
index 619d2f93..aca715f8 100644
--- a/desiredata/src/u_pdreceive.c
+++ b/desiredata/src/u_pdreceive.c
@@ -45,10 +45,6 @@ static void dopoll();
int main(int argc, char **argv) {
int portno;
struct sockaddr_in server;
-#ifdef MSW
- short version = MAKEWORD(2, 0);
- WSADATA nobby;
-#endif
if (argc < 2 || sscanf(argv[1],"%d",&portno)<1 || portno<=0) goto usage;
if (argc >= 3) {
if (!strcmp(argv[2],"tcp")) protocol = SOCK_STREAM;
@@ -56,6 +52,8 @@ int main(int argc, char **argv) {
else goto usage;
} else protocol = SOCK_STREAM;
#ifdef MSW
+ short version = MAKEWORD(2, 0);
+ WSADATA nobby;
if (WSAStartup(version, &nobby)) sockerror("WSAstartup");
#endif
sockfd = socket(AF_INET, protocol, 0);
@@ -66,28 +64,15 @@ int main(int argc, char **argv) {
maxfd = sockfd + 1;
server.sin_family = AF_INET;
server.sin_addr.s_addr = INADDR_ANY;
-
#ifdef IRIX
/* this seems to work only in IRIX but is unnecessary in Linux. Not sure what MSW needs in place of this. */
if (setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, 0, 0) < 0) fprintf(stderr, "setsockopt failed\n");
#endif
-
/* assign client port number */
server.sin_port = htons((unsigned short)portno);
-
/* name the socket */
- if (bind(sockfd, (struct sockaddr *)&server, sizeof(server)) < 0) {
- sockerror("bind");
- x_closesocket(sockfd);
- return 0;
- }
- if (protocol == SOCK_STREAM) {
- if (listen(sockfd, 5) < 0) {
- sockerror("listen");
- x_closesocket(sockfd);
- return 1;
- }
- }
+ if (bind(sockfd, (struct sockaddr *)&server, sizeof(server))<0) {sockerror("bind"); x_closesocket(sockfd); return 0;}
+ if (protocol == SOCK_STREAM) if (listen(sockfd, 5) < 0) {sockerror("listen"); x_closesocket(sockfd); return 1;}
/* now loop forever selecting on sockets */
while (1) dopoll();
usage:
@@ -113,10 +98,7 @@ static void rmport(t_fdpoll *x) {
if (fp == x) {
x_closesocket(fp->fd);
free(fp->inbuf);
- while (i--) {
- fp[0] = fp[1];
- fp++;
- }
+ for (;i--;fp++) fp[0] = fp[1];
fdpoll = (t_fdpoll *)realloc(fdpoll, (nfdpoll-1)*sizeof(t_fdpoll));
nfdpoll--;
printf("number_connected %d;\n", nfdpoll);
@@ -143,10 +125,7 @@ static void udpread() {
#ifdef MSW
for (int j=0; j<ret; j++) putchar(buf[j]);
#else
- if (write(1, buf, ret) < ret) {
- perror("write");
- exit(1);
- }
+ if (write(1, buf, ret) < ret) {perror("write"); exit(1);}
#endif
}
}
@@ -200,14 +179,13 @@ static void tcpread(t_fdpoll *x) {
}
static void dopoll() {
- t_fdpoll *fp;
fd_set readset, writeset, exceptset;
FD_ZERO(&writeset);
FD_ZERO(&readset);
FD_ZERO(&exceptset);
FD_SET(sockfd, &readset);
if (protocol == SOCK_STREAM) {
- fp = fdpoll;
+ t_fdpoll *fp = fdpoll;
for (int i=nfdpoll; i--; fp++) FD_SET(fp->fd, &readset);
}
if (select(maxfd+1, &readset, &writeset, &exceptset, 0) < 0) {perror("select"); exit(1);}