[tracker/libtracker-sparql-porting] tracker-miner-flickr: Added refactored writeback code on libtracker-client



commit 078da8e793b69b1500159008c3b98d898b8c7b11
Author: Martyn Russell <martyn lanedo com>
Date:   Mon Aug 16 15:56:34 2010 +0100

    tracker-miner-flickr: Added refactored writeback code on libtracker-client
    
    libtracker-sparql doesn't have support for this because it is quite a
    specific use case right now

 src/miners/flickr/Makefile.am               |    3 +-
 src/miners/flickr/tracker-miner-flickr.vala |   15 ++-
 src/miners/flickr/tracker-writeback.c       |  156 +++++++++++++++++++++++++++
 3 files changed, 169 insertions(+), 5 deletions(-)
---
diff --git a/src/miners/flickr/Makefile.am b/src/miners/flickr/Makefile.am
index 4c5d5bb..a238dfc 100644
--- a/src/miners/flickr/Makefile.am
+++ b/src/miners/flickr/Makefile.am
@@ -32,7 +32,8 @@ tracker_miner_flickr_VALASOURCES =					\
 
 tracker_miner_flickr_SOURCES =						\
 	tracker-miner-flickr.vala.stamp                                 \
-	$(tracker_miner_flickr_VALASOURCES:.vala=.c)
+	$(tracker_miner_flickr_VALASOURCES:.vala=.c)			\
+	tracker-writeback.c
 
 tracker_miner_flickr_LDADD =						\
 	$(top_builddir)/src/libtracker-miner/libtracker-miner- TRACKER_API_VERSION@.la \
diff --git a/src/miners/flickr/tracker-miner-flickr.vala b/src/miners/flickr/tracker-miner-flickr.vala
index 45df0ab..4a470f7 100644
--- a/src/miners/flickr/tracker-miner-flickr.vala
+++ b/src/miners/flickr/tracker-miner-flickr.vala
@@ -17,6 +17,14 @@
  * Boston, MA  02110-1301, USA.
  */
 
