1
0
mirror of https://git.FreeBSD.org/ports.git synced 2024-11-05 22:43:24 +00:00
freebsd-ports/www/wwwoffle/files/patch-ac
Steve Price 49d2ff06d8 From the submitter:
The wwwoffled program in the www/wwwoffle port doesn't retry a select()
call when select() fails with EINTR, which it should do.  This causes
problems such as a 'wwwoffle -offline' command not taking effect which
can be annoying.

PR:		19652
Submitted by:	maintainer
2000-07-07 19:31:03 +00:00

85 lines
1.6 KiB
Plaintext

--- io.c.orig Sun Jan 2 19:55:12 2000
+++ io.c Mon May 29 20:40:30 2000
@@ -135,14 +135,17 @@
fd_set readfd;
struct timeval tv;
- FD_ZERO(&readfd);
-
- FD_SET(fd,&readfd);
-
- tv.tv_sec=tv.tv_usec=0;
-
- if(select(fd+1,&readfd,NULL,NULL,&tv)<=0)
- return(nr);
+ while(1)
+ {
+ tv.tv_sec=tv.tv_usec=0;
+ FD_ZERO(&readfd);
+ FD_SET(fd,&readfd);
+ n=select(fd+1,&readfd,NULL,NULL,&tv);
+ if(n>0)
+ break;
+ if(n==0 || errno!=EINTR)
+ return(nr);
+ }
n=read(fd,fdbuf[fd],BUFSIZE);
@@ -206,15 +209,18 @@
fd_set readfd;
struct timeval tv;
- FD_ZERO(&readfd);
-
- FD_SET(fd,&readfd);
-
- tv.tv_sec=timeout;
- tv.tv_usec=0;
-
- if(select(fd+1,&readfd,NULL,NULL,&tv)<=0)
- return(-1);
+ while(1)
+ {
+ tv.tv_sec=timeout;
+ tv.tv_usec=0;
+ FD_ZERO(&readfd);
+ FD_SET(fd,&readfd);
+ nr=select(fd+1,&readfd,NULL,NULL,&tv);
+ if(nr>0)
+ break;
+ if(nr==0 || errno!=EINTR)
+ return(-1);
+ }
nr=read(fd,buffer,n);
}
@@ -364,15 +370,18 @@
fd_set readfd;
struct timeval tv;
- FD_ZERO(&readfd);
-
- FD_SET(fd,&readfd);
-
- tv.tv_sec=timeout;
- tv.tv_usec=0;
-
- if(select(fd+1,&readfd,NULL,NULL,&tv)<=0)
- return(-1);
+ while(1)
+ {
+ tv.tv_sec=timeout;
+ tv.tv_usec=0;
+ FD_ZERO(&readfd);
+ FD_SET(fd,&readfd);
+ n=select(fd+1,&readfd,NULL,NULL,&tv);
+ if(n>0)
+ break;
+ if(n==0 || errno!=EINTR)
+ return(-1);
+ }
n=read(fd,fdbuf[fd]+fdbytes[fd],BUFSIZE-fdbytes[fd]);
fdbytes[fd]+=n;