Commit 6bb344e9 authored by bellard's avatar bellard

added url_get_max_packet_size() support - added URL_RDWR flag


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@795 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 3441fa10
...@@ -58,15 +58,18 @@ int url_open(URLContext **puc, const char *filename, int flags) ...@@ -58,15 +58,18 @@ int url_open(URLContext **puc, const char *filename, int flags)
goto found; goto found;
up = up->next; up = up->next;
} }
return -ENOENT; err = -ENOENT;
goto fail;
found: found:
uc = av_malloc(sizeof(URLContext)); uc = av_malloc(sizeof(URLContext));
if (!uc) if (!uc) {
return -ENOMEM; err = -ENOMEM;
goto fail;
}
uc->prot = up; uc->prot = up;
uc->flags = flags; uc->flags = flags;
uc->is_streamed = 0; /* default = not streamed */ uc->is_streamed = 0; /* default = not streamed */
uc->packet_size = 1; /* default packet size */ uc->max_packet_size = 0; /* default: stream file */
err = up->url_open(uc, filename, flags); err = up->url_open(uc, filename, flags);
if (err < 0) { if (err < 0) {
av_free(uc); av_free(uc);
...@@ -75,6 +78,9 @@ int url_open(URLContext **puc, const char *filename, int flags) ...@@ -75,6 +78,9 @@ int url_open(URLContext **puc, const char *filename, int flags)
} }
*puc = uc; *puc = uc;
return 0; return 0;
fail:
*puc = NULL;
return err;
} }
int url_read(URLContext *h, unsigned char *buf, int size) int url_read(URLContext *h, unsigned char *buf, int size)
...@@ -89,8 +95,11 @@ int url_read(URLContext *h, unsigned char *buf, int size) ...@@ -89,8 +95,11 @@ int url_read(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)
{ {
int ret; int ret;
if (!(h->flags & URL_WRONLY)) if (!(h->flags & (URL_WRONLY | URL_RDWR)))
return -EIO; return -EIO;
/* avoid sending too big packets */
if (h->max_packet_size && size > h->max_packet_size)
return -EIO;
ret = h->prot->url_write(h, buf, size); ret = h->prot->url_write(h, buf, size);
return ret; return ret;
} }
...@@ -132,3 +141,16 @@ offset_t url_filesize(URLContext *h) ...@@ -132,3 +141,16 @@ offset_t url_filesize(URLContext *h)
url_seek(h, pos, SEEK_SET); url_seek(h, pos, SEEK_SET);
return size; return size;
} }
/*
* Return the maximum packet size associated to packetized file
* handle. If the file is not packetized (stream like http or file on
* disk), then 0 is returned.
*
* @param h file handle
* @return maximum packet size in bytes
*/
int url_get_max_packet_size(URLContext *h)
{
return h->max_packet_size;
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment