#include <unistd.h>
#include "libavutil/avstring.h"
#include "libavutil/opt.h"
#include "os_support.h"
#include "avformat.h"
#include "url.h"
Go to the source code of this file.
Defines | |
#define | URL_SCHEME_CHARS |
Functions | |
static int | default_interrupt_cb (void) |
URLProtocol * | av_protocol_next (URLProtocol *p) |
returns the next registered protocol after the given protocol (the first if NULL is given), or NULL if protocol is the last one. | |
const char * | avio_enum_protocols (void **opaque, int output) |
Iterate through names of available protocols. | |
int | ffurl_register_protocol (URLProtocol *protocol, int size) |
Register the URLProtocol protocol. | |
static int | url_alloc_for_protocol (URLContext **puc, struct URLProtocol *up, const char *filename, int flags) |
int | ffurl_connect (URLContext *uc) |
Connect an URLContext that has been allocated by ffurl_alloc. | |
int | url_open_protocol (URLContext **puc, struct URLProtocol *up, const char *filename, int flags) |
int | url_alloc (URLContext **puc, const char *filename, int flags) |
int | url_connect (URLContext *uc) |
int | url_open (URLContext **puc, const char *filename, int flags) |
int | url_read (URLContext *h, unsigned char *buf, int size) |
int | url_read_complete (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) |
int64_t | url_filesize (URLContext *h) |
int | url_get_file_handle (URLContext *h) |
int | url_get_max_packet_size (URLContext *h) |
void | url_get_filename (URLContext *h, char *buf, int buf_size) |
void | url_set_interrupt_cb (URLInterruptCB *interrupt_cb) |
int | av_register_protocol2 (URLProtocol *protocol, int size) |
Register the URLProtocol protocol. | |
int | ffurl_alloc (URLContext **puc, const char *filename, int flags) |
Create a URLContext for accessing to the resource indicated by url, but do not initiate the connection yet. | |
int | ffurl_open (URLContext **puc, const char *filename, int flags) |
Create an URLContext for accessing to the resource indicated by url, and open it. | |
static int | retry_transfer_wrapper (URLContext *h, unsigned char *buf, int size, int size_min, int(*transfer_func)(URLContext *h, unsigned char *buf, int size)) |
int | ffurl_read (URLContext *h, unsigned char *buf, int size) |
Read up to size bytes from the resource accessed by h, and store the read bytes in buf. | |
int | ffurl_read_complete (URLContext *h, unsigned char *buf, int size) |
Read as many bytes as possible (up to size), calling the read function multiple times if necessary. | |
int | ffurl_write (URLContext *h, const unsigned char *buf, int size) |
Write size bytes from buf to the resource accessed by h. | |
int64_t | ffurl_seek (URLContext *h, int64_t pos, int whence) |
Change the position that will be used by the next read/write operation on the resource accessed by h. | |
int | ffurl_close (URLContext *h) |
Close the resource accessed by the URLContext h, and free the memory used by it. | |
int | url_exist (const char *filename) |
Return a non-zero value if the resource indicated by url exists, 0 otherwise. | |
int | avio_check (const char *url, int flags) |
Return AVIO_FLAG_* access flags corresponding to the access permissions of the resource in url, or a negative value corresponding to an AVERROR code in case of failure. | |
int64_t | ffurl_size (URLContext *h) |
Return the filesize of the resource accessed by h, AVERROR(ENOSYS) if the operation is not supported by h, or another negative value corresponding to an AVERROR error code in case of failure. | |
int | ffurl_get_file_handle (URLContext *h) |
Return the file descriptor associated with this URL. | |
void | avio_set_interrupt_cb (int(*interrupt_cb)(void)) |
The callback is called in blocking functions to test regulary if asynchronous interruption is needed. | |
int | av_url_read_pause (URLContext *h, int pause) |
int64_t | av_url_read_seek (URLContext *h, int stream_index, int64_t timestamp, int flags) |
Variables | |
URLProtocol * | first_protocol = NULL |
int(* | url_interrupt_cb )(void) = default_interrupt_cb |
Logging context. | |
static const AVOption | options [] = {{NULL}} |
static const AVClass | urlcontext_class |
static const char * | urlcontext_to_name (void *ptr) |
#define URL_SCHEME_CHARS |
Value:
"abcdefghijklmnopqrstuvwxyz" \ "ABCDEFGHIJKLMNOPQRSTUVWXYZ" \ "0123456789+-."
Definition at line 215 of file avio.c.
Referenced by ffurl_alloc().
int avio_check | ( | const char * | url, | |
int | flags | |||
) |
Return AVIO_FLAG_* access flags corresponding to the access permissions of the resource in url, or a negative value corresponding to an AVERROR code in case of failure.
The returned access flags are masked by the value in flags.
Definition at line 353 of file avio.c.
Referenced by build_feed_streams(), find_image_range(), and opt_output_file().
const char* avio_enum_protocols | ( | void ** | opaque, | |
int | output | |||
) |
Iterate through names of available protocols.
opaque | A private pointer representing current protocol. It must be a pointer to NULL on first iteration and will be updated by successive calls to avio_enum_protocols. | |
output | If set to 1, iterate over output protocols, otherwise over input protocols. |
Definition at line 61 of file avio.c.
Referenced by avio_enum_protocols().
void avio_set_interrupt_cb | ( | int(*)(void) | interrupt_cb | ) |
The callback is called in blocking functions to test regulary if asynchronous interruption is needed.
AVERROR_EXIT is returned in this case by the interrupted function. 'NULL' means no interrupt callback is given.
Definition at line 399 of file avio.c.
Referenced by main(), read_thread(), transcode(), and url_set_interrupt_cb().
static int default_interrupt_cb | ( | void | ) | [static] |
int ffurl_alloc | ( | URLContext ** | h, | |
const char * | url, | |||
int | flags | |||
) |
Create a URLContext for accessing to the resource indicated by url, but do not initiate the connection yet.
puc | pointer to the location where, in case of success, the function puts the pointer to the created URLContext | |
flags | flags which control how the resource indicated by url is to be opened |
Definition at line 220 of file avio.c.
Referenced by avio_check(), ffurl_open(), mmsh_open(), open_input(), and url_alloc().
int ffurl_close | ( | URLContext * | h | ) |
Close the resource accessed by the URLContext h, and free the memory used by it.
Definition at line 326 of file avio.c.
Referenced by applehttp_close(), applehttp_read(), applehttp_read_seek(), avio_check(), avio_close(), avio_open(), concat_close(), concat_open(), crypto_close(), ff_rtsp_undo_setup(), ffurl_open(), free_variant_list(), gopher_close(), http_close(), http_open_cnx(), http_seek(), md5_close(), mms_close(), mmsh_close(), mmsh_open(), open_input(), read_data(), recheck_discard_flags(), rtmp_close(), rtp_close(), rtp_open(), sap_read_close(), sap_write_close(), url_close(), url_exist(), and url_open_protocol().
int ffurl_connect | ( | URLContext * | uc | ) |
Connect an URLContext that has been allocated by ffurl_alloc.
Definition at line 126 of file avio.c.
Referenced by avio_check(), ffurl_open(), mmsh_open(), open_input(), url_connect(), and url_open_protocol().
int ffurl_get_file_handle | ( | URLContext * | h | ) |
Return the file descriptor associated with this URL.
For RTP, this will return only the RTP file descriptor, not the RTCP file descriptor.
Definition at line 387 of file avio.c.
Referenced by http_get_file_handle(), rtp_open(), rtsp_write_packet(), sap_fetch_packet(), sap_write_header(), and url_get_file_handle().
int ffurl_open | ( | URLContext ** | h, | |
const char * | url, | |||
int | flags | |||
) |
Create an URLContext for accessing to the resource indicated by url, and open it.
puc | pointer to the location where, in case of success, the function puts the pointer to the created URLContext | |
flags | flags which control how the resource indicated by url is to be opened |
Definition at line 248 of file avio.c.
Referenced by applehttp_read(), avio_open(), concat_open(), crypto_open(), gopher_open(), http_open_cnx(), md5_close(), mms_open(), open_input(), rtmp_open(), rtp_open(), sap_read_header(), sap_write_header(), url_exist(), and url_open().
int ffurl_read | ( | URLContext * | h, | |
unsigned char * | buf, | |||
int | size | |||
) |
Read up to size bytes from the resource accessed by h, and store the read bytes in buf.
Definition at line 291 of file avio.c.
Referenced by applehttp_read(), concat_read(), crypto_read(), ff_rtmp_packet_read(), ffio_fdopen(), gopher_read(), http_getc(), http_read(), read_data(), sap_fetch_packet(), sap_read_header(), and url_read().
int ffurl_read_complete | ( | URLContext * | h, | |
unsigned char * | buf, | |||
int | size | |||
) |
Read as many bytes as possible (up to size), calling the read function multiple times if necessary.
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.
Definition at line 298 of file avio.c.
Referenced by ff_rtmp_packet_read(), ff_rtsp_tcp_read_packet(), get_chunk_header(), get_http_header_data(), get_tcp_server_response(), open_input(), read_data_packet(), rtmp_handshake(), and url_read_complete().
int ffurl_register_protocol | ( | URLProtocol * | protocol, | |
int | size | |||
) |
Register the URLProtocol protocol.
size | the size of the URLProtocol struct referenced |
Definition at line 71 of file avio.c.
Referenced by av_register_protocol2().
int64_t ffurl_seek | ( | URLContext * | h, | |
int64_t | pos, | |||
int | whence | |||
) |
Change the position that will be used by the next read/write operation on the resource accessed by h.
pos | specifies the new position to set | |
whence | specifies how pos should be interpreted, it must be one of SEEK_SET (seek from the beginning), SEEK_CUR (seek from the current position), SEEK_END (seek from the end), or AVSEEK_SIZE (return the filesize of the requested resource, pos is ignored). |
Definition at line 316 of file avio.c.
Referenced by concat_read(), concat_seek(), ffio_fdopen(), ffurl_connect(), ffurl_size(), and url_seek().
int64_t ffurl_size | ( | URLContext * | h | ) |
Return the filesize of the resource accessed by h, AVERROR(ENOSYS) if the operation is not supported by h, or another negative value corresponding to an AVERROR error code in case of failure.
Definition at line 372 of file avio.c.
Referenced by concat_open(), and url_filesize().
int ffurl_write | ( | URLContext * | h, | |
const unsigned char * | buf, | |||
int | size | |||
) |
Write size bytes from buf to the resource accessed by h.
Definition at line 305 of file avio.c.
Referenced by ff_rtmp_packet_write(), ffio_fdopen(), gopher_write(), http_close(), http_connect(), http_write(), md5_close(), rtmp_handshake(), rtp_check_and_send_back_rr(), rtp_send_punch_packets(), rtp_write(), sap_write_close(), sap_write_packet(), send_command_packet(), tcp_write_packet(), and url_write().
static int retry_transfer_wrapper | ( | URLContext * | h, | |
unsigned char * | buf, | |||
int | size, | |||
int | size_min, | |||
int(*)(URLContext *h, unsigned char *buf, int size) | transfer_func | |||
) | [inline, static] |
Definition at line 261 of file avio.c.
Referenced by ffurl_read(), ffurl_read_complete(), and ffurl_write().
static int url_alloc_for_protocol | ( | URLContext ** | puc, | |
struct URLProtocol * | up, | |||
const char * | filename, | |||
int | flags | |||
) | [static] |
int url_exist | ( | const char * | url | ) |
Return a non-zero value if the resource indicated by url exists, 0 otherwise.
void url_set_interrupt_cb | ( | URLInterruptCB * | interrupt_cb | ) |
int(* url_interrupt_cb)(void) = default_interrupt_cb |
const AVClass urlcontext_class [static] |
Initial value:
{ .class_name = "URLContext", .item_name = urlcontext_to_name, .option = options, .version = LIBAVUTIL_VERSION_INT, }