+public delegate void TrackerWritebackCallback (HashTable<string,void*> resources);
+
+public extern void  tracker_writeback_init       ();
+public extern void  tracker_writeback_shutdown   ();
+public extern uint  tracker_writeback_connect    (TrackerWritebackCallback callback,
+												  void                    *user_data);
+public extern void  tracker_writeback_disconnect (uint                     handle);
+
 namespace Tracker {
 
 private errordomain RestCallError {
@@ -85,8 +93,8 @@ public class MinerFlickr : Tracker.MinerWeb {
 
 		rest = new Rest.Proxy (FLICKR_REST_URL, false);
 
-		// FIXME: Add support for this, it won't be in libtracker-sparql though.
-		// tracker_client.writeback_connect (writeback);
+		tracker_writeback_init ();
+		tracker_writeback_connect (writeback, null);
 
 		init_datasource ();
 
@@ -94,6 +102,7 @@ public class MinerFlickr : Tracker.MinerWeb {
 	}
 
 	public void shutdown () {
+		tracker_writeback_shutdown ();
 		status = "Shutting down";
 		associated = false;
 	}
@@ -783,8 +792,6 @@ public class MinerFlickr : Tracker.MinerWeb {
 		} catch (Error tracker_error) {
 			throw tracker_error;
 		}
-
-		return null;
 	}
 
 	public void update_triple_string (Tracker.Sparql.Builder builder, string graph, string urn, string property, string new_value) {
diff --git a/src/miners/flickr/tracker-writeback.c b/src/miners/flickr/tracker-writeback.c
new file mode 100644
index 0000000..befffe0
--- /dev/null
+++ b/src/miners/flickr/tracker-writeback.c
@@ -0,0 +1,156 @@
+/*
+ * Copyright (C) 2010, Nokia <ivan frade nokia com>
+ * Copyright (C) 2010, Codeminded BVBA <abustany gnome org>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the
+ * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ * Boston, MA  02110-1301, USA.
+ */
+
+#include "config.h"
+
+#include <libtracker-common/tracker-common.h>
+#include <libtracker-sparql/tracker-sparql.h>
+
+#include "tracker-writeback.h"
+
+typedef struct {
+	guint id;
+	TrackerWritebackCallback func;
+	gpointer data;
+} WritebackCallback;
+
+static DBusGConnection *connection;
+static DBusGProxy *proxy_resources;
+static GList *writeback_callbacks;
+static guint writeback_callback_id;
+
+static void
+writeback_cb (DBusGProxy       *proxy,
+              const GHashTable *resources,
+              gpointer          user_data)
+{
+	WritebackCallback *cb;
+	GList *l;
+
+	g_return_if_fail (resources != NULL);
+
+	for (l = writeback_callbacks; l; l = l->next) {
+		cb = l->data;
+		cb->func (resources, cb->data);
+	}
+}
+
+void
+tracker_writeback_init (void)
+{
+	GError *error = NULL;
+
+	connection = dbus_g_bus_get (DBUS_BUS_SESSION, &error);
+
+	if (!connection || error) {
+		g_warning ("Could not connect to D-Bus session bus, %s\n",
+			   error ? error->message : "no error given");
+		g_clear_error (&error);
+		return;
+	}
+
+	proxy_resources =
+		dbus_g_proxy_new_for_name (connection,
+		                           TRACKER_DBUS_SERVICE,
+		                           TRACKER_DBUS_OBJECT_RESOURCES,
+		                           TRACKER_DBUS_INTERFACE_RESOURCES);
+
+	dbus_g_proxy_add_signal (proxy_resources,
+	                         "Writeback",
+	                         TRACKER_TYPE_STR_STRV_MAP,
+	                         G_TYPE_INVALID);
+}
+
+void
+tracker_writeback_shutdown (void)
+{
+	GList *l;
+
+	if (proxy_resources) {
+		g_object_unref (proxy_resources);
+		proxy_resources = NULL;
+	}
+
+	for (l = writeback_callbacks; l; l = l->next) {
+		WritebackCallback *cb = l->data;
+
+		if (!cb) {
+			continue;
+		}
+
+		g_slice_free (WritebackCallback, l->data);
+	}
+
+	g_list_free (writeback_callbacks);
+}
+
+guint
+tracker_writeback_connect (TrackerWritebackCallback callback,
+			   gpointer                 user_data)
+{
+	WritebackCallback *cb;
+
+	g_return_val_if_fail (callback != NULL, 0);
+
+	/* Connect the DBus signal if needed */
+	if (!writeback_callbacks) {
+		dbus_g_proxy_connect_signal (proxy_resources,
+		                             "Writeback",
+		                             G_CALLBACK (writeback_cb),
+					     NULL,
+		                             NULL);
+	}
+
+	cb = g_slice_new0 (WritebackCallback);
+	cb->id = ++writeback_callback_id;
+	cb->func = callback;
+	cb->data = user_data;
+
+	writeback_callbacks = g_list_prepend (writeback_callbacks, cb);
+
+	return cb->id;
+}
+
+void
+tracker_writeback_disconnect (guint handle)
+{
+	GList *l;
+
+	for (l = writeback_callbacks; l; l = l->next) {
+		WritebackCallback *cb = l->data;
+
+		if (!cb) {
+			continue;
+		}
+
+		if (cb->id == handle) {
+			g_slice_free (WritebackCallback, l->data);
+			writeback_callbacks = g_list_remove (writeback_callbacks, l);
+		}
+	}
+
+	/* Disconnect the DBus signal if not needed anymore */
+	if (!writeback_callbacks) {
+		dbus_g_proxy_disconnect_signal (proxy_resources,
+		                                "Writeback",
+		                                G_CALLBACK (writeback_cb),
+		                                NULL);
+	}
+}



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