mirror of
				https://git.ffmpeg.org/ffmpeg.git
				synced 2025-11-04 09:40:56 +00:00 
			
		
		
		
	Make url_read_complete retry on EAGAIN and return how much data it read
if it reached EOF, making it useful in more cases. Originally committed as revision 21393 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
		
							parent
							
								
									98287358e9
								
							
						
					
					
						commit
						ddb901b74d
					
				
					 2 changed files with 12 additions and 2 deletions
				
			
		| 
						 | 
					@ -156,8 +156,10 @@ int url_read_complete(URLContext *h, unsigned char *buf, int size)
 | 
				
			||||||
    len = 0;
 | 
					    len = 0;
 | 
				
			||||||
    while (len < size) {
 | 
					    while (len < size) {
 | 
				
			||||||
        ret = url_read(h, buf+len, size-len);
 | 
					        ret = url_read(h, buf+len, size-len);
 | 
				
			||||||
        if (ret < 1)
 | 
					        if (ret == AVERROR(EAGAIN)) {
 | 
				
			||||||
            return ret;
 | 
					            ret = 0;
 | 
				
			||||||
 | 
					        } else if (ret < 1)
 | 
				
			||||||
 | 
					            return ret < 0 ? ret : len;
 | 
				
			||||||
        len += ret;
 | 
					        len += ret;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    return len;
 | 
					    return len;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -69,6 +69,14 @@ int url_open_protocol (URLContext **puc, struct URLProtocol *up,
 | 
				
			||||||
                       const char *filename, int flags);
 | 
					                       const char *filename, int flags);
 | 
				
			||||||
int url_open(URLContext **h, const char *filename, int flags);
 | 
					int url_open(URLContext **h, const char *filename, int flags);
 | 
				
			||||||
int url_read(URLContext *h, unsigned char *buf, int size);
 | 
					int url_read(URLContext *h, unsigned char *buf, int size);
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * Read as many bytes as possible (up to size), calling the
 | 
				
			||||||
 | 
					 * read function multiple times if necessary.
 | 
				
			||||||
 | 
					 * Will also retry if the read function returns AVERROR(EAGAIN).
 | 
				
			||||||
 | 
					 * This makes special short-read handling in applications
 | 
				
			||||||
 | 
					 * unnecessary, if the return value is < size then it is
 | 
				
			||||||
 | 
					 * certain there was either an error or the end of file was reached.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
int url_read_complete(URLContext *h, unsigned char *buf, int size);
 | 
					int url_read_complete(URLContext *h, unsigned char *buf, int size);
 | 
				
			||||||
int url_write(URLContext *h, unsigned char *buf, int size);
 | 
					int url_write(URLContext *h, unsigned char *buf, int size);
 | 
				
			||||||
int64_t url_seek(URLContext *h, int64_t pos, int whence);
 | 
					int64_t url_seek(URLContext *h, int64_t pos, int whence);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue