[grilo] doc: Added more information to the Quick Start chapter and renamed it to Tutorials.
- From: Iago Toral Quiroga <itoral src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [grilo] doc: Added more information to the Quick Start chapter and renamed it to Tutorials.
- Date: Tue, 28 Jun 2011 16:22:57 +0000 (UTC)
commit a1648e6a80bb8e60e2faf6ed3c75c29abba90aa2
Author: Iago Toral Quiroga <itoral igalia com>
Date: Tue Jun 28 18:10:53 2011 +0200
doc: Added more information to the Quick Start chapter and
renamed it to Tutorials.
doc/grilo/Makefile.am | 4 +-
doc/grilo/environment-setup.xml | 199 ++++++++++
doc/grilo/grilo-docs.sgml | 18 +-
doc/grilo/quick-start-using-grilo.xml | 296 ---------------
doc/grilo/quick-start.xml | 73 ++++
doc/grilo/writing-apps.xml | 648 +++++++++++++++++++++++++++++++++
6 files changed, 937 insertions(+), 301 deletions(-)
---
diff --git a/doc/grilo/Makefile.am b/doc/grilo/Makefile.am
index d533007..6ec6e07 100644
--- a/doc/grilo/Makefile.am
+++ b/doc/grilo/Makefile.am
@@ -73,7 +73,9 @@ HTML_IMAGES=
# Extra SGML files that are included by $(DOC_MAIN_SGML_FILE).
# e.g. content_files=running.sgml building.sgml changes-2.0.sgml
content_files=overview.xml \
- quick-start-using-grilo.xml \
+ quick-start.xml \
+ environment-setup.xml \
+ writing-apps.xml \
quick-start-plugins-media-sources.xml \
quick-start-plugins-metadata-sources.xml \
quick-start-plugins-testing.xml
diff --git a/doc/grilo/environment-setup.xml b/doc/grilo/environment-setup.xml
new file mode 100644
index 0000000..cfc257f
--- /dev/null
+++ b/doc/grilo/environment-setup.xml
@@ -0,0 +1,199 @@
+<?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'">
+]>
+
+<section id="environment-setup">
+
+ <para>
+ This section provides information on how to configure a proper environment for
+ building Grilo, as well building and running Grilo based programs.
+ </para>
+
+ <section id="building-grilo-detailed">
+ <title>Building Grilo </title>
+
+ <section id="building-grilo-sources-install">
+ <title>Building and installing Grilo</title>
+
+ <para>
+ You can check the basics of how to build and install Grilo from the
+ source code respositories in the
+ <link linkend="quick-start">Quick start guide</link>.
+ </para>
+ </section>
+
+ <section id="building-grilo-sources-uninstalled">
+ <title>Building and not installing Grilo</title>
+
+ <para>
+ If you do not want to install Grilo and rather use it in uninstalled
+ form, do:
+ </para>
+
+ <programlisting>
+# Building Grilo
+$ git clone git://git.gnome.org/grilo
+$ cd grilo
+$ ./autogen.sh
+$ make
+
+# Building Grilo Plugins
+$ export PKG_CONFIG_PATH=$PWD:$PKG_CONFIG_PATH
+$ cd ..
+$ git clone git://git.gnome.org/grilo-plugins
+$ cd grilo-plugins
+$ ./autogen.sh --enable-uninstalled
+$ make
+$ source ./setup-plugins-env.sh
+ </programlisting>
+
+ <para>
+ Please, notice the '--enable-uninstalled' switch passed to the autogen.sh
+ script in grilo-plugins and the PKG_CONFIG_PATH export.
+ </para>
+
+ <para>
+ The last 'source' command looks for the plugins built in the local repository
+ and exports the GRL_PLUGIN_PATH environment variable accordingly, making them
+ visible to Grilo based applications. Notice that if that if this last step
+ is ommitted Grilo based applications (like grilo-test-ui) will not
+ see any of the plugins available.
+ </para>
+ </section>
+
+ <section id="compilation-options">
+ <title>Compilation options</title>
+ <para>
+ This is a reference of the most useful compilation switches available:
+ </para>
+ <itemizedlist>
+ <listitem>
+ --enable-gtk-doc: Build documentation
+ tutorials and API reference. Check doc/ directory for
+ the generated documentation. Only in grilo core.
+ </listitem>
+ <listitem>
+ --enable-debug: Build with debug information.
+ </listitem>
+ <listitem>
+ --enable-uninstalled: Prepare for uninstalled use. Only
+ in grilo-plugins.
+ </listitem>
+ </itemizedlist>
+
+ <para>
+ For more options please run './configure --help'.
+ </para>
+ </section>
+ </section>
+
+ <section id="compiling-grilo-programs-detailed">
+ <title>Compiling Grilo based programs</title>
+
+ <para>
+ You can check how to compile Grilo based apps
+ by checking the
+ <link linkend="quick-start">Quick start guide</link>.
+ </para>
+ </section>
+
+ <section id="running-grilo-programs-detailed">
+ <title>Running Grilo based programs</title>
+
+ <para>
+ If you have installed the Grilo libraries in your system
+ make sure they have been installed in a path that is
+ included in the dynamic linker search path, otherwise
+ export the environment variable LD_LIBRARY_PATH to
+ include them, for example:
+ </para>
+
+ <programlisting>
+$ export LD_LIBRARY_PATH=/usr/local/lib
+ </programlisting>
+
+
+ <para>
+ For plugins to be visible to application they must be
+ stored in the default plugin search path. This should be
+ the case if you are not running Grilo in uninstalled form.
+ If you are running Grilo uninstalled, or for some reason
+ you have plugins available in directories other than
+ the default plugin path, export the GRL_PLUGIN_PATH to
+ point to the list of directories containing Grilo plugins,
+ for example:
+ </para>
+
+ <programlisting>
+$ export GRL_PLUGIN_PATH=/usr/local/lib/grilo-0.2
+ </programlisting>
+
+ <para>
+ Notice that if you are running Grilo uninstalled the above will not
+ be necessary if you have followed the instructions provided in this
+ documentation, since sourcing the setup-plugins-env.sh script will
+ export the variable automatically for you.
+ </para>
+ </section>
+
+ <section id="debugging-with-grilo">
+ <title>Debugging with Grilo</title>
+
+ <para>
+ If you want to debug Grilo itself, make sure you have built it with
+ --enable-debug (both the framework and the plugins).
+ </para>
+
+ <para>
+ You can also control logging by setting the environment variable GRL_DEBUG.
+ Here are some examples:
+ </para>
+
+ <programlisting>
+# Disable logging for all modules
+$ export GRL_DEBUG=*:-
+
+# Enable full logging for all modules
+$ export GRL_DEBUG=*:*
+
+# Enable logging of messages of level WARNING or higher for all modules
+$ export GRL_DEBUG=*:warning
+
+# Enable logging of messages of level INFO or higher for all modules
+$ export GRL_DEBUG=*:info
+
+# Enable full logging for the plugin registry module
+$ export GRL_DEBUG=plugin-registry:*
+
+# Enable full logging for the plugin registry module
+# and WARNING or higher for the Youtube plugin
+$ export GRL_DEBUG=plugin-registry:*,youtube:warning
+ </programlisting>
+
+ <para>
+ Programs can also control logging programatically. See the
+ <link linkend="grilo-grl-log">GrlLog</link> API reference for details.
+ </para>
+
+ <para>
+ Plugins can be ranked. Ranks can be used to sort plugins
+ by rank and also in case of conflict when two plugins offer the same
+ feature, to decide on the one to use. By default, all the plugins
+ have the same rank (0). Higher ranks give plugins more relevance /
+ priority.
+ </para>
+
+ <para>
+ Ranks can be controlled with the environment variable GRL_PLUGIN_RANKS.
+ Here is one example:
+ </para>
+
+ <programlisting>
+# Set the rank of the Youtube plugin to 5 and the Bookmarks plugin to -4
+$ export GRL_PLUGIN_RANKS=youtube:5,bookmarks:-4
+ </programlisting>
+
+ </section>
+</section>
diff --git a/doc/grilo/grilo-docs.sgml b/doc/grilo/grilo-docs.sgml
index 60c9f59..da009e2 100644
--- a/doc/grilo/grilo-docs.sgml
+++ b/doc/grilo/grilo-docs.sgml
@@ -21,16 +21,26 @@
</preface>
<reference>
- <title>Quick Start</title>
+ <title>Tutorial</title>
<chapter>
- <title>Using Grilo</title>
- <xi:include href="quick-start-using-grilo.xml"/>
+ <title>Quick start guide</title>
+ <xi:include href="quick-start.xml"/>
+ </chapter>
+
+ <chapter>
+ <title>Environment Setup</title>
+ <xi:include href="environment-setup.xml"/>
+ </chapter>
+
+ <chapter>
+ <title>Writing applications with Grilo</title>
+ <xi:include href="writing-apps.xml"/>
</chapter>
<chapter>
<title>Writing plugins for Grilo</title>
- <section id="quick-start-writing-plugins">
+ <section id="writing-plugins">
<section id="media-source-plugins">
<title>Media Source plugins</title>
<xi:include href="quick-start-plugins-media-sources.xml"/>
diff --git a/doc/grilo/quick-start.xml b/doc/grilo/quick-start.xml
new file mode 100644
index 0000000..16896f7
--- /dev/null
+++ b/doc/grilo/quick-start.xml
@@ -0,0 +1,73 @@
+<?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'">
+]>
+
+<section id="quick-start">
+
+ <para>
+ If you just want to have a go at Grilo as soon as possible this is
+ the right section for you.
+ </para>
+
+ <para>
+ This section gives basic instructions on how to download, build
+ and demo the development version of Grilo directly from the source
+ code repositories, as well as how to build programs that use
+ Grilo.
+ </para>
+
+
+ <section id="building-grilo">
+ <title>Building Grilo from sources</title>
+ <programlisting>
+# Building Grilo
+$ git clone git://git.gnome.org/grilo
+$ cd grilo
+$ ./autogen.sh --prefix=/usr
+$ make
+$ sudo make install
+
+# Building Grilo Plugins
+$ cd ..
+$ git clone git://git.gnome.org/grilo-plugins
+$ cd grilo-plugins
+$ ./autogen.sh --prefix=/usr
+$ make
+$ sudo make install
+ </programlisting>
+
+ <para>
+ You should now see the grilo libraries installed under /usr/lib and the
+ plugins for grilo installed under /usr/lib/grilo-x.y, where 'x.y' represents
+ the library version.
+ </para>
+ </section>
+
+ <section id="testing-grilo">
+ <title>Testing Grilo</title>
+ <para>After building and installing grilo and grilo-plugins, do:</para>
+ <programlisting>
+# Execute Grilo's test GUI
+$ /usr/bin/grilo-test-ui
+ </programlisting>
+
+ <para>
+ This is a simple playground application that you can use to test
+ the framework and its plugins.
+ </para>
+
+ <para>
+ Notice that grilo-test-ui is optional and will not be built unless
+ you have the GTK+ development package installed on your system.
+ </para>
+ </section>
+
+ <section id="compiling-grilo-programs">
+ <title>Compiling Grilo based programs</title>
+ <programlisting>
+gcc -o example `pkg-config --cflags --libs grilo-x.y` example.c
+ </programlisting>
+ </section>
+</section>
diff --git a/doc/grilo/writing-apps.xml b/doc/grilo/writing-apps.xml
new file mode 100644
index 0000000..b6554d6
--- /dev/null
+++ b/doc/grilo/writing-apps.xml
@@ -0,0 +1,648 @@
+<?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'">
+]>
+
+<section id="writing-apps">
+
+ <para>
+ This section intends to be a starting point for developers interested
+ in getting started witrh Grilo, and as such it does not try to be
+ a comprehensive tutorial covering all topics and features of Grilo,
+ instead, this is intends to focus on typical use case scenarios
+ and code examples to put the developer on the right track.
+ </para>
+
+ <section id="programming-with-grilo-concepts">
+ <title>Basic concepts</title>
+
+ <section id="programming-with-grilo-concepts-understanding">
+ <title>Understanding Grilo</title>
+ <para>
+ Grilo provides a high-level API that application developers
+ can use to interact with heterogeneous media providers using
+ an homogeneous language, reducing remarkably the effort required
+ to integrate media content from multiple sources.
+ </para>
+
+ <para>
+ This high-level, provider-independent API is then implemented
+ for all the providers supported by Grilo by means of plugins.
+ These plugins encapsulate all the provider-specific details,
+ effectively hiding all the technical tidbits and particularities
+ of specific media providers from application developers.
+ </para>
+
+ <para>
+ There are two kinds of plugins in Grilo:
+ <itemizedlist>
+ <listitem>Media Sources, which provide access to media content
+ that can be browsed or searched.</listitem>
+ <listitem>Metadata Sources, which provide additional metadata
+ about media content obtained through media sources.</listitem>
+ </itemizedlist>
+ </para>
+
+ <para>
+ Management of available plugins is done through the
+ <link linkend="GrlPluginRegistry">Plugin Registry</link>.
+ This object exposes API to load plugins and retrieve
+ available media source and metadata source objects.
+ </para>
+
+ <para>
+ Some plugins may require certain configuration information
+ in order to work properly. Examples of configuration information
+ that may be needed include API keys, service credentials,
+ etc. Please check the section
+ <link linkend="programming-with-grilo-configuring-plugins">
+ Configuring you plugins
+ </link>
+ for more details on this subject.
+ </para>
+
+ <para>
+ You can instruct Grilo to load all available plugins via
+ <link linkend="grl-plugin-registry-load-all">grl_plugin_registry_load_all()</link>.
+ This will look into the default
+ installation directory for the plugins and also the paths
+ included via the environment variable GRL_PLUGIN_PATH.
+ Please check section
+ <link linkend="running-grilo-programs-detailed">
+ Running Grilo based programs
+ </link>
+ for more details on this subject.
+ </para>
+
+ <para>
+ Users can also load plugins using their plugin
+ identifiers. These plugin identifier strings
+ can be obtained by running the tool 'grl-inspect'.
+ </para>
+
+ <para>
+ Users have two options to gain access to the media source and
+ metadata source objects loaded by the plugin registry:
+ </para>
+
+ <itemizedlist>
+ <listitem>
+ Call
+ <link linkend="grl-plugin-registry-get-sources">
+ grl_plugin_registry_get_sources*
+ </link> or
+ <link linkend="grl-plugin-registry-lookup-source">
+ grl_plugin_registry_lookup_source
+ </link>. These should be used
+ when plugins have already been loaded.
+ </listitem>
+ <listitem>
+ By connecting to the
+ <link linkend="GrlPluginRegistry-source-added">source-added</link>
+ signal, that is emitted whenever a new media source or metadata
+ source object is found.
+ </listitem>
+ </itemizedlist>
+
+ <para>
+ For more information on how to use the plugin registry, please
+ check <link linkend="GrlPluginRegistry">its API reference</link>
+ or any of the code examples below.
+ </para>
+
+ <para>
+ Media source and metadata source objects are the objects
+ application developers will be interacting with for most
+ of their Grilo work. These objects provide developers
+ with a well known interface (API) to interact with
+ media content that is provider-independent. Typically,
+ each media source object provides access to content
+ delivered by one particular media provider.
+ </para>
+
+ </section>
+
+ <section id="programming-with-grilo-media-sources">
+
+ <title>Media Sources</title>
+
+ <para>
+ Media Source objects provide access to media content. Application
+ developers would usually interact with these objects issuing
+ Browse, Search or Query operations on them. The purpose of
+ these operations is explained below:
+ </para>
+
+ <itemizedlist>
+ <listitem>
+ <emphasis>Search.</emphasis>
+ Instructs the media source to look for media matching
+ specific keywords. Example: YouTube search.
+ </listitem>
+ <listitem>
+ <emphasis>Browse:.</emphasis>
+ Navigates through a hierarchy of content exposed by the
+ media provider. Example: Filesystem browsing.
+ </listitem>
+ <listitem>
+ <emphasis>Query:</emphasis>
+ An advanced search mode that uses service-specific
+ commands to exploit features specific to a particular
+ media provider.
+ </listitem>
+ <listitem>
+ <emphasis>Metadata</emphasis>
+ Obtain (more) metadata information for a particular media resource.
+ </listitem>
+ <listitem>
+ <emphasis>Store and Remove</emphasis>
+ Push and remove content from the media provider.
+ </listitem>
+ </itemizedlist>
+ </section>
+
+ <section id="programming-with-grilo-metadata-sources">
+
+ <title>Metadata Sources</title>
+
+ <para>
+ Metadata Source objects provide means to acquire additional
+ metadata that was not provided by the original media source
+ that delivered the media. Application developers would usually
+ interact with metadata sources via Resolve or SetMetadata
+ operations, which are described below:
+ </para>
+
+ <itemizedlist>
+ <listitem>
+ <emphasis>Resolve:</emphasis>
+ Acquire additional metadata for a particular media resource.
+ </listitem>
+ <listitem>
+ <emphasis>SetMetadata:</emphasis>
+ Update metadata information available for a particular media resouce.
+ </listitem>
+ </itemizedlist>
+
+ </section>
+
+ <section id="programming-with-grilo-async-apis">
+
+ <title>Asynchronous APIs</title>
+
+ <para>
+ Most of the APIs exposed by Media Source and Metadata Source
+ objects are asynchronous. The reason for this is that
+ these operations usually involve I/O which
+ would block the user interface if executed synchronously,
+ specially for the more heavy operations like Browse or
+ Search, leading to unresponsive GUIs and bad user
+ experience.
+ </para>
+
+ <para>
+ For this reason, most of the APIs in Grilo accept a
+ user callback and user data parameters that are used
+ to hand over the result of the operation to the
+ client asynchronously.
+ </para>
+
+ <para>
+ In cases where asychrony is not needed, for example
+ for programs that do not have a graphical user
+ interface and are designed to run in the background,
+ Grilo also provides synchronous versions of some of
+ the APIs, but for situations other than this, use of
+ the asynchronous APIs is <emphasis>strongly</emphasis>
+ encouraged.
+ </para>
+
+ <para>
+ For operations that can produce multiple results,
+ like Browse, Search or Query, callbacks are
+ involked once per matching result. For operations
+ that are expected to produce a single result, like
+ Metadata or Resolve, callbacks are invoked just
+ once.
+ </para>
+
+ <para>
+ In any case, clients should always expect the result
+ callback to be invoked at least once after an
+ asynchronous operation has been issued, even if the
+ operation fails or is cancelled (in which case the
+ error parameter of the callback will be set to a
+ non-NULL value).
+ </para>
+
+ </section>
+
+ <section id="programming-with-grilo-operation-identifiers">
+
+ <title>Operation identifiers</title>
+
+ <para>
+ Some Media Source and Metadata Source operations will return
+ an operation identifier that serves varios purposes:
+ </para>
+
+ <itemizedlist>
+ <listitem>Identify the operation within the framework.</listitem>
+ <listitem>Match asynchronously results with the issuing operations.</listitem>
+ <listitem>Provide an operation identifier that can be used to cancel the operation.</listitem>
+ </itemizedlist>
+
+ <para>
+ For example, issuing an asycnronous Search operation on a Media
+ Source object would synchrnously return an operation identifier.
+ The developer can store this identifier and use it to cancel.
+ </para>
+
+ <para>
+ Also, if the operation was not cancelled, the results callback
+ will be invoked at least once (actually, for the case
+ of a Browse operation is will be invoked once per matching
+ result) handing the results of the operation to the application.
+ Each time the resuls calback is involked, the operation identifier
+ will be provided so that the callback can identify the operation
+ that triggered the result (there can be multiple operations
+ ongoing simultaneously).
+ </para>
+
+ </section>
+
+ <section id="programmaing-with-grilo-media-objects">
+
+ <title>Media objects</title>
+
+ <para>
+ As discusssed before, Media Source objects provide means
+ to access media content exposed by media providers through
+ operations like Search, Browse or Query. Media content is
+ represented in Grilo via
+ <link linkend="GrlMedia">GrlMedia</link>
+ objects that contain metadata information related with
+ a particular media resource.
+ </para>
+
+ <para>
+ There are various subclasses of GrlMedia, which provide
+ specific APIs to get and set metadata associated with
+ specific media types, like video, audio or image
+ resources.
+ </para>
+
+ <para>
+ Typically, these GrlMedia objects will be obtained by
+ issuing Search, Browse or Query operations on Media
+ Source objects, which produce these objects
+ as results. Upon reception, clients would
+ usually use the API exposed by these objects to
+ collect the information of interest.
+ </para>
+
+ <para>
+ Grilo also supports the concept of media container,
+ represented by the GrlMediaBox subclass. These objects
+ represent categories or forlders that contain other
+ media objects (including maybe more GrlMediaBox objects),
+ allowing tree-like hierarchies of content, like the ones
+ would usually traverse during Browse operations.
+ </para>
+
+ <para>
+ Please, check the <link linkend="GrlMedia">GrlMedia</link>
+ API reference for more information on this subject.
+ </para>
+
+ </section>
+
+ <section>
+
+ <title>Metadata keys</title>
+
+ <para>
+ Metadata keys identify pieces of information (metadata).
+ They are often an input parameter for many operations
+ in Grilo, with the purpose of specifying what pieces of
+ information are relevant for a particular operations.
+ </para>
+
+ <para>
+ Grilo has a list of predefined supported keys. For each
+ of these keys, Grilo provides definitions
+ (identifiers) that clients can use to refer to
+ specific pieces of information. Some
+ examples are GRL_METADATA_KEY_TITLE or
+ GRL_METADATA_KEY_ARTIST.
+ </para>
+
+ <para>
+ For a complete list of all System Keys, please check
+ <link linkend="grilo-grl-metadata-key">grl-metadata-key.h</link>.
+ </para>
+
+ <para>
+ Some plugins can also introduce additional metadata
+ keys known as User Keys. The difference with the System
+ Keys is that these do not have definitions available, and
+ hence clients must query the plugin registry to know
+ their identifiers first using
+ <link linkend="grl-plugin-registry-lookup-metadata-key">
+ grl_plugin_registry_lookup_metadata_key
+ </link>.
+ </para>
+
+ </section>
+ </section>
+
+ <section id="programming-with-grilo-use-cases-explained">
+
+ <title>Typical use cases explained</title>
+
+ <para>
+ The following sections will guide the reader through some
+ of the typical use cases of Grilo, using code examples
+ to make the ideas even more clear.
+ </para>
+
+ <section id="programming-with-grilo-configuring-plugins">
+
+ <title>Configuring your plugins</title>
+
+ <para>For some plugins to work properly, it is required that the user (or
+ application developer) provides certain configuration. For example,
+ some plugins may require a username and a password, others may
+ require an API token to gain access to the underlying media provider.
+ </para>
+ <para>
+ These configuration options could be mandatory (without them
+ the plugin cannot operate and will fail to load), or
+ optional, in which case they are intended to allow users to tweak
+ certain aspects of how a particular plugin should work.
+ </para>
+ <para>
+ An example of a mandatory configuration is in the Youtube plugin: in order
+ for it to work a valid API key must be provided. It is the responsibility
+ of the user (or the application developer) to get that key (usually
+ registering in Youtube and applying for an application key) and provide
+ it to the plugin.
+ </para>
+ <para>
+ In order to know what confirguration options are available for a certain
+ plugin, users/developers must check the plugin documentation.
+ </para>
+ <para>
+ Here is a small program illustrating how to configure a plugin form your
+ application:
+ </para>
+ <programlisting role="C">
+ <xi:include href="../../examples/configuring-plugins.c"
+ parse="text"
+ xmlns:xi="http://www.w3.org/2001/XInclude"/>
+ </programlisting>
+
+ <para>
+ For more information on how to configure plugins
+ plase check the
+ <link linkend="GrlConfig">GrlConfig</link>
+ API reference.
+ </para>
+ </section>
+
+ <section id="programming-with-grilo-browsing">
+
+ <title>Browsing media content</title>
+
+ <para>Here is a small program illustrating how you can browse
+ content from a particular media source (a similar approach
+ can be used for searching content instead of browsing):</para>
+ <programlisting role="C">
+ <xi:include href="../../examples/browsing.c"
+ parse="text"
+ xmlns:xi="http://www.w3.org/2001/XInclude"/>
+ </programlisting>
+
+ <para>
+ Please notice:
+ <itemizedlist>
+ <listitem>
+ Finalization of the Browse operation is always
+ indicated by setting the 'remaining' parameter to 0.
+ </listitem>
+ <listitem>
+ The user callback used to receive the results is
+ guaranteed to be invoked at least once (with remaining
+ set to 0), even if the operation fails or is cancelled
+ (in these cases the error parameter will be set to a
+ non-NULL value).
+ </listitem>
+ <listitem>
+ Received GrlMedia objects are owned by the application
+ and must be freed when no longer needed.
+ </listitem>
+ <listitem>
+ If an error occurs, the GError parameter is set in the
+ callback, but this error parameter is owned by Grilo
+ nad will be freed inmediately after the callback.
+ If you want to keep the error beyond the scope of
+ the callback you must add a reference to it in the
+ callback code.
+ </listitem>
+ <listitem>
+ When the media source cannot estimate the number
+ of remaining items, reamining is set to
+ GRL_SOURCE_REMAINING_UNKNOWN.
+ </listitem>
+ </itemizedlist>
+ </para>
+
+ <para>
+ For more information on how to operate media sources
+ plase check the
+ <link linkend="GrlMediaSource">GrlMediaSource</link>
+ API reference.
+ </para>
+ </section>
+
+ <section id="programming-with-grilo-searching">
+
+ <title>Searching media content</title>
+
+ <para>Here is a small program illustrating how you can search
+ content by text from a particular media source (Jamendo
+ in this example):</para>
+ <programlisting role="C">
+ <xi:include href="../../examples/searching.c"
+ parse="text"
+ xmlns:xi="http://www.w3.org/2001/XInclude"/>
+ </programlisting>
+
+ <para>
+ Please notice that all the considerations remarked for the
+ Browse operations above apply also to Search operations.
+ </para>
+
+ <para>
+ For more information on how to operate media sources
+ plase check the
+ <link linkend="GrlMediaSource">GrlMediaSource</link>
+ API reference.
+ </para>
+ </section>
+
+ <section id="programming-with-grilo-multivalued-data">
+
+ <title>Handling multi-valued metadata</title>
+
+ <para>When working with multimedia content, it can happen that certain
+ attributes of a particular media resouce are multi-valued. For example,
+ a particular video resorce may have multiple URIs associated, considering
+ different resolutions, streaming protocols and/or formats.
+ </para>
+ <para>
+ Grilo provides plugin and application developers with means
+ to handle multi-valued properties.
+ </para>
+ <para>
+ One issue concerning multi-valued properties are their relations with
+ other properties. Following the example of the video resource with
+ multiple URIs, each of these URIs should have its own mime-type associated,
+ as well as its own width and height values. When dealing with multi-valued
+ properties it is necessary to make this relations among keys more explicit.
+ </para>
+ <para>
+ Grilo provides application and plugin developers with a high-level APIs to
+ handle certain relations among keys consistently. Continuing with the example
+ of the video resource with multiple URIs, there is
+ <link linkend="grl-media-video-add-url-data">
+ grl_media_video_add_url_data
+ </link> and
+ <link linkend="grl-media-video-add-url-data-nth">
+ grl_media_video_get_url_data_nth
+ </link> to add and retrieve all the metadata
+ associated with a particular instance of the video resource (URI, mime-type,
+ framerate, width and height, etc) in one go.
+ </para>
+ <para>
+ Grilo allows plugin developers to define their own metadata keys.
+ In this case, the plugin developer must also provide information
+ on the relations that these keys hold with others. In this scenario
+ plugin developers must use GrlRelatedKeys objects to group related keys
+ together.
+ </para>
+ <para>
+ Here is a small program illustrating how get all available URLs from
+ a video resource, as well the corresponding MIME value for each one.
+ We use GrlRelatedKeys instead of the high-level API from GrlMediaVideo
+ to illustrate how to use it:
+ </para>
+ <programlisting role="C">
+ <xi:include href="../../examples/multivalues.c"
+ parse="text"
+ xmlns:xi="http://www.w3.org/2001/XInclude"/>
+ </programlisting>
+
+ <para>
+ For more information on how to operate with media objects
+ plase check the
+ <link linkend="GrlData">GrlData</link> hierarchy
+ API reference.
+ </para>
+ </section>
+
+ <section id="programming-with-grilo-efficient-metadata-resolution">
+
+ <title>Efficient metadata resolution</title>
+
+ <para>When executing operations that return lists of media items (like
+ Browse or Search) it is convenient to ensure that we do not
+ request metadata that could slow down the operation unless it
+ is really necessary.
+ </para>
+ <para>
+ A clear example of this situation is the way Youtube video
+ URLs are resolved: a browse operation on Youtube can usually
+ be resolved in a single HTTP query, however, if one wants to
+ obtain the URLs of the videos then for each video in the result
+ set another HTTP request is needed. This would slow down
+ the browse operation remarkably and would spam Youtube
+ with requests to obtain URLs that may not be ever needed.
+ Indeed, a normal player would browse a list of videos and show
+ information useful for the user to select the one he/she is
+ interested in (title, duration, artist, etc), the URL is not
+ interesting at this stage, it is only interesting when the user
+ selected a video to play, and we would be interested only
+ in that single URL and not in all the URLs of the videos
+ we are displaying.
+ </para>
+ <para>
+ Grilo provides methods to application developers to query
+ the keys (if any) that may have an impact on the performance
+ for a particular source (like the URL in the case of Youtube),
+ but it is usually easier to just use the GRL_RESOLVE_FAST_ONLY
+ flag when issuing Search, Browse or Query operations.
+ </para>
+ <para>
+ By using this flag, Grilo will resolve only the keys
+ that do not have an impact on performance. If you browse
+ Youtube with this flag Grilo won't request the URL key
+ to the Youtube source. However, if the source could resolve
+ the URL without performance penalties, it would do so
+ normally.
+ </para>
+ <para>
+ Usually, for operations like Browse or Search that operate
+ with large result sets it is recommended to use
+ GRL_RESOLVE_FAST_ONLY. If you really need to get the metadata
+ you requested for a specific item (for example if you want to
+ play a video from Youtube you really need the URL), then
+ you can safely use the Metadata operation without the
+ GRL_RESOLVE_FAST_ONLY flag, wich would only operate on this
+ particular item, reducing the performance penalty and providing
+ a more efficient solution.
+ </para>
+ <para>
+ The program below demonstrates how this works, it accepts as
+ argument the id of the source we want to operate with, when the
+ source is registered it will issue a search operation requesting
+ only fast keys. When the search callback is invoked we will print
+ both the title information and the URL of the first media
+ that matched the search text.
+ </para>
+ <para>
+ If we run the program using grl-jamendo as target source, we will
+ see that it retrieves both the title and the URL of the media
+ immediately, however, if we use grl-youtube, it won't and in order
+ to obtain the URL we issue a new Metadata operation, this time
+ without the GRL_RESOLVE_FAST_ONLY flag.
+ </para>
+ <para>
+ Of course this is a very simple example, in a real application the way
+ this would work is that we would request the URL in a
+ Browse/Search that could return hundreds of results
+ and we may or may not get the URLs depending on the source
+ we are operating with, but in any case we will ensure the operation
+ will run as fast as possible: the user will see the results
+ of the search fast. Then, when the user selects
+ a media item to be played from that result set we would check if
+ we have the URL already (and we will have the URL ready if the source
+ could resolve it fast) in which case we can play the media right away (no
+ time penalty at all from the user point of view). If the URL could not
+ be resolved because it was slow for the source (like in the case of Youtube)
+ then we just have to issue a Metadata operation requesting the URL,
+ but that won't be too bad because we are requesting it only
+ for the item that the user selected, so from the user's perspective
+ the playback will take slightly more to start but would still
+ be an acceptable delay.
+ </para>
+ <programlisting role="C">
+ <xi:include href="../../examples/efficient-metadata-resolution.c"
+ parse="text"
+ xmlns:xi="http://www.w3.org/2001/XInclude"/>
+ </programlisting>
+ </section>
+
+ </section>
+</section>
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]