[tracker/writeback: 10/16] Added filter for the list of rdf:type being passed vs. module to elect



commit 2c7e74df5cda82273a80a590b18500c40711e420
Author: Philip Van Hoof <philip codeminded be>
Date:   Tue Nov 17 12:11:45 2009 +0100

    Added filter for the list of rdf:type being passed vs. module to elect

 .../tracker-writeback-dispatcher.c                 |   45 +++++++++++++++----
 src/tracker-writeback/tracker-writeback-module.c   |   10 ++++-
 src/tracker-writeback/tracker-writeback-module.h   |    4 +-
 src/tracker-writeback/tracker-writeback-mp3.c      |   37 +++++++++++++---
 src/tracker-writeback/tracker-writeback.h          |    2 +-
 5 files changed, 78 insertions(+), 20 deletions(-)
---
diff --git a/src/tracker-writeback/tracker-writeback-dispatcher.c b/src/tracker-writeback/tracker-writeback-dispatcher.c
index dc3a399..a107c0b 100644
--- a/src/tracker-writeback/tracker-writeback-dispatcher.c
+++ b/src/tracker-writeback/tracker-writeback-dispatcher.c
@@ -40,6 +40,7 @@ typedef struct {
 
 typedef struct {
 	TrackerWritebackDispatcher *dispatcher;
+	GStrv rdf_types;
 } QueryData;
 
 #define TRACKER_WRITEBACK_DISPATCHER_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), TRACKER_TYPE_WRITEBACK_DISPATCHER, TrackerWritebackDispatcherPrivate))
@@ -253,6 +254,24 @@ tracker_writeback_dispatcher_new ()
 	return g_object_new (TRACKER_TYPE_WRITEBACK_DISPATCHER, NULL);
 }
 
