Mercurial > libavformat.hg
changeset 388:9af30d452a0a libavformat
tcp select() check and enables pressing 'q' when reading/(writing) from
tcp/http in ffmpeg.c patch by (Leon van Stuivenberg <l dot vanstuivenberg at chello dot nl>)
author | michael |
---|---|
date | Sun, 14 Mar 2004 19:40:43 +0000 |
parents | f2760852ed18 |
children | e14fcd57ad2f |
files | tcp.c |
diffstat | 1 files changed, 28 insertions(+), 21 deletions(-) [+] |
line wrap: on
line diff
--- a/tcp.c Sun Mar 14 04:08:11 2004 +0000 +++ b/tcp.c Sun Mar 14 19:40:43 2004 +0000 @@ -141,7 +141,7 @@ static int tcp_read(URLContext *h, uint8_t *buf, int size) { TCPContext *s = h->priv_data; - int len, fd_max; + int len, fd_max, ret; fd_set rfds; struct timeval tv; @@ -153,28 +153,31 @@ FD_SET(s->fd, &rfds); tv.tv_sec = 0; tv.tv_usec = 100 * 1000; - select(fd_max + 1, &rfds, NULL, NULL, &tv); + ret = select(fd_max + 1, &rfds, NULL, NULL, &tv); + if (ret > 0 && FD_ISSET(s->fd, &rfds)) { #ifdef __BEOS__ - len = recv(s->fd, buf, size, 0); + len = recv(s->fd, buf, size, 0); #else - len = read(s->fd, buf, size); + len = read(s->fd, buf, size); #endif - if (len < 0) { - if (errno != EINTR && errno != EAGAIN) + if (len < 0) { + if (errno != EINTR && errno != EAGAIN) #ifdef __BEOS__ - return errno; + return errno; #else - return -errno; + return -errno; #endif - } else break; + } else return len; + } else if (ret < 0) { + return -1; + } } - return len; } static int tcp_write(URLContext *h, uint8_t *buf, int size) { TCPContext *s = h->priv_data; - int ret, size1, fd_max; + int ret, size1, fd_max, len; fd_set wfds; struct timeval tv; @@ -187,24 +190,28 @@ FD_SET(s->fd, &wfds); tv.tv_sec = 0; tv.tv_usec = 100 * 1000; - select(fd_max + 1, NULL, &wfds, NULL, &tv); + ret = select(fd_max + 1, NULL, &wfds, NULL, &tv); + if (ret > 0 && FD_ISSET(s->fd, &wfds)) { #ifdef __BEOS__ - ret = send(s->fd, buf, size, 0); + len = send(s->fd, buf, size, 0); #else - ret = write(s->fd, buf, size); + len = write(s->fd, buf, size); #endif - if (ret < 0) { - if (errno != EINTR && errno != EAGAIN) { + if (len < 0) { + if (errno != EINTR && errno != EAGAIN) { #ifdef __BEOS__ - return errno; + return errno; #else - return -errno; + return -errno; #endif + } + continue; } - continue; + size -= len; + buf += len; + } else if (ret < 0) { + return -1; } - size -= ret; - buf += ret; } return size1 - size; }