|  |  |  | GStreamer 1.0 Core Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | ||||
#include <gst/gst.h> GQuark gst_plugin_error_quark (void); #define GST_PLUGIN_ERROR enum GstPluginError; GstPlugin; struct GstPluginDesc; gboolean (*GstPluginInitFunc) (GstPlugin *plugin); gboolean (*GstPluginInitFullFunc) (GstPlugin *plugin,gpointer user_data); #define GST_PLUGIN_DEFINE (major, minor, name, description, init, version, license, package, origin) #define GST_LICENSE_UNKNOWN gboolean (*GstPluginFilter) (GstPlugin *plugin,gpointer user_data); const gchar * gst_plugin_get_name (GstPlugin *plugin); const gchar * gst_plugin_get_description (GstPlugin *plugin); const gchar * gst_plugin_get_filename (GstPlugin *plugin); const gchar * gst_plugin_get_license (GstPlugin *plugin); const gchar * gst_plugin_get_package (GstPlugin *plugin); const gchar * gst_plugin_get_origin (GstPlugin *plugin); const gchar * gst_plugin_get_source (GstPlugin *plugin); const gchar * gst_plugin_get_version (GstPlugin *plugin); const gchar * gst_plugin_get_release_date_string (GstPlugin *plugin); gboolean gst_plugin_is_loaded (GstPlugin *plugin); const GstStructure * gst_plugin_get_cache_data (GstPlugin *plugin); void gst_plugin_set_cache_data (GstPlugin *plugin,GstStructure *cache_data); GstPlugin * gst_plugin_load_file (const gchar *filename,GError **error); GstPlugin * gst_plugin_load (GstPlugin *plugin); GstPlugin * gst_plugin_load_by_name (const gchar *name); void gst_plugin_list_free (GList *list); gboolean gst_plugin_register_static (gint major_version,gint minor_version,const gchar *name,const gchar *description,GstPluginInitFunc init_func,const gchar *version,const gchar *license,const gchar *source,const gchar *package,const gchar *origin); gboolean gst_plugin_register_static_full (gint major_version,gint minor_version,const gchar *name,const gchar *description,GstPluginInitFullFunc init_full_func,const gchar *version,const gchar *license,const gchar *source,const gchar *package,const gchar *origin,gpointer user_data); enum GstPluginFlags; enum GstPluginDependencyFlags; void gst_plugin_add_dependency (GstPlugin *plugin,const gchar **env_vars,const gchar **paths,const gchar **names,GstPluginDependencyFlags flags); void gst_plugin_add_dependency_simple (GstPlugin *plugin,const gchar *env_vars,const gchar *paths,const gchar *names,GstPluginDependencyFlags flags);
GStreamer is extensible, so GstElement instances can be loaded at runtime. A plugin system can provide one or more of the basic GStreamer GstPluginFeature subclasses.
A plugin should export a symbol gst_plugin_desc that is a struct of type GstPluginDesc. the plugin loader will check the version of the core library the plugin was linked against and will create a new GstPlugin. It will then call the GstPluginInitFunc function that was provided in the gst_plugin_desc.
Once you have a handle to a GstPlugin (e.g. from the GstRegistry), you can add any object that subclasses GstPluginFeature.
Usually plugins are always automaticlly loaded so you don't need to call
gst_plugin_load() explicitly to bring it into memory. There are options to
statically link plugins to an app or even use GStreamer without a plugin
repository in which case gst_plugin_load() can be needed to bring the plugin
into memory.
GQuark              gst_plugin_error_quark              (void);
Get the error quark.
| Returns : | The error quark used in GError messages | 
#define GST_PLUGIN_ERROR gst_plugin_error_quark ()
The error message category quark
typedef enum {
  GST_PLUGIN_ERROR_MODULE,
  GST_PLUGIN_ERROR_DEPENDENCIES,
  GST_PLUGIN_ERROR_NAME_MISMATCH
} GstPluginError;
The plugin loading errors
struct GstPluginDesc {
  gint major_version;
  gint minor_version;
  const gchar *name;
  const gchar *description;
  GstPluginInitFunc plugin_init;
  const gchar *version;
  const gchar *license;
  const gchar *source;
  const gchar *package;
  const gchar *origin;
  const gchar *release_datetime;
};
A plugin should export a variable of this type called plugin_desc. The plugin loader will use the data provided there to initialize the plugin.
The licence parameter must be one of: LGPL, GPL, QPL, GPL/QPL, MPL,
BSD, MIT/X11, Proprietary, unknown.
| gint  | the major version number of core that plugin was compiled for | 
| gint  | the minor version number of core that plugin was compiled for | 
| const gchar * | a unique name of the plugin | 
| const gchar * | description of plugin | 
| GstPluginInitFunc  | pointer to the init function of this plugin. | 
| const gchar * | version of the plugin | 
| const gchar * | effective license of plugin | 
| const gchar * | source module plugin belongs to | 
| const gchar * | shipped package plugin belongs to | 
| const gchar * | URL to provider of plugin | 
| const gchar * | date time string in ISO 8601 format (or rather, a subset thereof), or NULL. Allowed are the following formats: "YYYY-MM-DD" and "YYY-MM-DDTHH:MMZ" (with 'T' a separator and 'Z' indicating UTC/Zulu time). This field should be set via the GST_PACKAGE_RELEASE_DATETIME preprocessor macro. | 
gboolean            (*GstPluginInitFunc)                (GstPlugin *plugin);
A plugin should provide a pointer to a function of this type in the plugin_desc struct. This function will be called by the loader at startup. One would then register each GstPluginFeature.
| 
 | The plugin object | 
| Returns : | TRUEif plugin initialised successfully | 
gboolean (*GstPluginInitFullFunc) (GstPlugin *plugin,gpointer user_data);
A plugin should provide a pointer to a function of either GstPluginInitFunc or this type in the plugin_desc struct. The function will be called by the loader at startup. One would then register each GstPluginFeature. This version allows user data to be passed to init function (useful for bindings).
| 
 | The plugin object | 
| 
 | extra data | 
| Returns : | TRUEif plugin initialised successfully | 
#define GST_PLUGIN_DEFINE(major,minor,name,description,init,version,license,package,origin)
This macro needs to be used to define the entry point and meta data of a plugin. One would use this macro to export a plugin, so that it can be used by other applications.
The macro uses a define named PACKAGE for the GstPluginDesc,source field. When using autoconf, this is usually set automatically via the AC_INIT macro, and set in config.h. If you are not using autoconf, you will need to define PACKAGE yourself and set it to a short mnemonic string identifying your application/package, e.g. 'someapp' or 'my-plugins-foo.
If defined, the GST_PACKAGE_RELEASE_DATETIME will also be used for the GstPluginDesc,release_datetime field.
| 
 | major version number of the gstreamer-core that plugin was compiled for | 
| 
 | minor version number of the gstreamer-core that plugin was compiled for | 
| 
 | short, but unique name of the plugin | 
| 
 | information about the purpose of the plugin | 
| 
 | function pointer to the plugin_init method with the signature of static gboolean plugin_init (GstPlugin * plugin). | 
| 
 | full version string (e.g. VERSION from config.h) | 
| 
 | under which licence the package has been released, e.g. GPL, LGPL. | 
| 
 | the package-name (e.g. PACKAGE_NAME from config.h) | 
| 
 | a description from where the package comes from (e.g. the homepage URL) | 
#define GST_LICENSE_UNKNOWN "unknown"
To be used in GST_PLUGIN_DEFINE if usure about the licence.
gboolean (*GstPluginFilter) (GstPlugin *plugin,gpointer user_data);
A function that can be used with e.g. gst_registry_plugin_filter()
to get a list of plugins that match certain criteria.
| 
 | the plugin to check | 
| 
 | the user_data that has been passed on e.g. gst_registry_plugin_filter() | 
| Returns : | TRUE for a positive match, FALSE otherwise | 
const gchar *       gst_plugin_get_name                 (GstPlugin *plugin);
Get the short name of the plugin
| 
 | plugin to get the name of | 
| Returns : | the name of the plugin | 
const gchar *       gst_plugin_get_description          (GstPlugin *plugin);
Get the long descriptive name of the plugin
| 
 | plugin to get long name of | 
| Returns : | the long name of the plugin | 
const gchar *       gst_plugin_get_filename             (GstPlugin *plugin);
get the filename of the plugin
| 
 | plugin to get the filename of | 
| Returns : | the filename of the plugin | 
const gchar *       gst_plugin_get_license              (GstPlugin *plugin);
get the license of the plugin
| 
 | plugin to get the license of | 
| Returns : | the license of the plugin | 
const gchar *       gst_plugin_get_package              (GstPlugin *plugin);
get the package the plugin belongs to.
| 
 | plugin to get the package of | 
| Returns : | the package of the plugin | 
const gchar *       gst_plugin_get_origin               (GstPlugin *plugin);
get the URL where the plugin comes from
| 
 | plugin to get the origin of | 
| Returns : | the origin of the plugin | 
const gchar *       gst_plugin_get_source               (GstPlugin *plugin);
get the source module the plugin belongs to.
| 
 | plugin to get the source of | 
| Returns : | the source of the plugin | 
const gchar *       gst_plugin_get_version              (GstPlugin *plugin);
get the version of the plugin
| 
 | plugin to get the version of | 
