[grilo] doc: Provide more links in documentation
- From: Juan A. Suarez Romero <jasuarez src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [grilo] doc: Provide more links in documentation
- Date: Wed, 29 Jun 2011 08:14:42 +0000 (UTC)
commit 55bbc031b56f501504339533984be25fb98ce99d
Author: Juan A. Suarez Romero <jasuarez igalia com>
Date: Tue Jun 28 11:09:53 2011 +0000
doc: Provide more links in documentation
Add cross-references.
Signed-off-by: Juan A. Suarez Romero <jasuarez igalia com>
doc/grilo/plugins-media-sources.xml | 206 +++++++++++++++++---------------
doc/grilo/plugins-metadata-sources.xml | 39 ++++---
2 files changed, 131 insertions(+), 114 deletions(-)
---
diff --git a/doc/grilo/plugins-media-sources.xml b/doc/grilo/plugins-media-sources.xml
index 63afe61..7db6ec6 100644
--- a/doc/grilo/plugins-media-sources.xml
+++ b/doc/grilo/plugins-media-sources.xml
@@ -1,4 +1,4 @@
-<?xml version="1.0"?>
+ <?xml version="1.0"?>
<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.3//EN"
"http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd" [
<!ENTITY % local.common.attrib "xmlns:xi CDATA #FIXED 'http://www.w3.org/2003/XInclude'">
@@ -68,10 +68,10 @@
<title>Registering Media Source Plugins</title>
<para>
- Grilo plugins must use the macro GRL_PLUGIN_REGISTER, which
- defines the entry and exit points of the plugin (called
- when the plugin is loaded and unloaded respectively) as well
- as its plugin identifier (a string identifying the plugin).
+ Grilo plugins must use the macro GRL_PLUGIN_REGISTER(), which defines the
+ entry and exit points of the plugin (called when the plugin is loaded and
+ unloaded respectively) as well as its plugin identifier (a string
+ identifying the plugin).
</para>
<para>
@@ -87,22 +87,24 @@
</para>
<para>
- Usually the plugin initialization function will create
- at least one GrlMediaSource instance and register it
- using grl_plugin_registry_register_source.
+ Usually the plugin initialization function will create at least one <link
+ linkend="GrlMediaSource">GrlMediaSource</link> instance and register it
+ using <link
+ linkend="grl-plugin-registry-register-source">grl_plugin_registry_register_source()</link>.
</para>
<para>
- A GrlMediaSource instance represents a particular source
- of media. Usually each plugin would spawn just one media
- source, but some plugins may spawn multiple media sources.
- For example, a UPnP plugin spawning one media source object
- for each UPnP server discovered.
+ A <link linkend="GrlMediaSource">GrlMediaSource</link> instance represents a
+ particular source of media. Usually each plugin would spawn just one media
+ source, but some plugins may spawn multiple media sources. For example, a
+ UPnP plugin spawning one media source object for each UPnP server
+ discovered.
</para>
<para>
- Users can query the registry for available media sources and
- then use the GrlMediaSource API to interact with them.
+ Users can query the registry for available media sources and then use the
+ <link linkend="GrlMediaSource">GrlMediaSource</link> API to interact with
+ them.
</para>
<para>
@@ -112,13 +114,13 @@
</para>
<para>
- The parameter "configs" of the plugin initialization function
- provides available configuration information provided by the
- user for this plugin, if any. This parameter is a list of
- GrlConfig objects. Usually there would be only one GrlConfig
- object in the list, but there might be more in the cases of
- plugins spawning multiple media sources that require different
- configuration options.
+ The parameter "configs" of the plugin initialization function provides
+ available configuration information provided by the user for this plugin, if
+ any. This parameter is a list of <link linkend="GrlConfig">GrlConfig</link>
+ objects. Usually there would be only one <link
+ linkend="GrlConfig">GrlConfig</link> object in the list, but there might be
+ more in the cases of plugins spawning multiple media sources that require
+ different configuration options.
</para>
<programlisting role="C">
@@ -153,23 +155,22 @@ GRL_PLUGIN_REGISTER (grl_foo_plugin_init, NULL, "grl-foo");
</programlisting>
<para>
- The next step is to implement the plugin code, for that
- Media Source plugins must extend the
- <link linkend="GrlMediaSource">GrlMediaSource</link> class.
+ The next step is to implement the plugin code, for that Media Source plugins
+ must extend the <link linkend="GrlMediaSource">GrlMediaSource</link> class.
</para>
<para>
In typical GObject fashion, developers should use the G_DEFINE_TYPE macro,
and then provide the class initialization function
- (grl_foo_source_class_init in the example below) and the instance
- initialization function (grl_foo_source_init in the example below).
- A constructor function, although not mandatory, is usually nice to
- have (grl_foo_source_new in the example below).
+ (grl_foo_source_class_init() in the example below) and the instance
+ initialization function (grl_foo_source_init() in the example below). A
+ constructor function, although not mandatory, is usually nice to have
+ (grl_foo_source_new() in the example below).
</para>
<para>
- When creating a new GrlMediaSource instance, a few properties
- should be provided:
+ When creating a new <link linkend="GrlMediaSource">GrlMediaSource</link>
+ instance, a few properties should be provided:
<itemizedlist>
<listitem>
<emphasis>source-id:</emphasis> An identifier for the source object.
@@ -361,12 +362,13 @@ grl_foo_source_slow_keys (GrlMetadataSource *source)
<listitem>Plugin executes the search on the backend. Typically this
involves some kind blocking operation (networking, disk access, etc)
that should be executed asynchronously when possible.</listitem>
- <listitem>Plugin receives the results from the media provider.
- For each result received the plugin creates a
- GrlMedia object encapsulating the metadata obtained for
- that particular match.</listitem>
- <listitem>Plugin sends the GrlMedia objects back to the client
- one by one by invoking the user provided callback.</listitem>
+ <listitem>Plugin receives the results from the media provider. For each
+ result received the plugin creates a <link
+ linkend="GrlMedia">GrlMedia</link> object encapsulating the metadata
+ obtained for that particular match.</listitem>
+ <listitem>Plugin sends the <link linkend="GrlMedia">GrlMedia</link>
+ objects back to the client one by one by invoking the user provided
+ callback.</listitem>
</itemizedlist>
</para>
@@ -454,10 +456,10 @@ grl_foo_source_search (GrlMediaSource *source, GrlMediaSourceSearchSpec *ss)
</para>
<para>
- The signature and way of operation of the Browse operation is the same
- as in the Search operation with one difference: instead of a text
- parameter with the search keywords, it receives a GrlMedia object
- representing the container (box) the user wants to browse.
+ The signature and way of operation of the Browse operation is the same as in
+ the Search operation with one difference: instead of a text parameter with
+ the search keywords, it receives a <link linkend="GrlMedia">GrlMedia</link>
+ object representing the container (box) the user wants to browse.
</para>
<para>
@@ -572,28 +574,32 @@ grl_foo_source_browse (GrlMediaSource *source, GrlMediaSourceBrowseSpec *bs)
<listitem>
In the example we are assuming that the content hierarchy only has two
levels, the first level exposes a list of categories (each one exposed
- as a GrlMediaBox object so the user knows they can be browsed again), and
- then a second level with the contents within these categories, that we
- assume are all media items, although in real life they could very well
- be more GrlMediaBox objects, leading to more complex hierarchies.
+ as a <link linkend="GrlMediaBox">GrlMediaBox</link> object so the user
+ knows they can be browsed again), and then a second level with the
+ contents within these categories, that we assume are all media items,
+ although in real life they could very well be more <link
+ linkend="GrlMediaBox">GrlMediaBox</link> objects, leading to more
+ complex hierarchies.
</listitem>
<listitem>
- GrlMediaBox objects returned by a browse operation can be browsed
- by clients in future Browse operations.
+ <link linkend="GrlMediaBox">GrlMediaBox</link> objects returned by a
+ browse operation can be browsed by clients in future Browse operations.
</listitem>
<listitem>
- The input parameter that informs the plugin about the box that
- should be browsed (bs->container) is of type GrlMediaBox. The
- plugin developer must map that to something the media provider
- understands. Typically, when GrlMedia objects are returned from
- a plugin to the client, they are created so their "id"
- property (grl_media_set_id) can be used for this purpose,
- identifying these media resources uniquely in the context of
- the media provider.
+ The input parameter that informs the plugin about the box that should be
+ browsed (bs->container) is of type <link
+ linkend="GrlMediaBox">GrlMediaBox</link>. The plugin developer must map
+ that to something the media provider understands. Typically, when <link
+ linkend="GrlMedia">GrlMedia</link> objects are returned from a plugin to
+ the client, they are created so their "id" property (<link
+ linkend="grl-media-set-id">grl_media_set_id()</link>) can be used for
+ this purpose, identifying these media resources uniquely in the context
+ of the media provider.
</listitem>
<listitem>
- A GrlMediaBox object with NULL id always represents the root
- box/category in the content hierarchy exposed by the plugin.
+ A <link linkend="GrlMediaBox">GrlMediaBox</link> object with NULL id
+ always represents the root box/category in the content hierarchy exposed
+ by the plugin.
</listitem>
</itemizedlist>
</para>
@@ -731,11 +737,15 @@ grl_foo_source_query (GrlMediaSource *source, GrlMediaSourceQuerySpec *qs)
plugin code is not recommended, instead, splitting the work to do in
chunks using the idle loop is encouraged.
</listitem>
- <listitem>Creating GrlMedia instances is easy, depending on the type of
- media you should instantiate one of the GrlMedia subclasses (GrlMediaImage,
- GrlMediaVideo, GrlMediaAudio or GrlMediaBox), and then use the API to
- set the corresponding data. Check the <link linkend="GrlData">GrlData</link>
- hierarchy in the API reference for more details.
+ <listitem>Creating <link linkend="GrlMedia">GrlMedia</link> instances is
+ easy, depending on the type of media you should instantiate one of the
+ <link linkend="GrlMedia">GrlMedia</link> subclasses (<link
+ linkend="GrlMediaImage">GrlMediaImage</link>, <link
+ linkend="GrlMediaVideo">GrlMediaVideo</link>, <link
+ linkend="GrlMediaAudio">GrlMediaAudio</link> or <link
+ linkend="GrlMediaBox">GrlMediaBox</link>), and then use the API to set the
+ corresponding data. Check the <link linkend="GrlData">GrlData</link>
+ hierarchy in the API reference for more details.
</listitem>
<listitem>The remaining count parameter present in the callbacks is intended
to provide the client with an <emphasis>estimation</emphasis> of how many
@@ -770,8 +780,8 @@ grl_foo_source_query (GrlMediaSource *source, GrlMediaSourceQuerySpec *qs)
plugin developer.
</listitem>
<listitem>
- Returned GrlMedia objects are owned by the client and should not be
- freed by the plugin.
+ Returned <link linkend="GrlMedia">GrlMedia</link> objects are owned by
+ the client and should not be freed by the plugin.
</listitem>
<listitem>
The list of metadata information requested by the client is
@@ -797,16 +807,17 @@ grl_foo_source_query (GrlMediaSource *source, GrlMediaSourceQuerySpec *qs)
</para>
<para>
- The purpose of the metadata method is to provide additional
- metadata for GrlMedia objects produced by the media source.
+ The purpose of the metadata method is to provide additional metadata for
+ <link linkend="GrlMedia">GrlMedia</link> objects produced by the media
+ source.
</para>
<para>
- Typically, the use case for Metadata operations is applications
- obtaining a list of GrlMedia objects by executing a Browse,
- Search or Query operation , requesting limited metadata (for
- performance reasons), and then requesting additional metadata
- for specific items selected by the user.
+ Typically, the use case for Metadata operations is applications obtaining a
+ list of <link linkend="GrlMedia">GrlMedia</link> objects by executing a
+ Browse, Search or Query operation , requesting limited metadata (for
+ performance reasons), and then requesting additional metadata for specific
+ items selected by the user.
</para>
<programlisting role="C">
@@ -850,9 +861,10 @@ grl_foo_source_metadata (GrlMediaSource *source, GrlMediaSourceMetadataSpec *ms)
Some considerations that plugin developers should take into account:
<itemizedlist>
<listitem>
- Clients invoke this method passing the GrlMedia object that
- they want to update (ms->media). Plugin developers should resolve the
- requested metadata (ms->keys) and store it in that GrlMedia
+ Clients invoke this method passing the <link
+ linkend="GrlMedia">GrlMedia</link> object that they want to update
+ (ms->media). Plugin developers should resolve the requested metadata
+ (ms->keys) and store it in that <link linkend="GrlMedia">GrlMedia</link>
object.
</listitem>
<listitem>
@@ -981,34 +993,36 @@ grl_foo_source_remove (GrlMediaSource *source, GrlMediaSourceRemoveSpec *rs)
<para>Implementation of the "media_from_uri" method is optional.</para>
<para>
- Some times clients have access to the URI of the media, and they
- want to retrieve metadata for it. A couple of examples where this may
- come in handy: A file system browser that needs to obtain additional
- metadata for a particular media item located in the filesystem. A browser
- plugin that can obtain additional metadata for a media item given its
- URL. In these cases we know the URI of the media, but we need to
- create a GrlMedia object representing it.
+ Some times clients have access to the URI of the media, and they want to
+ retrieve metadata for it. A couple of examples where this may come in handy:
+ A file system browser that needs to obtain additional metadata for a
+ particular media item located in the filesystem. A browser plugin that can
+ obtain additional metadata for a media item given its URL. In these cases we
+ know the URI of the media, but we need to create a <link
+ linkend="GrlMedia">GrlMedia</link> object representing it.
</para>
<para>
- Plugins that want to support URI to GrlMedia conversions must implement
- the "test_media_from_uri" and "media_from_uri" methods.
+ Plugins that want to support URI to <link linkend="GrlMedia">GrlMedia</link>
+ conversions must implement the "test_media_from_uri" and "media_from_uri"
+ methods.
</para>
<para>
The method "test_media_from_uri" should return TRUE if, upon inspection of
- the media URI, the plugin decides that it can convert it to a GrlMedia
- object. For example, a YouTube plugin would check that the URI of the media
- is a valid YouTube URL. This method is asynchronous and should not block.
- If the plugin cannot decide if it can or cannot convert the URI to a
- GrlMedia object by inspecting the URI without doing blocking operations,
- it should return TRUE. This method is used to discard efficiently plugins
- that cannot resolve the media.
+ the media URI, the plugin decides that it can convert it to a <link
+ linkend="GrlMedia">GrlMedia</link> object. For example, a YouTube plugin
+ would check that the URI of the media is a valid YouTube URL. This method is
+ asynchronous and should not block. If the plugin cannot decide if it can or
+ cannot convert the URI to a <link linkend="GrlMedia">GrlMedia</link> object
+ by inspecting the URI without doing blocking operations, it should return
+ TRUE. This method is used to discard efficiently plugins that cannot resolve
+ the media.
</para>
<para>
- The method "media_from_uri" is used to do the actual conversion from the
- URI to the GrlMedia object.
+ The method "media_from_uri" is used to do the actual conversion from the URI
+ to the <link linkend="GrlMedia">GrlMedia</link> object.
</para>
<programlisting role="C">
@@ -1144,14 +1158,14 @@ grl_foo_source_notify_change_stop (GrlMediaSource *source,
</programlisting>
<para>
- Please check the
- <link linkend="GrlMediaSource">GrlMediaSource</link> API reference
- for more details on how grl_media_source_notify_change_list
+ Please check the <link linkend="GrlMediaSource">GrlMediaSource</link> API
+ reference for more details on how <link
+ linkend="grl-media-source-notify-change-list">grl_media_source_notify_change_list()</link>
should be used.
</para>
<para>Examples of plugins implementing change notification are
- gr-upnp and grl-tracker among others
+ grl-upnp and grl-tracker among others
</para>
</section>
</section>
diff --git a/doc/grilo/plugins-metadata-sources.xml b/doc/grilo/plugins-metadata-sources.xml
index d345927..6fe824d 100644
--- a/doc/grilo/plugins-metadata-sources.xml
+++ b/doc/grilo/plugins-metadata-sources.xml
@@ -25,8 +25,9 @@
</para>
<para>
- Media sources extend GrlMetadataSource, so they are also metadata
- sources.
+ Media sources extend <link
+ linkend="GrlMetadataSource">GrlMetadataSource</link>, so they are also
+ metadata sources.
</para>
<para>
@@ -43,10 +44,10 @@
<para>
Registering a new metadata source plugin is done by following the same
- procedure as for media source plugins, except that they must extend
- GrlMetadataSource. Please, check
- <link linkend="media-source-plugins-basics">Registering Media Source Plugins</link>
- for details.
+ procedure as for media source plugins, except that they must extend <link
+ linkend="GrlMetadataSource">GrlMetadataSource</link>. Please, check <link
+ linkend="media-source-plugins-basics">Registering Media Source
+ Plugins</link> for details.
</para>
<para>
@@ -69,23 +70,23 @@
</para>
<para>
- Resolve operations are issued in order to grab additional information
- on a given media (GrlMedia).
+ Resolve operations are issued in order to grab additional information on a
+ given media (<link linkend="GrlMedia">GrlMedia</link>).
</para>
<para>
- Typically, implementing Resolve implies inspecting the metadata
- already known for that media and use that information to gain access
- to new information. For example, a plugin can use the artist and album
- information of a given GrlMediaAudio item to obtain additional information,
- like the album cover thumbnail.
+ Typically, implementing Resolve implies inspecting the metadata already
+ known for that media and use that information to gain access to new
+ information. For example, a plugin can use the artist and album
+ information of a given <link linkend="GrlMediaAudio">GrlMediaAudio</link>
+ item to obtain additional information, like the album cover thumbnail.
</para>
<para>
Plugins implementing "resolve" must also implement "may_resolve". The
- purpose of this method is to analyze if the GrlMedia contains enough
- metadata to enable the plugin to extract the additional metadata
- requested.
+ purpose of this method is to analyze if the <link
+ linkend="GrlMedia">GrlMedia</link> contains enough metadata to enable the
+ plugin to extract the additional metadata requested.
</para>
<programlisting role="C">
@@ -336,8 +337,10 @@ grl_foo_source_set_metadata (GrlMetadataSource *source,
Grilo provides plugin developers with API to attach arbitrary data
to a certain operation given its identifier. These APIs are:
<itemizedlist>
- <listitem>grl_operation_set_data</listitem>
- <listitem>grl_operation_get_data</listitem>
+ <listitem><link
+ linkend="grl-operation-set-data">grl_operation_set_data()</link></listitem>
+ <listitem><link
+ linkend="grl-operation-get-data">grl_operation_get_data()</link></listitem>
</itemizedlist>
See the API reference documentation for
<link linkend="grilo-grl-operation">grl-operation</link> for
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]