| @@ -89,13 +89,6 @@ static int default_interrupt_cb(void); | |||
| int (*url_interrupt_cb)(void) = default_interrupt_cb; | |||
| #endif | |||
| #if FF_API_OLD_AVIO | |||
| URLProtocol *av_protocol_next(URLProtocol *p) | |||
| { | |||
| return ffurl_protocol_next(p); | |||
| } | |||
| #endif | |||
| const char *avio_enum_protocols(void **opaque, int output) | |||
| { | |||
| URLProtocol **p = opaque; | |||
| @@ -168,9 +161,7 @@ static int url_alloc_for_protocol (URLContext **puc, struct URLProtocol *up, | |||
| int ffurl_connect(URLContext* uc, AVDictionary **options) | |||
| { | |||
| int err = | |||
| #if !FF_API_OLD_AVIO | |||
| uc->prot->url_open2 ? uc->prot->url_open2(uc, uc->filename, uc->flags, options) : | |||
| #endif | |||
| uc->prot->url_open(uc, uc->filename, uc->flags); | |||
| if (err) | |||
| return err; | |||
| @@ -183,81 +174,6 @@ int ffurl_connect(URLContext* uc, AVDictionary **options) | |||
| return 0; | |||
| } | |||
| #if FF_API_OLD_AVIO | |||
| int url_open_protocol (URLContext **puc, struct URLProtocol *up, | |||
| const char *filename, int flags) | |||
| { | |||
| int ret; | |||
| ret = url_alloc_for_protocol(puc, up, filename, flags, NULL); | |||
| if (ret) | |||
| goto fail; | |||
| ret = ffurl_connect(*puc, NULL); | |||
| if (!ret) | |||
| return 0; | |||
| fail: | |||
| ffurl_close(*puc); | |||
| *puc = NULL; | |||
| return ret; | |||
| } | |||
| int url_alloc(URLContext **puc, const char *filename, int flags) | |||
| { | |||
| return ffurl_alloc(puc, filename, flags, NULL); | |||
| } | |||
| int url_connect(URLContext* uc) | |||
| { | |||
| return ffurl_connect(uc, NULL); | |||
| } | |||
| int url_open(URLContext **puc, const char *filename, int flags) | |||
| { | |||
| return ffurl_open(puc, filename, flags, NULL, NULL); | |||
| } | |||
| int url_read(URLContext *h, unsigned char *buf, int size) | |||
| { | |||
| return ffurl_read(h, buf, size); | |||
| } | |||
| int url_read_complete(URLContext *h, unsigned char *buf, int size) | |||
| { | |||
| return ffurl_read_complete(h, buf, size); | |||
| } | |||
| int url_write(URLContext *h, const unsigned char *buf, int size) | |||
| { | |||
| return ffurl_write(h, buf, size); | |||
| } | |||
| int64_t url_seek(URLContext *h, int64_t pos, int whence) | |||
| { | |||
| return ffurl_seek(h, pos, whence); | |||
| } | |||
| int url_close(URLContext *h) | |||
| { | |||
| return ffurl_close(h); | |||
| } | |||
| int64_t url_filesize(URLContext *h) | |||
| { | |||
| return ffurl_size(h); | |||
| } | |||
| int url_get_file_handle(URLContext *h) | |||
| { | |||
| return ffurl_get_file_handle(h); | |||
| } | |||
| int url_get_max_packet_size(URLContext *h) | |||
| { | |||
| return h->max_packet_size; | |||
| } | |||
| void url_get_filename(URLContext *h, char *buf, int buf_size) | |||
| { | |||
| av_strlcpy(buf, h->filename, buf_size); | |||
| } | |||
| void url_set_interrupt_cb(URLInterruptCB *interrupt_cb) | |||
| { | |||
| avio_set_interrupt_cb(interrupt_cb); | |||
| } | |||
| int av_register_protocol2(URLProtocol *protocol, int size) | |||
| { | |||
| return ffurl_register_protocol(protocol, size); | |||
| } | |||
| #endif | |||
| #define URL_SCHEME_CHARS \ | |||
| "abcdefghijklmnopqrstuvwxyz" \ | |||
| "ABCDEFGHIJKLMNOPQRSTUVWXYZ" \ | |||
| @@ -393,17 +309,6 @@ int ffurl_close(URLContext *h) | |||
| return ret; | |||
| } | |||
| #if FF_API_OLD_AVIO | |||
| int url_exist(const char *filename) | |||
| { | |||
| URLContext *h; | |||
| if (ffurl_open(&h, filename, AVIO_FLAG_READ, NULL, NULL) < 0) | |||
| return 0; | |||
| ffurl_close(h); | |||
| return 1; | |||
| } | |||
| #endif | |||
| int avio_check(const char *url, int flags) | |||
| { | |||
| URLContext *h; | |||
| @@ -471,19 +376,3 @@ int ff_check_interrupt(AVIOInterruptCB *cb) | |||
| #endif | |||
| } | |||
| #if FF_API_OLD_AVIO | |||
| int av_url_read_pause(URLContext *h, int pause) | |||
| { | |||
| if (!h->prot->url_read_pause) | |||
| return AVERROR(ENOSYS); | |||
| return h->prot->url_read_pause(h, pause); | |||
| } | |||
| int64_t av_url_read_seek(URLContext *h, | |||
| int stream_index, int64_t timestamp, int flags) | |||
| { | |||
| if (!h->prot->url_read_seek) | |||
| return AVERROR(ENOSYS); | |||
| return h->prot->url_read_seek(h, stream_index, timestamp, flags); | |||
| } | |||
| #endif | |||
| @@ -66,7 +66,6 @@ typedef struct { | |||
| * function pointers specified in avio_alloc_context() | |||
| */ | |||
| typedef struct { | |||
| #if !FF_API_OLD_AVIO | |||
| /** | |||
| * A class for private options. | |||
| * | |||
| @@ -80,7 +79,6 @@ typedef struct { | |||
| * to any av_opt_* functions in that case. | |||
| */ | |||
| AVClass *av_class; | |||
| #endif | |||
| unsigned char *buffer; /**< Start of the buffer. */ | |||
| int buffer_size; /**< Maximum buffer size */ | |||
| unsigned char *buf_ptr; /**< Current position in the buffer */ | |||
| @@ -97,9 +95,6 @@ typedef struct { | |||
| int must_flush; /**< true if the next seek should flush */ | |||
| int eof_reached; /**< true if eof reached */ | |||
| int write_flag; /**< true if open for writing */ | |||
| #if FF_API_OLD_AVIO | |||
| attribute_deprecated int is_streamed; | |||
| #endif | |||
| int max_packet_size; | |||
| unsigned long checksum; | |||
| unsigned char *checksum_ptr; | |||
| @@ -124,262 +119,6 @@ typedef struct { | |||
| /* unbuffered I/O */ | |||
| #if FF_API_OLD_AVIO | |||
| /** | |||
| * URL Context. | |||
| * New fields can be added to the end with minor version bumps. | |||
| * Removal, reordering and changes to existing fields require a major | |||
| * version bump. | |||
| * sizeof(URLContext) must not be used outside libav*. | |||
| * @deprecated This struct will be made private | |||
| */ | |||
| typedef struct URLContext { | |||
| const AVClass *av_class; ///< information for av_log(). Set by url_open(). | |||
| struct URLProtocol *prot; | |||
| int flags; | |||
| int is_streamed; /**< true if streamed (no seek possible), default = false */ | |||
| int max_packet_size; /**< if non zero, the stream is packetized with this max packet size */ | |||
| void *priv_data; | |||
| char *filename; /**< specified URL */ | |||
| int is_connected; | |||
| AVIOInterruptCB interrupt_callback; | |||
| } URLContext; | |||
| #define URL_PROTOCOL_FLAG_NESTED_SCHEME 1 /*< The protocol name can be the first part of a nested protocol scheme */ | |||
| #define URL_PROTOCOL_FLAG_NETWORK 2 /*< The protocol uses network */ | |||
| /** | |||
| * @deprecated This struct is to be made private. Use the higher-level | |||
| * AVIOContext-based API instead. | |||
| */ | |||
| typedef struct URLProtocol { | |||
| const char *name; | |||
| int (*url_open)(URLContext *h, const char *url, int flags); | |||
| int (*url_read)(URLContext *h, unsigned char *buf, int size); | |||
| int (*url_write)(URLContext *h, const unsigned char *buf, int size); | |||
| int64_t (*url_seek)(URLContext *h, int64_t pos, int whence); | |||
| int (*url_close)(URLContext *h); | |||
| struct URLProtocol *next; | |||
| int (*url_read_pause)(URLContext *h, int pause); | |||
| int64_t (*url_read_seek)(URLContext *h, int stream_index, | |||
| int64_t timestamp, int flags); | |||
| int (*url_get_file_handle)(URLContext *h); | |||
| int priv_data_size; | |||
| const AVClass *priv_data_class; | |||
| int flags; | |||
| int (*url_check)(URLContext *h, int mask); | |||
| } URLProtocol; | |||
| typedef struct URLPollEntry { | |||
| URLContext *handle; | |||
| int events; | |||
| int revents; | |||
| } URLPollEntry; | |||
| /* not implemented */ | |||
| attribute_deprecated int url_poll(URLPollEntry *poll_table, int n, int timeout); | |||
| /** | |||
| * @name URL open modes | |||
| * The flags argument to url_open and cosins must be one of the following | |||
| * constants, optionally ORed with other flags. | |||
| * @{ | |||
| */ | |||
| #define URL_RDONLY 1 /**< read-only */ | |||
| #define URL_WRONLY 2 /**< write-only */ | |||
| #define URL_RDWR (URL_RDONLY|URL_WRONLY) /**< read-write */ | |||
| /** | |||
| * @} | |||
| */ | |||
| /** | |||
| * Use non-blocking mode. | |||
| * If this flag is set, operations on the context will return | |||
| * AVERROR(EAGAIN) if they can not be performed immediately. | |||
| * If this flag is not set, operations on the context will never return | |||
| * AVERROR(EAGAIN). | |||
| * Note that this flag does not affect the opening/connecting of the | |||
| * context. Connecting a protocol will always block if necessary (e.g. on | |||
| * network protocols) but never hang (e.g. on busy devices). | |||
| * Warning: non-blocking protocols is work-in-progress; this flag may be | |||
| * silently ignored. | |||
| */ | |||
| #define URL_FLAG_NONBLOCK 8 | |||
| typedef int URLInterruptCB(void); | |||
| extern URLInterruptCB *url_interrupt_cb; | |||
| /** | |||
| * @defgroup old_url_funcs Old url_* functions | |||
| * The following functions are deprecated. Use the buffered API based on #AVIOContext instead. | |||
| * @{ | |||
| * @ingroup lavf_io | |||
| */ | |||
| attribute_deprecated int url_open_protocol (URLContext **puc, struct URLProtocol *up, | |||
| const char *url, int flags); | |||
| attribute_deprecated int url_alloc(URLContext **h, const char *url, int flags); | |||
| attribute_deprecated int url_connect(URLContext *h); | |||
| attribute_deprecated int url_open(URLContext **h, const char *url, int flags); | |||
| attribute_deprecated int url_read(URLContext *h, unsigned char *buf, int size); | |||
| attribute_deprecated int url_read_complete(URLContext *h, unsigned char *buf, int size); | |||
| attribute_deprecated int url_write(URLContext *h, const unsigned char *buf, int size); | |||
| attribute_deprecated int64_t url_seek(URLContext *h, int64_t pos, int whence); | |||
| attribute_deprecated int url_close(URLContext *h); | |||
| attribute_deprecated int64_t url_filesize(URLContext *h); | |||
| attribute_deprecated int url_get_file_handle(URLContext *h); | |||
| attribute_deprecated int url_get_max_packet_size(URLContext *h); | |||
| attribute_deprecated void url_get_filename(URLContext *h, char *buf, int buf_size); | |||
| attribute_deprecated int av_url_read_pause(URLContext *h, int pause); | |||
| attribute_deprecated int64_t av_url_read_seek(URLContext *h, int stream_index, | |||
| int64_t timestamp, int flags); | |||
| attribute_deprecated void url_set_interrupt_cb(int (*interrupt_cb)(void)); | |||
| /** | |||
| * If protocol is NULL, returns the first registered protocol, | |||
| * if protocol is non-NULL, returns the next registered protocol after protocol, | |||
| * or NULL if protocol is the last one. | |||
| */ | |||
| attribute_deprecated URLProtocol *av_protocol_next(URLProtocol *p); | |||
| /** | |||
| * Register the URLProtocol protocol. | |||
| * | |||
| * @param size the size of the URLProtocol struct referenced | |||
| */ | |||
| attribute_deprecated int av_register_protocol2(URLProtocol *protocol, int size); | |||
| /** | |||
| * @} | |||
| */ | |||
| typedef attribute_deprecated AVIOContext ByteIOContext; | |||
| attribute_deprecated int init_put_byte(AVIOContext *s, | |||
| unsigned char *buffer, | |||
| int buffer_size, | |||
| int write_flag, | |||
| void *opaque, | |||
| int (*read_packet)(void *opaque, uint8_t *buf, int buf_size), | |||
| int (*write_packet)(void *opaque, uint8_t *buf, int buf_size), | |||
| int64_t (*seek)(void *opaque, int64_t offset, int whence)); | |||
| attribute_deprecated AVIOContext *av_alloc_put_byte( | |||
| unsigned char *buffer, | |||
| int buffer_size, | |||
| int write_flag, | |||
| void *opaque, | |||
| int (*read_packet)(void *opaque, uint8_t *buf, int buf_size), | |||
| int (*write_packet)(void *opaque, uint8_t *buf, int buf_size), | |||
| int64_t (*seek)(void *opaque, int64_t offset, int whence)); | |||
| /** | |||
| * @defgroup old_avio_funcs Old put_/get_*() functions | |||
| * The following functions are deprecated. Use the "avio_"-prefixed functions instead. | |||
| * @{ | |||
| * @ingroup lavf_io | |||
| */ | |||
| attribute_deprecated int get_buffer(AVIOContext *s, unsigned char *buf, int size); | |||
| attribute_deprecated int get_partial_buffer(AVIOContext *s, unsigned char *buf, int size); | |||
| attribute_deprecated int get_byte(AVIOContext *s); | |||
| attribute_deprecated unsigned int get_le16(AVIOContext *s); | |||
| attribute_deprecated unsigned int get_le24(AVIOContext *s); | |||
| attribute_deprecated unsigned int get_le32(AVIOContext *s); | |||
| attribute_deprecated uint64_t get_le64(AVIOContext *s); | |||
| attribute_deprecated unsigned int get_be16(AVIOContext *s); | |||
| attribute_deprecated unsigned int get_be24(AVIOContext *s); | |||
| attribute_deprecated unsigned int get_be32(AVIOContext *s); | |||
| attribute_deprecated uint64_t get_be64(AVIOContext *s); | |||
| attribute_deprecated void put_byte(AVIOContext *s, int b); | |||
| attribute_deprecated void put_nbyte(AVIOContext *s, int b, int count); | |||
| attribute_deprecated void put_buffer(AVIOContext *s, const unsigned char *buf, int size); | |||
| attribute_deprecated void put_le64(AVIOContext *s, uint64_t val); | |||
| attribute_deprecated void put_be64(AVIOContext *s, uint64_t val); | |||
| attribute_deprecated void put_le32(AVIOContext *s, unsigned int val); | |||
| attribute_deprecated void put_be32(AVIOContext *s, unsigned int val); | |||
| attribute_deprecated void put_le24(AVIOContext *s, unsigned int val); | |||
| attribute_deprecated void put_be24(AVIOContext *s, unsigned int val); | |||
| attribute_deprecated void put_le16(AVIOContext *s, unsigned int val); | |||
| attribute_deprecated void put_be16(AVIOContext *s, unsigned int val); | |||
| attribute_deprecated void put_tag(AVIOContext *s, const char *tag); | |||
| /** | |||
| * @} | |||
| */ | |||
| attribute_deprecated int av_url_read_fpause(AVIOContext *h, int pause); | |||
| attribute_deprecated int64_t av_url_read_fseek (AVIOContext *h, int stream_index, | |||
| int64_t timestamp, int flags); | |||
| /** | |||
| * @defgroup old_url_f_funcs Old url_f* functions | |||
| * The following functions are deprecated, use the "avio_"-prefixed functions instead. | |||
| * @{ | |||
| * @ingroup lavf_io | |||
| */ | |||
| attribute_deprecated int url_fopen( AVIOContext **s, const char *url, int flags); | |||
| attribute_deprecated int url_fclose(AVIOContext *s); | |||
| attribute_deprecated int64_t url_fseek(AVIOContext *s, int64_t offset, int whence); | |||
| attribute_deprecated int url_fskip(AVIOContext *s, int64_t offset); | |||
| attribute_deprecated int64_t url_ftell(AVIOContext *s); | |||
| attribute_deprecated int64_t url_fsize(AVIOContext *s); | |||
| #define URL_EOF (-1) | |||
| attribute_deprecated int url_fgetc(AVIOContext *s); | |||
| attribute_deprecated int url_setbufsize(AVIOContext *s, int buf_size); | |||
| attribute_deprecated int url_fprintf(AVIOContext *s, const char *fmt, ...) av_printf_format(2, 3); | |||
| attribute_deprecated void put_flush_packet(AVIOContext *s); | |||
| attribute_deprecated int url_open_dyn_buf(AVIOContext **s); | |||
| attribute_deprecated int url_open_dyn_packet_buf(AVIOContext **s, int max_packet_size); | |||
| attribute_deprecated int url_close_dyn_buf(AVIOContext *s, uint8_t **pbuffer); | |||
| attribute_deprecated int url_fdopen(AVIOContext **s, URLContext *h); | |||
| /** | |||
| * @} | |||
| */ | |||
| /** | |||
| * @deprecated use AVIOContext.eof_reached | |||
| */ | |||
| attribute_deprecated int url_feof(AVIOContext *s); | |||
| attribute_deprecated int url_ferror(AVIOContext *s); | |||
| attribute_deprecated int udp_set_remote_url(URLContext *h, const char *uri); | |||
| attribute_deprecated int udp_get_local_port(URLContext *h); | |||
| attribute_deprecated void init_checksum(AVIOContext *s, | |||
| unsigned long (*update_checksum)(unsigned long c, const uint8_t *p, unsigned int len), | |||
| unsigned long checksum); | |||
| attribute_deprecated unsigned long get_checksum(AVIOContext *s); | |||
| attribute_deprecated void put_strz(AVIOContext *s, const char *buf); | |||
| /** @note unlike fgets, the EOL character is not returned and a whole | |||
| line is parsed. return NULL if first char read was EOF */ | |||
| attribute_deprecated char *url_fgets(AVIOContext *s, char *buf, int buf_size); | |||
| /** | |||
| * @deprecated use avio_get_str instead | |||
| */ | |||
| attribute_deprecated char *get_strz(AVIOContext *s, char *buf, int maxlen); | |||
| /** | |||
| * @deprecated Use AVIOContext.seekable field directly. | |||
| */ | |||
| attribute_deprecated static inline int url_is_streamed(AVIOContext *s) | |||
| { | |||
| return !s->seekable; | |||
| } | |||
| attribute_deprecated URLContext *url_fileno(AVIOContext *s); | |||
| /** | |||
| * @deprecated use AVIOContext.max_packet_size directly. | |||
| */ | |||
| attribute_deprecated int url_fget_max_packet_size(AVIOContext *s); | |||
| attribute_deprecated int url_open_buf(AVIOContext **s, uint8_t *buf, int buf_size, int flags); | |||
| /** return the written or read size */ | |||
| attribute_deprecated int url_close_buf(AVIOContext *s); | |||
| /** | |||
| * Return a non-zero value if the resource indicated by url | |||
| * exists, 0 otherwise. | |||
| * @deprecated Use avio_check instead. | |||
| */ | |||
| attribute_deprecated int url_exist(const char *url); | |||
| #endif // FF_API_OLD_AVIO | |||
| /** | |||
| * Return AVIO_FLAG_* access flags corresponding to the access permissions | |||
| * of the resource in url, or a negative value corresponding to an | |||
| @@ -40,7 +40,6 @@ | |||
| */ | |||
| #define SHORT_SEEK_THRESHOLD 4096 | |||
| #if !FF_API_OLD_AVIO | |||
| static void *ffio_url_child_next(void *obj, void *prev) | |||
| { | |||
| AVIOContext *s = obj; | |||
| @@ -64,7 +63,7 @@ const AVClass ffio_url_class = { | |||
| .child_next = ffio_url_child_next, | |||
| .child_class_next = ffio_url_child_class_next, | |||
| }; | |||
| #endif | |||
| static void fill_buffer(AVIOContext *s); | |||
| static int url_resetbuf(AVIOContext *s, int flags); | |||
| @@ -89,9 +88,6 @@ int ffio_init_context(AVIOContext *s, | |||
| s->must_flush = 0; | |||
| s->eof_reached = 0; | |||
| s->error = 0; | |||
| #if FF_API_OLD_AVIO | |||
| s->is_streamed = 0; | |||
| #endif | |||
| s->seekable = AVIO_SEEKABLE_NORMAL; | |||
| s->max_packet_size = 0; | |||
| s->update_checksum= NULL; | |||
| @@ -104,33 +100,6 @@ int ffio_init_context(AVIOContext *s, | |||
| return 0; | |||
| } | |||
| #if FF_API_OLD_AVIO | |||
| int init_put_byte(AVIOContext *s, | |||
| unsigned char *buffer, | |||
| int buffer_size, | |||
| int write_flag, | |||
| void *opaque, | |||
| int (*read_packet)(void *opaque, uint8_t *buf, int buf_size), | |||
| int (*write_packet)(void *opaque, uint8_t *buf, int buf_size), | |||
| int64_t (*seek)(void *opaque, int64_t offset, int whence)) | |||
| { | |||
| return ffio_init_context(s, buffer, buffer_size, write_flag, opaque, | |||
| read_packet, write_packet, seek); | |||
| } | |||
| AVIOContext *av_alloc_put_byte( | |||
| unsigned char *buffer, | |||
| int buffer_size, | |||
| int write_flag, | |||
| void *opaque, | |||
| int (*read_packet)(void *opaque, uint8_t *buf, int buf_size), | |||
| int (*write_packet)(void *opaque, uint8_t *buf, int buf_size), | |||
| int64_t (*seek)(void *opaque, int64_t offset, int whence)) | |||
| { | |||
| return avio_alloc_context(buffer, buffer_size, write_flag, opaque, | |||
| read_packet, write_packet, seek); | |||
| } | |||
| #endif | |||
| AVIOContext *avio_alloc_context( | |||
| unsigned char *buffer, | |||
| int buffer_size, | |||
| @@ -265,19 +234,6 @@ int64_t avio_seek(AVIOContext *s, int64_t offset, int whence) | |||
| return offset; | |||
| } | |||
| #if FF_API_OLD_AVIO | |||
| int url_fskip(AVIOContext *s, int64_t offset) | |||
| { | |||
| int64_t ret = avio_seek(s, offset, SEEK_CUR); | |||
| return ret < 0 ? ret : 0; | |||
| } | |||
| int64_t url_ftell(AVIOContext *s) | |||
| { | |||
| return avio_seek(s, 0, SEEK_CUR); | |||
| } | |||
| #endif | |||
| int64_t avio_size(AVIOContext *s) | |||
| { | |||
| int64_t size; | |||
| @@ -297,22 +253,6 @@ int64_t avio_size(AVIOContext *s) | |||
| return size; | |||
| } | |||
| #if FF_API_OLD_AVIO | |||
| int url_feof(AVIOContext *s) | |||
| { | |||
| if(!s) | |||
| return 0; | |||
| return s->eof_reached; | |||
| } | |||
| int url_ferror(AVIOContext *s) | |||
| { | |||
| if(!s) | |||
| return 0; | |||
| return s->error; | |||
| } | |||
| #endif | |||
| void avio_wl32(AVIOContext *s, unsigned int val) | |||
| { | |||
| avio_w8(s, val); | |||
| @@ -329,143 +269,6 @@ void avio_wb32(AVIOContext *s, unsigned int val) | |||
| avio_w8(s, val); | |||
| } | |||
| #if FF_API_OLD_AVIO | |||
| void put_strz(AVIOContext *s, const char *str) | |||
| { | |||
| avio_put_str(s, str); | |||
| } | |||
| #define GET(name, type) \ | |||
| type get_be ##name(AVIOContext *s) \ | |||
| {\ | |||
| return avio_rb ##name(s);\ | |||
| }\ | |||
| type get_le ##name(AVIOContext *s) \ | |||
| {\ | |||
| return avio_rl ##name(s);\ | |||
| } | |||
| GET(16, unsigned int) | |||
| GET(24, unsigned int) | |||
| GET(32, unsigned int) | |||
| GET(64, uint64_t) | |||
| #undef GET | |||
| #define PUT(name, type ) \ | |||
| void put_le ##name(AVIOContext *s, type val)\ | |||
| {\ | |||
| avio_wl ##name(s, val);\ | |||
| }\ | |||
| void put_be ##name(AVIOContext *s, type val)\ | |||
| {\ | |||
| avio_wb ##name(s, val);\ | |||
| } | |||
| PUT(16, unsigned int) | |||
| PUT(24, unsigned int) | |||
| PUT(32, unsigned int) | |||
| PUT(64, uint64_t) | |||
| #undef PUT | |||
| int get_byte(AVIOContext *s) | |||
| { | |||
| return avio_r8(s); | |||
| } | |||
| int get_buffer(AVIOContext *s, unsigned char *buf, int size) | |||
| { | |||
| return avio_read(s, buf, size); | |||
| } | |||
| int get_partial_buffer(AVIOContext *s, unsigned char *buf, int size) | |||
| { | |||
| return ffio_read_partial(s, buf, size); | |||
| } | |||
| void put_byte(AVIOContext *s, int val) | |||
| { | |||
| avio_w8(s, val); | |||
| } | |||
| void put_buffer(AVIOContext *s, const unsigned char *buf, int size) | |||
| { | |||
| avio_write(s, buf, size); | |||
| } | |||
| void put_nbyte(AVIOContext *s, int b, int count) | |||
| { | |||
| ffio_fill(s, b, count); | |||
| } | |||
| int url_fopen(AVIOContext **s, const char *filename, int flags) | |||
| { | |||
| return avio_open(s, filename, flags); | |||
| } | |||
| int url_fclose(AVIOContext *s) | |||
| { | |||
| return avio_close(s); | |||
| } | |||
| int64_t url_fseek(AVIOContext *s, int64_t offset, int whence) | |||
| { | |||
| return avio_seek(s, offset, whence); | |||
| } | |||
| int64_t url_fsize(AVIOContext *s) | |||
| { | |||
| return avio_size(s); | |||
| } | |||
| int url_setbufsize(AVIOContext *s, int buf_size) | |||
| { | |||
| return ffio_set_buf_size(s, buf_size); | |||
| } | |||
| int url_fprintf(AVIOContext *s, const char *fmt, ...) | |||
| { | |||
| va_list ap; | |||
| char buf[4096]; | |||
| int ret; | |||
| va_start(ap, fmt); | |||
| ret = vsnprintf(buf, sizeof(buf), fmt, ap); | |||
| va_end(ap); | |||
| avio_write(s, buf, strlen(buf)); | |||
| return ret; | |||
| } | |||
| void put_flush_packet(AVIOContext *s) | |||
| { | |||
| avio_flush(s); | |||
| } | |||
| int av_url_read_fpause(AVIOContext *s, int pause) | |||
| { | |||
| return avio_pause(s, pause); | |||
| } | |||
| int64_t av_url_read_fseek(AVIOContext *s, int stream_index, | |||
| int64_t timestamp, int flags) | |||
| { | |||
| return avio_seek_time(s, stream_index, timestamp, flags); | |||
| } | |||
| void init_checksum(AVIOContext *s, | |||
| unsigned long (*update_checksum)(unsigned long c, const uint8_t *p, unsigned int len), | |||
| unsigned long checksum) | |||
| { | |||
| ffio_init_checksum(s, update_checksum, checksum); | |||
| } | |||
| unsigned long get_checksum(AVIOContext *s) | |||
| { | |||
| return ffio_get_checksum(s); | |||
| } | |||
| int url_open_dyn_buf(AVIOContext **s) | |||
| { | |||
| return avio_open_dyn_buf(s); | |||
| } | |||
| int url_open_dyn_packet_buf(AVIOContext **s, int max_packet_size) | |||
| { | |||
| return ffio_open_dyn_packet_buf(s, max_packet_size); | |||
| } | |||
| int url_close_dyn_buf(AVIOContext *s, uint8_t **pbuffer) | |||
| { | |||
| return avio_close_dyn_buf(s, pbuffer); | |||
| } | |||
| int url_fdopen(AVIOContext **s, URLContext *h) | |||
| { | |||
| return ffio_fdopen(s, h); | |||
| } | |||
| #endif | |||
| int avio_put_str(AVIOContext *s, const char *str) | |||
| { | |||
| int len = 1; | |||
| @@ -548,15 +351,6 @@ void avio_wb24(AVIOContext *s, unsigned int val) | |||
| avio_w8(s, val); | |||
| } | |||
| #if FF_API_OLD_AVIO | |||
| void put_tag(AVIOContext *s, const char *tag) | |||
| { | |||
| while (*tag) { | |||
| avio_w8(s, *tag++); | |||
| } | |||
| } | |||
| #endif | |||
| /* Input stream */ | |||
| static void fill_buffer(AVIOContext *s) | |||
| @@ -638,17 +432,6 @@ int avio_r8(AVIOContext *s) | |||
| return 0; | |||
| } | |||
| #if FF_API_OLD_AVIO | |||
| int url_fgetc(AVIOContext *s) | |||
| { | |||
| if (s->buf_ptr >= s->buf_end) | |||
| fill_buffer(s); | |||
| if (s->buf_ptr < s->buf_end) | |||
| return *s->buf_ptr++; | |||
| return URL_EOF; | |||
| } | |||
| #endif | |||
| int avio_read(AVIOContext *s, unsigned char *buf, int size) | |||
| { | |||
| int len, size1; | |||
| @@ -774,14 +557,6 @@ unsigned int avio_rb32(AVIOContext *s) | |||
| return val; | |||
| } | |||
| #if FF_API_OLD_AVIO | |||
| char *get_strz(AVIOContext *s, char *buf, int maxlen) | |||
| { | |||
| avio_get_str(s, INT_MAX, buf, maxlen); | |||
| return buf; | |||
| } | |||
| #endif | |||
| int ff_get_line(AVIOContext *s, char *buf, int maxlen) | |||
| { | |||
| int i = 0; | |||
| @@ -879,18 +654,13 @@ int ffio_fdopen(AVIOContext **s, URLContext *h) | |||
| av_free(buffer); | |||
| return AVERROR(ENOMEM); | |||
| } | |||
| #if FF_API_OLD_AVIO | |||
| (*s)->is_streamed = h->is_streamed; | |||
| #endif | |||
| (*s)->seekable = h->is_streamed ? 0 : AVIO_SEEKABLE_NORMAL; | |||
| (*s)->max_packet_size = max_packet_size; | |||
| if(h->prot) { | |||
| (*s)->read_pause = (int (*)(void *, int))h->prot->url_read_pause; | |||
| (*s)->read_seek = (int64_t (*)(void *, int, int64_t, int))h->prot->url_read_seek; | |||
| } | |||
| #if !FF_API_OLD_AVIO | |||
| (*s)->av_class = &ffio_url_class; | |||
| #endif | |||
| return 0; | |||
| } | |||
| @@ -993,13 +763,6 @@ int avio_close(AVIOContext *s) | |||
| return ffurl_close(h); | |||
| } | |||
| #if FF_API_OLD_AVIO | |||
| URLContext *url_fileno(AVIOContext *s) | |||
| { | |||
| return s->opaque; | |||
| } | |||
| #endif | |||
| int avio_printf(AVIOContext *s, const char *fmt, ...) | |||
| { | |||
| va_list ap; | |||
| @@ -1013,34 +776,6 @@ int avio_printf(AVIOContext *s, const char *fmt, ...) | |||
| return ret; | |||
| } | |||
| #if FF_API_OLD_AVIO | |||
| char *url_fgets(AVIOContext *s, char *buf, int buf_size) | |||
| { | |||
| int c; | |||
| char *q; | |||
| c = avio_r8(s); | |||
| if (s->eof_reached) | |||
| return NULL; | |||
| q = buf; | |||
| for(;;) { | |||
| if (s->eof_reached || c == '\n') | |||
| break; | |||
| if ((q - buf) < buf_size - 1) | |||
| *q++ = c; | |||
| c = avio_r8(s); | |||
| } | |||
| if (buf_size > 0) | |||
| *q = '\0'; | |||
| return buf; | |||
| } | |||
| int url_fget_max_packet_size(AVIOContext *s) | |||
| { | |||
| return s->max_packet_size; | |||
| } | |||
| #endif | |||
| int avio_pause(AVIOContext *s, int pause) | |||
| { | |||
| if (!s->read_pause) | |||
| @@ -1068,29 +803,6 @@ int64_t avio_seek_time(AVIOContext *s, int stream_index, | |||
| return ret; | |||
| } | |||
| /* buffer handling */ | |||
| #if FF_API_OLD_AVIO | |||
| int url_open_buf(AVIOContext **s, uint8_t *buf, int buf_size, int flags) | |||
| { | |||
| int ret; | |||
| *s = av_mallocz(sizeof(AVIOContext)); | |||
| if(!*s) | |||
| return AVERROR(ENOMEM); | |||
| ret = ffio_init_context(*s, buf, buf_size, | |||
| flags & AVIO_FLAG_WRITE, | |||
| NULL, NULL, NULL, NULL); | |||
| if(ret != 0) | |||
| av_freep(s); | |||
| return ret; | |||
| } | |||
| int url_close_buf(AVIOContext *s) | |||
| { | |||
| avio_flush(s); | |||
| return s->buf_ptr - s->buffer; | |||
| } | |||
| #endif | |||
| /* output in a dynamic buffer */ | |||
| typedef struct DynBuffer { | |||
| @@ -41,10 +41,8 @@ static void *format_child_next(void *obj, void *prev) | |||
| ((s->iformat && s->iformat->priv_class) || | |||
| s->oformat && s->oformat->priv_class)) | |||
| return s->priv_data; | |||
| #if !FF_API_OLD_AVIO | |||
| if (s->pb && s->pb->av_class && prev != s->pb) | |||
| return s->pb; | |||
| #endif | |||
| return NULL; | |||
| } | |||
| @@ -54,11 +52,7 @@ static const AVClass *format_child_class_next(const AVClass *prev) | |||
| AVOutputFormat *ofmt = NULL; | |||
| if (!prev) | |||
| #if !FF_API_OLD_AVIO | |||
| return &ffio_url_class; | |||
| #else | |||
| prev = (void *)&ifmt; // Dummy pointer; | |||
| #endif | |||
| while ((ifmt = av_iformat_next(ifmt))) | |||
| if (ifmt->priv_class == prev) | |||
| @@ -31,7 +31,6 @@ | |||
| #include "libavutil/dict.h" | |||
| #include "libavutil/log.h" | |||
| #if !FF_API_OLD_AVIO | |||
| #define URL_PROTOCOL_FLAG_NESTED_SCHEME 1 /*< The protocol name can be the first part of a nested protocol scheme */ | |||
| #define URL_PROTOCOL_FLAG_NETWORK 2 /*< The protocol uses network */ | |||
| @@ -74,7 +73,6 @@ typedef struct URLProtocol { | |||
| int flags; | |||
| int (*url_check)(URLContext *h, int mask); | |||
| } URLProtocol; | |||
| #endif | |||
| /** | |||
| * Create a URLContext for accessing to the resource indicated by | |||
| @@ -50,9 +50,6 @@ | |||
| #ifndef FF_API_OLD_METADATA2 | |||
| #define FF_API_OLD_METADATA2 (LIBAVFORMAT_VERSION_MAJOR < 54) | |||
| #endif | |||
| #ifndef FF_API_OLD_AVIO | |||
| #define FF_API_OLD_AVIO (LIBAVFORMAT_VERSION_MAJOR < 54) | |||
| #endif | |||
| #ifndef FF_API_DUMP_FORMAT | |||
| #define FF_API_DUMP_FORMAT (LIBAVFORMAT_VERSION_MAJOR < 54) | |||
| #endif | |||