[grilo] core: use GrlOperationOptions in grl_metadata_source_resolve()
- From: Guillaume JÃrÃme Emont <guijemont src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [grilo] core: use GrlOperationOptions in grl_metadata_source_resolve()
- Date: Wed, 14 Dec 2011 13:57:00 +0000 (UTC)
commit 75b14e03b343bc34e49294fded38e9bdea6fe002
Author: Guillaume Emont <gemont igalia com>
Date: Wed Apr 6 17:00:38 2011 +0200
core: use GrlOperationOptions in grl_metadata_source_resolve()
src/grl-metadata-source.c | 18 ++++++++++--------
src/grl-metadata-source.h | 6 +++---
2 files changed, 13 insertions(+), 11 deletions(-)
---
diff --git a/src/grl-metadata-source.c b/src/grl-metadata-source.c
index a28291c..63aa8bb 100644
--- a/src/grl-metadata-source.c
+++ b/src/grl-metadata-source.c
@@ -383,6 +383,7 @@ resolve_result_relay_cb (GrlMetadataSource *source,
g_object_unref (rrc->spec->source);
g_object_unref (rrc->spec->media);
+ g_object_unref (rrc->spec->options);
g_list_free (rrc->spec->keys);
g_free (rrc->spec);
g_free (rrc);
@@ -850,8 +851,7 @@ grl_metadata_source_may_resolve (GrlMetadataSource *source,
* @keys: (element-type GrlKeyID) (allow-none): the #GList
* of #GrlKeyID to retrieve
* @media: Transfer object where all the metadata is stored.
- * @flags: bitwise mask of #GrlMetadataResolutionFlags with the resolution
- * strategy
+ * @options: options to pass to this operation
* @callback: (scope notified): the callback to execute when the @media metadata is filled up
* @user_data: user data set for the @callback
*
@@ -868,7 +868,7 @@ guint
grl_metadata_source_resolve (GrlMetadataSource *source,
const GList *keys,
GrlMedia *media,
- GrlMetadataResolutionFlags flags,
+ GrlOperationOptions *options,
GrlMetadataSourceResolveCb callback,
gpointer user_data)
{
@@ -876,6 +876,7 @@ grl_metadata_source_resolve (GrlMetadataSource *source,
GList *_keys;
struct ResolveRelayCb *rrc;
guint resolve_id;
+ GrlMetadataResolutionFlags flags;
GRL_DEBUG ("grl_metadata_source_resolve");
@@ -887,6 +888,8 @@ grl_metadata_source_resolve (GrlMetadataSource *source,
_keys = g_list_copy ((GList *) keys);
+ flags = grl_operation_options_get_flags (options);
+
if (flags & GRL_RESOLVE_FAST_ONLY) {
grl_metadata_source_filter_slow (source, &_keys, FALSE);
}
@@ -905,7 +908,7 @@ grl_metadata_source_resolve (GrlMetadataSource *source,
rs->resolve_id = resolve_id;
rs->keys = _keys;
rs->media = g_object_ref (media);
- rs->flags = flags;
+ rs->options = g_object_ref (options);
rs->callback = resolve_result_relay_cb;
rs->user_data = rrc;
@@ -929,8 +932,7 @@ grl_metadata_source_resolve (GrlMetadataSource *source,
* @keys: (element-type GrlKeyID) (allow-none): the #GList
* of #GrlKeyID to retrieve
* @media: Transfer object where all the metadata is stored
- * @flags: bitwise mask of #GrlMetadataResolutionFlags with the resolution
- * strategy
+ * @options: options to pass to this operation
* @error: a #GError, or @NULL
*
* This is the main method of the #GrlMetadataSource class. It will fetch the
@@ -946,7 +948,7 @@ GrlMedia *
grl_metadata_source_resolve_sync (GrlMetadataSource *source,
const GList *keys,
GrlMedia *media,
- GrlMetadataResolutionFlags flags,
+ GrlOperationOptions *options,
GError **error)
{
GrlDataSync *ds;
@@ -956,7 +958,7 @@ grl_metadata_source_resolve_sync (GrlMetadataSource *source,
grl_metadata_source_resolve (source,
keys,
media,
- flags,
+ options,
resolve_result_async_cb,
ds);
diff --git a/src/grl-metadata-source.h b/src/grl-metadata-source.h
index a0505d7..37764fe 100644
--- a/src/grl-metadata-source.h
+++ b/src/grl-metadata-source.h
@@ -148,7 +148,7 @@ typedef struct {
guint resolve_id;
GList *keys;
GrlMedia *media;
- GrlMetadataResolutionFlags flags;
+ GrlOperationOptions *options;
GrlMetadataSourceResolveCb callback;
gpointer user_data;
@@ -300,14 +300,14 @@ gboolean grl_metadata_source_may_resolve (GrlMetadataSource *source,
guint grl_metadata_source_resolve (GrlMetadataSource *source,
const GList *keys,
GrlMedia *media,
- GrlMetadataResolutionFlags flags,
+ GrlOperationOptions *options,
GrlMetadataSourceResolveCb callback,
gpointer user_data);
GrlMedia *grl_metadata_source_resolve_sync (GrlMetadataSource *source,
const GList *keys,
GrlMedia *media,
- GrlMetadataResolutionFlags flags,
+ GrlOperationOptions *options,
GError **error);
void grl_metadata_source_set_metadata (GrlMetadataSource *source,
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]