+static gboolean
+types_match (const gchar **module_types, gchar **rdf_types)
+{
+	guint n;
+
+	for (n = 0; rdf_types[n] != NULL; n++) {
+		guint i;
+
+		for (i = 0; module_types[i] != NULL; i++) {
+			if (g_strcmp0 (module_types[i], rdf_types[n]) == 0) {
+				return TRUE;
+			}
+		}
+	}
+
+	return FALSE;
+}
+
 static void
 on_sparql_result_received (GPtrArray *result,
                            GError    *error,
@@ -260,28 +279,34 @@ on_sparql_result_received (GPtrArray *result,
 {
 	TrackerWritebackDispatcherPrivate *priv;
 	TrackerWritebackModule *module;
-	TrackerWriteback *writeback;
 	GHashTableIter iter;
 	gpointer key, value;
 	QueryData *data;
+	const gchar **module_types;
+	gchar **rdf_types;
 
 	data = user_data;
+	rdf_types = data->rdf_types;
 	priv = TRACKER_WRITEBACK_DISPATCHER_GET_PRIVATE (data->dispatcher);
 
-	/* FIXME: Lookup module by mimetype */
 	g_hash_table_iter_init (&iter, priv->modules);
 
-	if (!g_hash_table_iter_next (&iter, &key, &value)) {
-		return;
-	}
+	while (g_hash_table_iter_next (&iter, &key, &value)) {
+		module = value;
 
-	module = value;
-	writeback = tracker_writeback_module_create (module);
+		module_types = tracker_writeback_module_get_rdftypes (module);
 
-	tracker_writeback_update_metadata (writeback, result);
+		if (types_match (module_types, rdf_types)) {
+			TrackerWriteback *writeback;
 
-	g_object_unref (writeback);
+			writeback = tracker_writeback_module_create (module);
+			tracker_writeback_update_metadata (writeback, result);
+			g_object_unref (writeback);
+		}
 
+	}
+
+	g_strfreev (data->rdf_types);
 	g_slice_free (QueryData, data);
 }
 
@@ -292,7 +317,6 @@ on_writeback_cb (DBusGProxy                 *proxy,
 {
 	TrackerWritebackDispatcherPrivate *priv;
 	QueryData *data;
-	guint n;
 	GHashTableIter iter;
 	gpointer key, value;
 
@@ -313,6 +337,7 @@ on_writeback_cb (DBusGProxy                 *proxy,
 
 		data = g_slice_new (QueryData);
 		data->dispatcher = object;
+		data->rdf_types = g_strdupv (rdf_types);
 
 		tracker_resources_sparql_query_async (priv->client,
 		                                      query,
diff --git a/src/tracker-writeback/tracker-writeback-module.c b/src/tracker-writeback/tracker-writeback-module.c
index 22d4cdf..ee21b08 100644
--- a/src/tracker-writeback/tracker-writeback-module.c
+++ b/src/tracker-writeback/tracker-writeback-module.c
@@ -67,8 +67,8 @@ tracker_writeback_module_load (GTypeModule *module)
 
 	if (!g_module_symbol (writeback_module->module, "writeback_module_create",
 			      (gpointer *) &writeback_module->create) ||
-	    !g_module_symbol (writeback_module->module, "writeback_module_get_mimetypes",
-			      (gpointer *) &writeback_module->get_mimetypes)) {
+	    !g_module_symbol (writeback_module->module, "writeback_module_get_rdftypes",
+			      (gpointer *) &writeback_module->get_rdftypes)) {
 		g_warning ("Could not load module symbols for '%s': %s",
 			   writeback_module->name,
 			   g_module_error ());
@@ -153,3 +153,9 @@ tracker_writeback_module_create (TrackerWritebackModule *module)
 {
         return (module->create) (G_TYPE_MODULE (module));
 }
+
+const gchar**
+tracker_writeback_module_get_rdftypes (TrackerWritebackModule *module)
+{
+        return (module->get_rdftypes) ();
+}
diff --git a/src/tracker-writeback/tracker-writeback-module.h b/src/tracker-writeback/tracker-writeback-module.h
index 84796f0..7f40ec0 100644
--- a/src/tracker-writeback/tracker-writeback-module.h
+++ b/src/tracker-writeback/tracker-writeback-module.h
@@ -41,7 +41,7 @@ struct TrackerWritebackModule {
 	gchar *name;
 
         TrackerWriteback * (* create)        (GTypeModule *module);
-        GStrv              (* get_mimetypes) (void);
+        const gchar **     (* get_rdftypes)  (void);
 };
 
 struct TrackerWritebackModuleClass {
@@ -54,6 +54,8 @@ GType                     tracker_writeback_module_get_type               (void)
 TrackerWritebackModule *  tracker_writeback_module_get                    (const gchar *name);
 
 TrackerWriteback *        tracker_writeback_module_create                 (TrackerWritebackModule *module);
+const gchar**             tracker_writeback_module_get_rdftypes           (TrackerWritebackModule *module);
+
 GList *                   tracker_writeback_modules_list                  (void);
 
 
diff --git a/src/tracker-writeback/tracker-writeback-mp3.c b/src/tracker-writeback/tracker-writeback-mp3.c
index 6bb78e7..ef4cb03 100644
--- a/src/tracker-writeback/tracker-writeback-mp3.c
+++ b/src/tracker-writeback/tracker-writeback-mp3.c
@@ -65,7 +65,7 @@ tracker_writeback_mp3_init (TrackerWritebackMP3 *mp3)
 
 static gboolean
 tracker_writeback_mp3_update_metadata (TrackerWriteback *writeback,
-                                         GPtrArray        *values)
+                                       GPtrArray        *values)
 {
 	guint n;
 	const gchar *uri = NULL;
@@ -76,9 +76,32 @@ tracker_writeback_mp3_update_metadata (TrackerWriteback *writeback,
 		const GStrv row = g_ptr_array_index (values, n);
 
 		if (uri == NULL) {
+			GFileInfo *file_info;
+			const gchar *mime_type;
+
 			uri = row[0];
 			file = g_file_new_for_uri (uri);
-			path = g_file_get_path (file);
+
+			file_info = g_file_query_info (file, G_FILE_ATTRIBUTE_STANDARD_CONTENT_TYPE,
+			                               G_FILE_QUERY_INFO_NOFOLLOW_SYMLINKS,
+			                               NULL, NULL);
+
+			if (!file_info) {
+				g_object_unref (file);
+				return FALSE;
+			}
+
+			mime_type = g_file_info_get_content_type (file_info);
+
+			if (g_strcmp0 (mime_type, "audio/mpeg") == 0 ||
+			    g_strcmp0 (mime_type, "audio/x-mp3") == 0) {
+				g_object_unref (file_info);
+				path = g_file_get_path (file);
+			} else {
+				g_object_unref (file);
+				g_object_unref (file_info);
+				return FALSE;
+			}
 		}
 
 		if (g_strcmp0 (row[1], TRACKER_NIE_PREFIX "title") == 0) {
@@ -123,10 +146,12 @@ writeback_module_create (GTypeModule *module)
 	return g_object_new (TRACKER_TYPE_WRITEBACK_MP3, NULL);
 }
 
-const GStrv
-writeback_module_get_mimetypes (void)
+const gchar**
+writeback_module_get_rdftypes (void)
 {
-	static const gchar *mimetypes[] = { "*", NULL };
+	static const gchar *rdftypes[] = { TRACKER_NFO_PREFIX "Document",
+	                                   TRACKER_NMM_PREFIX "MusicPiece",
+	                                   NULL };
 
-	return (GStrv) mimetypes;
+	return rdftypes;
 }
diff --git a/src/tracker-writeback/tracker-writeback.h b/src/tracker-writeback/tracker-writeback.h
index ab3bd53..e971b39 100644
--- a/src/tracker-writeback/tracker-writeback.h
+++ b/src/tracker-writeback/tracker-writeback.h
@@ -51,7 +51,7 @@ GType          tracker_writeback_get_type (void) G_GNUC_CONST;
 
 /* Entry functions to be defined by modules */
 TrackerWriteback * writeback_module_create        (GTypeModule *module);
-const GStrv        writeback_module_get_mimetypes (void);
+const gchar**      writeback_module_get_rdftypes  (void);
 
 gboolean tracker_writeback_update_metadata (TrackerWriteback *writeback,
                                             GPtrArray        *values);



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]