From 5886cb87ab87dd7ca089c9300d54550f4fafff29 Mon Sep 17 00:00:00 2001 From: Wim Taymans <wim.taymans@gmail.com> Date: Thu, 16 Jan 2003 22:03:39 +0000 Subject: [PATCH] - Added rank to plugin features (for future use) Original commit message from CVS: - Added rank to plugin features (for future use) - update docs in gsturi --- gst/gstpluginfeature.h | 8 +++-- gst/gsturi.c | 67 +++++++++++++++++++++++++++++------------- gst/gsturi.h | 7 +++-- 3 files changed, 55 insertions(+), 27 deletions(-) diff --git a/gst/gstpluginfeature.h b/gst/gstpluginfeature.h index 4fd2b35c1c..277a4f94a1 100644 --- a/gst/gstpluginfeature.h +++ b/gst/gstpluginfeature.h @@ -41,11 +41,13 @@ typedef struct _GstPluginFeature GstPluginFeature; typedef struct _GstPluginFeatureClass GstPluginFeatureClass; struct _GstPluginFeature { - GObject object; + GObject object; - gchar *name; + gchar *name; + gint rank; - gpointer manager; + /* --- private --- */ + gpointer manager; }; struct _GstPluginFeatureClass { diff --git a/gst/gsturi.c b/gst/gsturi.c index eb4dddd704..ec07b48143 100644 --- a/gst/gsturi.c +++ b/gst/gsturi.c @@ -2,7 +2,7 @@ * Copyright (C) 1999,2000 Erik Walthinsen <omega@cse.ogi.edu> * 2000 Wim Taymans <wtay@chello.be> * - * gsttype.c: Media-type management functions + * gsturi.c: register URI handlers * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public @@ -20,13 +20,6 @@ * Boston, MA 02111-1307, USA. */ -/* TODO: - * probably should set up a hash table for the type id's, since currently - * it's a rather pathetic linear search. Eventually there may be dozens - * of id's, but in reality there are only so many instances of lookup, so - * I'm not overly worried yet... - */ - #include "gst_private.h" #include "gsturi.h" @@ -43,10 +36,10 @@ static GstPluginFeatureClass *parent_class = NULL; GType gst_uri_handler_get_type (void) { - static GType typefactory_type = 0; + static GType urihandler_type = 0; - if (!typefactory_type) { - static const GTypeInfo typefactory_info = { + if (!urihandler_type) { + static const GTypeInfo urihandler_info = { sizeof (GstURIHandlerClass), NULL, NULL, @@ -58,10 +51,10 @@ gst_uri_handler_get_type (void) (GInstanceInitFunc) gst_uri_handler_init, NULL }; - typefactory_type = g_type_register_static (GST_TYPE_PLUGIN_FEATURE, - "GstURIHandler", &typefactory_info, 0); + urihandler_type = g_type_register_static (GST_TYPE_PLUGIN_FEATURE, + "GstURIHandler", &urihandler_info, 0); } - return typefactory_type; + return urihandler_type; } static void @@ -85,11 +78,16 @@ gst_uri_handler_init (GstURIHandler *factory) /** * gst_uri_handler_new: - * @definition: the definition to use + * @name: the name of the feature + * @uri: the uri to register + * @longdesc: a description for this uri + * @element: an element that can handle the uri + * @property: the property on the element to set the uri * - * Creata a new typefactory from the given definition. + * Creates a plugin feature to register an element that can + * handle the given uri on the given property. * - * Returns: the new typefactory + * Returns: the new urihandler */ GstURIHandler* gst_uri_handler_new (const gchar *name, @@ -120,7 +118,7 @@ gst_uri_handler_new (const gchar *name, /** * gst_uri_handler_find: - * @name: the name of the typefactory to find + * @name: the name of the urihandler to find * * Return the URIHandler with the given name. * @@ -140,6 +138,14 @@ gst_uri_handler_find (const gchar *name) return NULL; } +/** + * gst_uri_handler_find_by_uri: + * @uri: the uri to find a handler for + * + * Find a URIHandler for the given uri. + * + * Returns: a GstURIHandler that can handle the given uri. + */ GstURIHandler* gst_uri_handler_find_by_uri (const gchar *uri) { @@ -163,18 +169,37 @@ gst_uri_handler_find_by_uri (const gchar *uri) return handler; } +/** + * gst_uri_handler_create: + * @handler: the uri handler to use + * @name: the name of the element + * + * Create an element with the given name from the given handler. + * + * Returns: a new element associated with the handler. + */ GstElement* -gst_uri_handler_create (GstURIHandler *factory, const gchar *name) +gst_uri_handler_create (GstURIHandler *handler, const gchar *name) { GstElement *element = NULL; - g_return_val_if_fail (factory != NULL, NULL); + g_return_val_if_fail (handler != NULL, NULL); - element = gst_element_factory_make (factory->element, name); + element = gst_element_factory_make (handler->element, name); return element; } +/** + * gst_uri_handler_make_by_uri: + * @uri: the uri + * @name: the name of the element + * + * Create an element with the given name that can handle the given + * uri. This function will also use set the uri on the element. + * + * Returns: a new element that can handle the uri. + */ GstElement* gst_uri_handler_make_by_uri (const gchar *uri, const gchar *name) { diff --git a/gst/gsturi.h b/gst/gsturi.h index 929e425a33..58e3a81de6 100644 --- a/gst/gsturi.h +++ b/gst/gsturi.h @@ -2,7 +2,7 @@ * Copyright (C) 1999,2000 Erik Walthinsen <omega@cse.ogi.edu> * 2000 Wim Taymans <wtay@chello.be> * - * gstscheduler.h: Header for default scheduler code + * gsturi.h: Header for uri to element mappings * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public @@ -43,6 +43,7 @@ typedef struct _GstURIHandlerClass GstURIHandlerClass; struct _GstURIHandler { GstPluginFeature feature; + /* --- public ---- */ gchar *uri; /* The uri that is described */ gchar *longdesc; /* description of the uri */ gchar *element; /* The element that can handle this uri */ @@ -58,12 +59,12 @@ GType gst_uri_handler_get_type (void); GstURIHandler* gst_uri_handler_new (const gchar *name, const gchar *uri, const gchar *longdesc, const gchar *element, gchar *property); -void gst_uri_handler_destroy (GstURIHandler *factory); +void gst_uri_handler_destroy (GstURIHandler *handler); GstURIHandler* gst_uri_handler_find (const gchar *name); GstURIHandler* gst_uri_handler_find_by_uri (const gchar *uri); -GstElement* gst_uri_handler_create (GstURIHandler *factory, const gchar *name); +GstElement* gst_uri_handler_create (GstURIHandler *handler, const gchar *name); GstElement* gst_uri_handler_make_by_uri (const gchar *uri, const gchar *name); G_END_DECLS