aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRonald S. Bultje <rsbultje@gmail.com>2008-08-19 23:44:23 +0000
committerRonald S. Bultje <rsbultje@gmail.com>2008-08-19 23:44:23 +0000
commitba99cfc2130025cd63a0ad767a1ee9293c2936f1 (patch)
treec3582706648e3feef340be6368c849720c6ce3e8
parentb76e3424cac3fd8bfb1e9e63477aa1ed1a12a5e4 (diff)
downloadffmpeg-ba99cfc2130025cd63a0ad767a1ee9293c2936f1.tar.gz
Implement url_open_protocol(), which is basiclly the former url_open()
but which opens a URLProtocol instead of a filename. url_open() is reimplemented to call url_open_protocol(). See discussion on "url_open_protocol" on ffmpeg-devel. Originally committed as revision 14857 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r--libavformat/avio.c69
-rw-r--r--libavformat/avio.h2
2 files changed, 39 insertions, 32 deletions
diff --git a/libavformat/avio.c b/libavformat/avio.c
index 743cc88e98..1278827802 100644
--- a/libavformat/avio.c
+++ b/libavformat/avio.c
@@ -59,41 +59,12 @@ int register_protocol(URLProtocol *protocol)
return 0;
}
-int url_open(URLContext **puc, const char *filename, int flags)
+int url_open_protocol (URLContext **puc, struct URLProtocol *up,
+ const char *filename, int flags)
{
URLContext *uc;
- URLProtocol *up;
- const char *p;
- char proto_str[128], *q;
int err;
- p = filename;
- q = proto_str;
- while (*p != '\0' && *p != ':') {
- /* protocols can only contain alphabetic chars */
- if (!isalpha(*p))
- goto file_proto;
- if ((q - proto_str) < sizeof(proto_str) - 1)
- *q++ = *p;
- p++;
- }
- /* if the protocol has length 1, we consider it is a dos drive */
- if (*p == '\0' || (q - proto_str) <= 1) {
- file_proto:
- strcpy(proto_str, "file");
- } else {
- *q = '\0';
- }
-
- up = first_protocol;
- while (up != NULL) {
- if (!strcmp(proto_str, up->name))
- goto found;
- up = up->next;
- }
- err = AVERROR(ENOENT);
- goto fail;
- found:
uc = av_malloc(sizeof(URLContext) + strlen(filename) + 1);
if (!uc) {
err = AVERROR(ENOMEM);
@@ -117,7 +88,7 @@ int url_open(URLContext **puc, const char *filename, int flags)
//We must be carefull here as url_seek() could be slow, for example for http
if( (flags & (URL_WRONLY | URL_RDWR))
- || !strcmp(proto_str, "file"))
+ || !strcmp(up->name, "file"))
if(!uc->is_streamed && url_seek(uc, 0, SEEK_SET) < 0)
uc->is_streamed= 1;
*puc = uc;
@@ -127,6 +98,40 @@ int url_open(URLContext **puc, const char *filename, int flags)
return err;
}
+int url_open(URLContext **puc, const char *filename, int flags)
+{
+ URLProtocol *up;
+ const char *p;
+ char proto_str[128], *q;
+
+ p = filename;
+ q = proto_str;
+ while (*p != '\0' && *p != ':') {
+ /* protocols can only contain alphabetic chars */
+ if (!isalpha(*p))
+ goto file_proto;
+ if ((q - proto_str) < sizeof(proto_str) - 1)
+ *q++ = *p;
+ p++;
+ }
+ /* if the protocol has length 1, we consider it is a dos drive */
+ if (*p == '\0' || (q - proto_str) <= 1) {
+ file_proto:
+ strcpy(proto_str, "file");
+ } else {
+ *q = '\0';
+ }
+
+ up = first_protocol;
+ while (up != NULL) {
+ if (!strcmp(proto_str, up->name))
+ return url_open_protocol (puc, up, filename, flags);
+ up = up->next;
+ }
+ *puc = NULL;
+ return AVERROR(ENOENT);
+}
+
int url_read(URLContext *h, unsigned char *buf, int size)
{
int ret;
diff --git a/libavformat/avio.h b/libavformat/avio.h
index 2d2e26999d..8137cb54dc 100644
--- a/libavformat/avio.h
+++ b/libavformat/avio.h
@@ -62,6 +62,8 @@ typedef struct URLPollEntry {
typedef int URLInterruptCB(void);
+int url_open_protocol (URLContext **puc, struct URLProtocol *up,
+ 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_write(URLContext *h, unsigned char *buf, int size);