| Top |  |  |  |  | 
| #define | GST_META_FLAGS() | 
| #define | GST_META_FLAG_IS_SET() | 
| #define | GST_META_FLAG_SET() | 
| #define | GST_META_FLAG_UNSET() | 
| gboolean | (*GstMetaInitFunction) () | 
| void | (*GstMetaFreeFunction) () | 
| gboolean | (*GstMetaTransformFunction) () | 
| #define | GST_META_TRANSFORM_IS_COPY() | 
| GType | gst_meta_api_type_register () | 
| gboolean | gst_meta_api_type_has_tag () | 
| const gchar * const* | gst_meta_api_type_get_tags () | 
| const GstMetaInfo * | gst_meta_register () | 
| const GstMetaInfo * | gst_meta_get_info () | 
| guint64 | gst_meta_get_seqnum () | 
| gint | gst_meta_compare_seqnum () | 
| struct | GstMeta | 
| enum | GstMetaFlags | 
| struct | GstMetaInfo | 
| GstMetaTransformCopy | |
| #define | GST_META_TAG_MEMORY | 
| #define | GST_META_TAG_MEMORY_STR | 
The GstMeta structure should be included as the first member of a GstBuffer metadata structure. The structure defines the API of the metadata and should be accessible to all elements using the metadata.
A metadata API is registered with gst_meta_api_type_register() which takes a
name for the metadata API and some tags associated with the metadata.
With gst_meta_api_type_has_tag() one can check if a certain metadata API
contains a given tag.
Multiple implementations of a metadata API can be registered.
To implement a metadata API, gst_meta_register() should be used. This
function takes all parameters needed to create, free and transform metadata
along with the size of the metadata. The function returns a GstMetaInfo
structure that contains the information for the implementation of the API.
A specific implementation can be retrieved by name with gst_meta_get_info().
See GstBuffer for how the metadata can be added, retrieved and removed from buffers.
#define GST_META_FLAGS(meta) (GST_META_CAST (meta)->flags)
A flags word containing GstMetaFlags flags set on meta
#define GST_META_FLAG_IS_SET(meta,flag) !!(GST_META_FLAGS (meta) & (flag))
Gives the status of a specific flag on a metadata.
#define GST_META_FLAG_SET(meta,flag) (GST_META_FLAGS (meta) |= (flag))
Sets a metadata flag on a metadata.
#define GST_META_FLAG_UNSET(meta,flag) (GST_META_FLAGS (meta) &= ~(flag))
Clears a metadata flag.
gboolean (*GstMetaInitFunction) (GstMeta *meta,gpointer params,GstBuffer *buffer);
Function called when meta
 is initialized in buffer
.
void (*GstMetaFreeFunction) (GstMeta *meta,GstBuffer *buffer);
Function called when meta
 is freed in buffer
.
gboolean (*GstMetaTransformFunction) (GstBuffer *transbuf,GstMeta *meta,GstBuffer *buffer,GQuark type,gpointer data);
Function called for each meta
 in buffer
 as a result of performing a
transformation on transbuf
. Additional type
 specific transform data
is passed to the function as data
.
Implementations should check the type
 of the transform and parse
additional type specific fields in data
 that should be used to update
the metadata on transbuf
.
#define GST_META_TRANSFORM_IS_COPY(type) ((type) == _gst_meta_transform_copy)
Check if the transform type is a copy transform
GType gst_meta_api_type_register (const gchar *api,const gchar **tags);
Register and return a GType for the api
 and associate it with
tags
.
gboolean gst_meta_api_type_has_tag (GType api,GQuark tag);
Check if api
 was registered with tag
.
const gchar * const*
gst_meta_api_type_get_tags (GType api);
Since: 1.2
const GstMetaInfo * gst_meta_register (GType api,const gchar *impl,gsize size,GstMetaInitFunction init_func,GstMetaFreeFunction free_func,GstMetaTransformFunction transform_func);
Register a new GstMeta implementation.
The same info
 can be retrieved later with gst_meta_get_info() by using
impl
 as the key.
const GstMetaInfo *
gst_meta_get_info (const gchar *impl);
Lookup a previously registered meta info structure by its implementation name
impl
.
guint64
gst_meta_get_seqnum (const GstMeta *meta);
Gets seqnum for this meta.
Since: 1.16
gint gst_meta_compare_seqnum (const GstMeta *meta1,const GstMeta *meta2);
Meta sequence number compare function. Can be used as GCompareFunc or a GCompareDataFunc.
 a negative number if meta1
comes before meta2
, 0 if both metas
have an equal sequence number, or a positive integer if meta1
comes
after meta2
.
Since: 1.16
struct GstMeta {
  GstMetaFlags       flags;
  const GstMetaInfo *info;
};
Base structure for metadata. Custom metadata will put this structure as the first member of their structure.
| GstMetaFlags  | extra flags for the metadata | |
| const GstMetaInfo * | pointer to the GstMetaInfo | 
struct GstMetaInfo {
  GType                      api;
  GType                      type;
  gsize                      size;
  GstMetaInitFunction        init_func;
  GstMetaFreeFunction        free_func;
  GstMetaTransformFunction   transform_func;
  /* No padding needed, GstMetaInfo is always allocated by GStreamer and is
   * not subclassable or stack-allocatable, so we can extend it as we please
   * just like interfaces */
};
The GstMetaInfo provides information about a specific metadata structure.
| tag identifying the metadata structure and api | ||
| type identifying the implementor of the api | ||
| size of the metadata | ||
| GstMetaInitFunction  | function for initializing the metadata | |
| GstMetaFreeFunction  | function for freeing the metadata | |
| GstMetaTransformFunction  | function for transforming the metadata | 
typedef struct {
  gboolean region;
  gsize offset;
  gsize size;
} GstMetaTransformCopy;
Extra data passed to a "gst-copy" transform GstMetaTransformFunction.
#define GST_META_TAG_MEMORY (_gst_meta_tag_memory)
GST_META_TAG_MEMORY is deprecated and should not be used in newly-written code.
The GQuarks are not exported by any public API, use GST_META_TAG_MEMORY_STR instead.
Metadata tagged with this tag depends on the particular memory or buffer that it is on.
#define GST_META_TAG_MEMORY_STR "memory"
This metadata stays relevant as long as memory layout is unchanged.
Since: 1.2