| Top |  |  |  |  | 
| GstBufferList * | gst_buffer_list_new () | 
| GstBufferList * | gst_buffer_list_new_sized () | 
| guint | gst_buffer_list_length () | 
| #define | gst_buffer_list_add() | 
| void | gst_buffer_list_insert () | 
| void | gst_buffer_list_remove () | 
| GstBufferList * | gst_buffer_list_ref () | 
| void | gst_buffer_list_unref () | 
| void | gst_clear_buffer_list () | 
| GstBufferList * | gst_buffer_list_copy () | 
| GstBufferList * | gst_buffer_list_copy_deep () | 
| #define | gst_buffer_list_is_writable() | 
| #define | gst_buffer_list_make_writable() | 
| gboolean | gst_buffer_list_replace () | 
| gboolean | gst_buffer_list_take () | 
| gboolean | (*GstBufferListFunc) () | 
| gboolean | gst_buffer_list_foreach () | 
| GstBuffer * | gst_buffer_list_get () | 
| GstBuffer * | gst_buffer_list_get_writable () | 
| gsize | gst_buffer_list_calculate_size () | 
Buffer lists are an object containing a list of buffers.
Buffer lists are created with gst_buffer_list_new() and filled with data
using a gst_buffer_list_insert().
Buffer lists can be pushed on a srcpad with gst_pad_push_list(). This is
interesting when multiple buffers need to be pushed in one go because it
can reduce the amount of overhead for pushing each buffer individually.
GstBufferList *
gst_buffer_list_new (void);
Creates a new, empty GstBufferList. The caller is responsible for unreffing the returned GstBufferList.
Free-function: gst_buffer_list_unref
GstBufferList *
gst_buffer_list_new_sized (guint size);
Creates a new, empty GstBufferList. The caller is responsible for unreffing
the returned GstBufferList. The list will have size
 space preallocated so
that memory reallocations can be avoided.
Free-function: gst_buffer_list_unref
guint
gst_buffer_list_length (GstBufferList *list);
Returns the number of buffers in list
.
#define gst_buffer_list_add(l,b) gst_buffer_list_insert((l),-1,(b));
Append b
 at the end of l
.
void gst_buffer_list_insert (GstBufferList *list,gint idx,GstBuffer *buffer);
Insert buffer
 at idx
 in list
. Other buffers are moved to make room for
this new buffer.
A -1 value for idx
 will append the buffer at the end.
void gst_buffer_list_remove (GstBufferList *list,guint idx,guint length);
Remove length
 buffers starting from idx
 in list
. The following buffers
are moved to close the gap.
GstBufferList *
gst_buffer_list_ref (GstBufferList *list);
Increases the refcount of the given buffer list by one.
Note that the refcount affects the writability of list
 and its data, see
gst_buffer_list_make_writable(). It is important to note that keeping
additional references to GstBufferList instances can potentially increase
the number of memcpy operations in a pipeline.
void
gst_buffer_list_unref (GstBufferList *list);
Decreases the refcount of the buffer list. If the refcount reaches 0, the buffer list will be freed.
void
gst_clear_buffer_list (GstBufferList **list_ptr);
Clears a reference to a GstBufferList.
list_ptr
 must not be NULL.
If the reference is NULL then this function does nothing. Otherwise, the
reference count of the list is decreased and the pointer is set to NULL.
[skip]
Since: 1.16
GstBufferList *
gst_buffer_list_copy (const GstBufferList *list);
Create a shallow copy of the given buffer list. This will make a newly allocated copy of the source list with copies of buffer pointers. The refcount of buffers pointed to will be increased by one.
GstBufferList *
gst_buffer_list_copy_deep (const GstBufferList *list);
Create a copy of the given buffer list. This will make a newly allocated copy of the buffer that the source buffer list contains.
Since: 1.6
#define gst_buffer_list_is_writable(list) gst_mini_object_is_writable (GST_MINI_OBJECT_CAST (list))
Tests if you can safely add buffers and groups into a buffer list.
#define gst_buffer_list_make_writable(list) GST_BUFFER_LIST_CAST (gst_mini_object_make_writable (GST_MINI_OBJECT_CAST (list)))
Makes a writable buffer list from the given buffer list. If the source buffer
list is already writable, this will simply return the same buffer list. A
copy will otherwise be made using gst_buffer_list_copy().
gboolean gst_buffer_list_replace (GstBufferList **old_list,GstBufferList *new_list);
Modifies a pointer to a GstBufferList to point to a different GstBufferList. The modification is done atomically (so this is useful for ensuring thread safety in some cases), and the reference counts are updated appropriately (the old buffer list is unreffed, the new is reffed).
Either new_list
 or the GstBufferList pointed to by old_list
 may be NULL.
| old_list | pointer to a pointer to a GstBufferList to be replaced. | [inout][transfer full][nullable] | 
| new_list | pointer to a GstBufferList that
will replace the buffer list pointed to by  | [transfer none][allow-none] | 
Since: 1.16
gboolean gst_buffer_list_take (GstBufferList **old_list,GstBufferList *new_list);
Modifies a pointer to a GstBufferList to point to a different
GstBufferList. This function is similar to gst_buffer_list_replace() except
that it takes ownership of new_list
.
| old_list | pointer to a pointer to a GstBufferList to be replaced. | [inout][transfer full] | 
| new_list | pointer to a GstBufferList
that will replace the bufferlist pointed to by  | [transfer full][allow-none] | 
Since: 1.16
gboolean (*GstBufferListFunc) (GstBuffer **buffer,guint idx,gpointer user_data);
A function that will be called from gst_buffer_list_foreach(). The buffer
field will point to a the reference of the buffer at idx
.
When this function returns TRUE, the next buffer will be
returned. When FALSE is returned, gst_buffer_list_foreach() will return.
When buffer
 is set to NULL, the item will be removed from the bufferlist.
When buffer
 has been made writable, the new buffer reference can be assigned
to buffer
. This function is responsible for unreffing the old buffer when
removing or modifying.
| buffer | pointer the buffer. | [out][nullable] | 
| idx | the index of  | |
| user_data | user data passed to  | 
gboolean gst_buffer_list_foreach (GstBufferList *list,GstBufferListFunc func,gpointer user_data);
Call func
 with data
 for each buffer in list
.
func
 can modify the passed buffer pointer or its contents. The return value
of func
 define if this function returns or if the remaining buffers in
the list should be skipped.
| list | ||
| func | a GstBufferListFunc to call. | [scope call] | 
| user_data | user data passed to  | [closure] | 
GstBuffer * gst_buffer_list_get (GstBufferList *list,guint idx);
Get the buffer at idx
.
You must make sure that idx
 does not exceed the number of
buffers available.
GstBuffer * gst_buffer_list_get_writable (GstBufferList *list,guint idx);
Gets the buffer at idx
, ensuring it is a writable buffer.
You must make sure that idx
 does not exceed the number of
buffers available.
the buffer at idx
in group
.
The returned  buffer remains valid as long as list
is valid and
the buffer is not removed from the list. 
[transfer none][nullable]
Since: 1.14
gsize
gst_buffer_list_calculate_size (GstBufferList *list);
Calculates the size of the data contained in buffer list by adding the size of all buffers.
Since: 1.14