Go to the documentation of this file.
30 #define AV_CAT_SEPARATOR "|"
50 for (
i = 0;
i !=
data->length;
i++)
55 return err < 0 ? -1 : 0;
60 char *node_uri =
NULL;
73 for (
i = 0,
len = 1; uri[
i];
i++) {
76 if (++
len == UINT_MAX /
sizeof(*nodes)) {
91 for (
i = 0; *uri;
i++) {
101 &
h->interrupt_callback,
NULL,
h->protocol_whitelist,
h->protocol_blacklist,
h);
121 else if (!(nodes =
av_realloc(nodes,
data->length *
sizeof(*nodes)))) {
134 size_t i =
data->current;
139 if (
i + 1 ==
data->length ||
145 return total ? total :
result;
151 return total ? total :
result;
163 for (
i =
data->length - 1;
i && pos < -nodes[
i].
size;
i--)
164 pos += nodes[
i].
size;
168 for (
i = 0;
i !=
data->current;
i++)
169 pos += nodes[
i].
size;
174 for (
i = 0;
i !=
data->length - 1 && pos >= nodes[
i].
size;
i++)
175 pos -= nodes[
i].
size;
197 .default_whitelist =
"concat,file,subfile",
size_t length
number of cat'ed nodes
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
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.
#define AVERROR_EOF
End of file.
int ffurl_close(URLContext *h)
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
int ffurl_open_whitelist(URLContext **puc, const char *filename, int flags, const AVIOInterruptCB *int_cb, AVDictionary **options, const char *whitelist, const char *blacklist, URLContext *parent)
Create an URLContext for accessing to the resource indicated by url, and open it.
and forward the result(frame or status change) to the corresponding input. If nothing is possible
struct concat_nodes * nodes
list of nodes to concat
int av_reallocp(void *ptr, size_t size)
Allocate, reallocate, or free a block of memory through a pointer to a pointer.
static int concat_read(URLContext *h, unsigned char *buf, int size)
int av_strstart(const char *str, const char *pfx, const char **ptr)
Return non-zero if pfx is a prefix of str.
void * av_realloc(void *ptr, size_t size)
Allocate, reallocate, or free a block of memory.
#define i(width, name, range_min, range_max)
static av_cold int concat_open(URLContext *h, const char *uri, int flags)
size_t current
index of currently read node
static int64_t concat_seek(URLContext *h, int64_t pos, int whence)
URLContext * uc
node's URLContext
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.
#define flags(name, subs,...)
size_t av_strlcpy(char *dst, const char *src, size_t size)
Copy the string src to dst, but no more than size - 1 bytes, and null-terminate dst.
int64_t ffurl_size(URLContext *h)
Return the filesize of the resource accessed by h, AVERROR(ENOSYS) if the operation is not supported ...
const URLProtocol ff_concat_protocol
static av_cold int concat_close(URLContext *h)