| Returns : | the version of the plugin | 
const gchar *       gst_plugin_get_release_date_string  (GstPlugin *plugin);
Get the release date (and possibly time) in form of a string, if available.
For normal GStreamer plugin releases this will usually just be a date in the form of "YYYY-MM-DD", while pre-releases and builds from git may contain a time component after the date as well, in which case the string will be formatted like "YYYY-MM-DDTHH:MMZ" (e.g. "2012-04-30T09:30Z").
There may be plugins that do not have a valid release date set on them.
| 
 | plugin to get the release date of | 
| Returns : | the date string of the plugin, or NULLif not available. | 
gboolean            gst_plugin_is_loaded                (GstPlugin *plugin);
queries if the plugin is loaded into memory
| 
 | plugin to query | 
| Returns : | TRUE is loaded, FALSE otherwise | 
const GstStructure * gst_plugin_get_cache_data          (GstPlugin *plugin);
Gets the plugin specific data cache. If it is NULL there is no cached data
stored. This is the case when the registry is getting rebuilt.
| 
 | a plugin | 
| Returns : | The cached data as a GstStructure or NULL. [transfer none] | 
void gst_plugin_set_cache_data (GstPlugin *plugin,GstStructure *cache_data);
Adds plugin specific data to cache. Passes the ownership of the structure to
the plugin.
The cache is flushed every time the registry is rebuilt.
| 
 | a plugin | 
| 
 | a structure containing the data to cache. [transfer full] | 
GstPlugin * gst_plugin_load_file (const gchar *filename,GError **error);
Loads the given plugin and refs it. Caller needs to unref after use.
| 
 | the plugin filename to load | 
| 
 | pointer to a NULL-valued GError | 
| Returns : | a reference to the existing loaded GstPlugin, a reference to the newly-loaded GstPlugin, or NULL if an error occurred. [transfer full] | 
GstPlugin *         gst_plugin_load                     (GstPlugin *plugin);
Loads plugin. Note that the *return value* is the loaded plugin; plugin is
untouched. The normal use pattern of this function goes like this:
GstPlugin *loaded_plugin; loaded_plugin = gst_plugin_load (plugin); // presumably, we're no longer interested in the potentially-unloaded plugin gst_object_unref (plugin); plugin = loaded_plugin;
| 
 | plugin to load. [transfer none] | 
| Returns : | a reference to a loaded plugin, or NULL on error. [transfer full] | 
GstPlugin *         gst_plugin_load_by_name             (const gchar *name);
Load the named plugin. Refs the plugin.
| 
 | name of plugin to load | 
| Returns : | a reference to a loaded plugin, or NULL on error. [transfer full] | 
void                gst_plugin_list_free                (GList *list);
Unrefs each member of list, then frees the list.
| 
 | list of GstPlugin. [transfer full][element-type Gst.Plugin] | 
gboolean gst_plugin_register_static (gint major_version,gint minor_version,const gchar *name,const gchar *description,GstPluginInitFunc init_func,const gchar *version,const gchar *license,const gchar *source,const gchar *package,const gchar *origin);
Registers a static plugin, ie. a plugin which is private to an application or library and contained within the application or library (as opposed to being shipped as a separate module file).
You must make sure that GStreamer has been initialised (with gst_init() or
via gst_init_get_option_group()) before calling this function.
| 
 | the major version number of the GStreamer core that the plugin was compiled for, you can just use GST_VERSION_MAJOR here | 
| 
 | the minor version number of the GStreamer core that the plugin was compiled for, you can just use GST_VERSION_MINOR here | 
| 
 | a unique name of the plugin (ideally prefixed with an application- or library-specific namespace prefix in order to avoid name conflicts in case a similar plugin with the same name ever gets added to GStreamer) | 
| 
 | description of the plugin | 
| 
 | pointer to the init function of this plugin. [scope call] | 
| 
 | version string of the plugin | 
| 
 | effective license of plugin. Must be one of the approved licenses (see GstPluginDesc above) or the plugin will not be registered. | 
| 
 | source module plugin belongs to | 
| 
 | shipped package plugin belongs to | 
| 
 | URL to provider of plugin | 
| Returns : | TRUE if the plugin was registered correctly, otherwise FALSE. | 
gboolean gst_plugin_register_static_full (gint major_version,gint minor_version,const gchar *name,const gchar *description,GstPluginInitFullFunc init_full_func,const gchar *version,const gchar *license,const gchar *source,const gchar *package,const gchar *origin,gpointer user_data);
Registers a static plugin, ie. a plugin which is private to an application or library and contained within the application or library (as opposed to being shipped as a separate module file) with a GstPluginInitFullFunc which allows user data to be passed to the callback function (useful for bindings).
You must make sure that GStreamer has been initialised (with gst_init() or
via gst_init_get_option_group()) before calling this function.
| 
 | the major version number of the GStreamer core that the plugin was compiled for, you can just use GST_VERSION_MAJOR here | 
