avio_alloc_context

Allocate and initialize an AVIOContext for buffered I/O. It must be later freed with avio_context_free().

@param buffer Memory block for input/output operations via AVIOContext. The buffer must be allocated with av_malloc() and friends. It may be freed and replaced with a new buffer by libavformat. AVIOContext.buffer holds the buffer currently in use, which must be later freed with av_free(). @param buffer_size The buffer size is very important for performance. For protocols with fixed blocksize it should be set to this blocksize. For others a typical size is a cache page, e.g. 4kb. @param write_flag Set to 1 if the buffer should be writable, 0 otherwise. @param opaque An opaque pointer to user-specific data. @param read_packet A function for refilling the buffer, may be NULL. For stream protocols, must never return 0 but rather a proper AVERROR code. @param write_packet A function for writing the buffer contents, may be NULL. The function may not change the input buffers content. @param seek A function for seeking to specified byte position, may be NULL.

@return Allocated AVIOContext or NULL on failure.

extern (C) @nogc nothrow
avio_alloc_context
(
ubyte* buffer
,,,
void* opaque
,
int function
(
void* opaque
,
ubyte* buf
,)
read_packet
,
int function
(
void* opaque
,
ubyte* buf
,)
write_packet
,
long function
(
void* opaque
,
long offset
,
int whence
)
seek
)

Meta