| 
 | the minor version number of the GStreamer core that the plugin was compiled for, you can just use GST_VERSION_MINOR here | 
| 
 | a unique name of the plugin (ideally prefixed with an application- or library-specific namespace prefix in order to avoid name conflicts in case a similar plugin with the same name ever gets added to GStreamer) | 
| 
 | description of the plugin | 
| 
 | pointer to the init function with user data of this plugin. [scope call] | 
| 
 | version string of the plugin | 
| 
 | effective license of plugin. Must be one of the approved licenses (see GstPluginDesc above) or the plugin will not be registered. | 
| 
 | source module plugin belongs to | 
| 
 | shipped package plugin belongs to | 
| 
 | URL to provider of plugin | 
| 
 | gpointer to user data | 
| Returns : | TRUE if the plugin was registered correctly, otherwise FALSE. | 
typedef enum {
  GST_PLUGIN_FLAG_CACHED      = (GST_OBJECT_FLAG_LAST << 0),
  GST_PLUGIN_FLAG_BLACKLISTED = (GST_OBJECT_FLAG_LAST << 1)
} GstPluginFlags;
The plugin loading state
typedef enum {
  GST_PLUGIN_DEPENDENCY_FLAG_NONE = 0,
  GST_PLUGIN_DEPENDENCY_FLAG_RECURSE = (1 << 0),
  GST_PLUGIN_DEPENDENCY_FLAG_PATHS_ARE_DEFAULT_ONLY = (1 << 1),
  GST_PLUGIN_DEPENDENCY_FLAG_FILE_NAME_IS_SUFFIX = (1 << 2)
} GstPluginDependencyFlags;
Flags used in connection with gst_plugin_add_dependency().
| no special flags | |
| recurse into subdirectories | |
| use paths argument only if none of the environment variables is set | |
| interpret filename argument as filter suffix and check all matching files in the directory | 
void gst_plugin_add_dependency (GstPlugin *plugin,const gchar **env_vars,const gchar **paths,const gchar **names,GstPluginDependencyFlags flags);
Make GStreamer aware of external dependencies which affect the feature set of this plugin (ie. the elements or typefinders associated with it).
GStreamer will re-inspect plugins with external dependencies whenever any of the external dependencies change. This is useful for plugins which wrap other plugin systems, e.g. a plugin which wraps a plugin-based visualisation library and makes visualisations available as GStreamer elements, or a codec loader which exposes elements and/or caps dependent on what external codec libraries are currently installed.
| 
 | a GstPlugin | 
| 
 | NULL-terminated array of environment variables affecting the feature set of the plugin (e.g. an environment variable containing paths where to look for additional modules/plugins of a library), or NULL. Environment variable names may be followed by a path component which will be added to the content of the environment variable, e.g. "HOME/.mystuff/plugins". [allow-none] | 
| 
 | NULL-terminated array of directories/paths where dependent files may be, or NULL. [allow-none] | 
| 
 | NULL-terminated array of file names (or file name suffixes,
depending on flags) to be used in combination with the paths frompathsand/or the paths extracted from the environment variables inenv_vars, or NULL. [allow-none] | 
| 
 | optional flags, or GST_PLUGIN_DEPENDENCY_FLAG_NONE | 
void gst_plugin_add_dependency_simple (GstPlugin *plugin,const gchar *env_vars,const gchar *paths,const gchar *names,GstPluginDependencyFlags flags);
Make GStreamer aware of external dependencies which affect the feature set of this plugin (ie. the elements or typefinders associated with it).
GStreamer will re-inspect plugins with external dependencies whenever any of the external dependencies change. This is useful for plugins which wrap other plugin systems, e.g. a plugin which wraps a plugin-based visualisation library and makes visualisations available as GStreamer elements, or a codec loader which exposes elements and/or caps dependent on what external codec libraries are currently installed.
Convenience wrapper function for gst_plugin_add_dependency() which
takes simple strings as arguments instead of string arrays, with multiple
arguments separated by predefined delimiters (see above).
| 
 | the GstPlugin | 
| 
 | one or more environment variables (separated by ':', ';' or ','), or NULL. Environment variable names may be followed by a path component which will be added to the content of the environment variable, e.g. "HOME/.mystuff/plugins:MYSTUFF_PLUGINS_PATH". [allow-none] | 
| 
 | one ore more directory paths (separated by ':' or ';' or ','), or NULL. Example: "/usr/lib/mystuff/plugins". [allow-none] | 
| 
 | one or more file names or file name suffixes (separated by commas), or NULL. [allow-none] | 
| 
 | optional flags, or GST_PLUGIN_DEPENDENCY_FLAG_NONE |