← Back to team overview

zeitgeist team mailing list archive

[Merge] lp:~rainct/zeitgeist/insert-event-fixes into lp:zeitgeist

 

Siegfried Gevatter has proposed merging lp:~rainct/zeitgeist/insert-event-fixes into lp:zeitgeist.

Requested reviews:
  Zeitgeist Framework Team (zeitgeist)
Related bugs:
  Bug #928804 in Zeitgeist Framework: "Blacklist doesn't handle empty current_uri"
  https://bugs.launchpad.net/zeitgeist/+bug/928804

For more details, see:
https://code.launchpad.net/~rainct/zeitgeist/insert-event-fixes/+merge/92468

- Pre-process events before they are send to the extensions (LP: #628804).
- Fix Storage Monitor to take into account that events may be NULL.
- Fix error messages (related to MOVE_EVENT) that were interchanged.
-- 
https://code.launchpad.net/~rainct/zeitgeist/insert-event-fixes/+merge/92468
Your team Zeitgeist Framework Team is requested to review the proposed merge of lp:~rainct/zeitgeist/insert-event-fixes into lp:zeitgeist.
=== modified file 'extensions/fts++/test/test-indexer.cpp'
--- extensions/fts++/test/test-indexer.cpp	2012-02-10 12:07:27 +0000
+++ extensions/fts++/test/test-indexer.cpp	2012-02-10 13:40:28 +0000
@@ -169,13 +169,22 @@
 static guint
 index_event (Fixture *fix, ZeitgeistEvent *event)
 {
+  GPtrArray *events;
   guint event_id = 0;
+  guint *event_ids;
+  int num_events_inserted;
 
   // add event to DBs
-  event_id = zeitgeist_engine_insert_event (ZEITGEIST_ENGINE (fix->db),
-                                            event, NULL, NULL);
+  events = g_ptr_array_new ();
+  g_ptr_array_add (events, event);
+  event_ids = zeitgeist_engine_insert_events (ZEITGEIST_ENGINE (fix->db),
+                                              events, NULL,
+                                              &num_events_inserted, NULL);
+  g_assert_cmpint (1, ==, num_events_inserted);
+  event_id = *event_ids;
+  g_ptr_array_unref (events);
 
-  GPtrArray *events = g_ptr_array_new_with_free_func (g_object_unref);
+  events = g_ptr_array_new_with_free_func (g_object_unref);
   g_ptr_array_add (events, event); // steal event ref
   zeitgeist_indexer_index_events (fix->indexer, events);
   g_ptr_array_unref (events);

=== modified file 'extensions/storage-monitor.vala'
--- extensions/storage-monitor.vala	2012-02-02 18:57:35 +0000
+++ extensions/storage-monitor.vala	2012-02-10 13:40:28 +0000
@@ -269,10 +269,11 @@
         {
             for (int i = 0; i < events.length; ++i)
             {
+                if (events[i] == null) continue;
                 for (int j = 0; j < events[i].subjects.length; ++j)
                 {
                     Subject subject = events[i].subjects[j];
-                    if (subject.storage == "")
+                    if (Utils.is_empty_string (subject.storage))
                         subject.storage = find_storage_for_uri (subject.uri);
                 }
             }

=== modified file 'src/engine.vala'
--- src/engine.vala	2012-02-07 17:02:05 +0000
+++ src/engine.vala	2012-02-10 13:40:28 +0000
@@ -27,6 +27,7 @@
 
 using Zeitgeist;
 using Zeitgeist.SQLite;
+using Zeitgeist.Utils;
 
 namespace Zeitgeist
 {
@@ -62,21 +63,74 @@
     public uint32[] insert_events (GenericArray<Event> events,
         BusName? sender=null) throws EngineError
     {
+        // Any changes to events need to be done here so they'll
+        // be taken into consideration by the extensions (LP: #928804).
+        for (int i = 0; i < events.length; ++i)
+        {
+            preprocess_event (events[i]);
+        }
+
         extension_collection.call_pre_insert_events (events, sender);
         uint32[] event_ids = new uint32[events.length];
         database.begin_transaction ();
         for (int i = 0; i < events.length; ++i)
         {
             if (events[i] != null)
-                event_ids[i] = insert_event (events[i], sender);
+                event_ids[i] = insert_event (events[i]);
         }
         database.end_transaction ();
         extension_collection.call_post_insert_events (events, sender);
         return event_ids;
     }
 
-    public uint32 insert_event (Event event,
-        BusName? sender=null) throws EngineError
+    private void preprocess_event (Event event) throws EngineError
+    {
+        // Iterate through subjects and check for validity
+        for (int i = 0; i < event.num_subjects(); ++i)
+        {
+            unowned Subject subject = event.subjects[i];
+
+            // If current_uri is unset, give it the same value as URI
+            if (is_empty_string (subject.current_uri))
+                subject.current_uri = subject.uri;
+
+            if (event.interpretation == ZG.MOVE_EVENT
+                && subject.uri == subject.current_uri)
+            {
+                throw new EngineError.INVALID_ARGUMENT (
+                    "Redundant event: event.interpretation indicates " +
+                    "the uri has been moved yet the subject.uri and " +
+                    "subject.current_uri are identical");
+            }
+            else if (event.interpretation != ZG.MOVE_EVENT
+                && subject.uri != subject.current_uri)
+            {
+                throw new EngineError.INVALID_ARGUMENT (
+                    "Illegal event: unless event.interpretation is " +
+                    "'MOVE_EVENT' then subject.uri and " +
+                    "subject.current_uri have to be the same");
+            }
+
+            // If subject manifestation and interpretation are not set,
+            // we try to automatically determine them from the other data.
+            if (is_empty_string (subject.manifestation))
+            {
+                unowned string? manifestation = manifestation_for_uri (
+                    subject.uri);
+                if (manifestation != null)
+                    subject.manifestation = manifestation;
+            }
+            if (is_empty_string (subject.interpretation))
+            {
+                unowned string? interpretation = interpretation_for_mimetype (
+                    subject.mimetype);
+                if (interpretation != null)
+                    subject.interpretation = interpretation;
+            }
+        }
+    }
+
+    private uint32 insert_event (Event event) throws EngineError
         requires (event.id == 0)
         requires (event.num_subjects () > 0)
     {
@@ -89,7 +143,7 @@
             var storages = new GenericArray<string> ();
             var subj_uris = new SList<string> ();
 
-            if (event.origin != "")
+            if (!is_empty_string (event.origin))
                 uris.add (event.origin);
 
             // Iterate through subjects and check for validity
@@ -105,34 +159,14 @@
                 subj_uris.append (subject.uri);
 
                 uris.add (subject.uri);
-
-                if (subject.current_uri == "" || subject.current_uri == null)
-                    subject.current_uri = subject.uri;
-
-                if (event.interpretation == ZG.MOVE_EVENT
-                    && subject.uri == subject.current_uri)
-                {
-                    throw new EngineError.INVALID_ARGUMENT (
-                        "Illegal event: unless event.interpretation is " +
-                        "'MOVE_EVENT' then subject.uri and " +
-                        "subject.current_uri have to be the same");
-                }
-                else if (event.interpretation != ZG.MOVE_EVENT
-                    && subject.uri != subject.current_uri)
-                {
-                    throw new EngineError.INVALID_ARGUMENT (
-                        "Redundant event: event.interpretation indicates " +
-                        "the uri has been moved yet the subject.uri and " +
-                        "subject.current_uri are identical");
-                }
-
-                uris.add (subject.current_uri);
-
-                if (subject.origin != "")
+                if (subject.uri != subject.current_uri)
+                    uris.add (subject.current_uri);
+
+                if (!is_empty_string (subject.origin))
                     uris.add (subject.origin);
-                if (subject.text != "")
+                if (!is_empty_string (subject.text))
                     texts.add (subject.text);
-                if (subject.storage != "")
+                if (!is_empty_string(subject.storage))
                     storages.add (subject.storage);
             }
 
@@ -180,25 +214,6 @@
 
             unowned Subject subject = event.subjects[i];
 
-            // If subject manifestation and interpretation are not set,
-            // we try to automatically determine them from the other data.
-
-            if (subject.manifestation == "")
-            {
-                unowned string? manifestation = manifestation_for_uri (
-                    subject.uri);
-                if (manifestation != null)
-                    subject.manifestation = manifestation;
-            }
-
-            if (subject.interpretation == "")
-            {
-                unowned string? interpretation = interpretation_for_mimetype (
-                    subject.mimetype);
-                if (interpretation != null)
-                    subject.interpretation = interpretation;
-            }
-
             insert_stmt.bind_text (8, subject.uri);
             insert_stmt.bind_text (9, subject.current_uri);
             insert_stmt.bind_int64 (10,

=== modified file 'test/dbus/blacklist-test.py'
--- test/dbus/blacklist-test.py	2012-02-08 12:49:38 +0000
+++ test/dbus/blacklist-test.py	2012-02-10 13:40:28 +0000
@@ -203,7 +203,9 @@
 		self._assert_template_count(1)
 
 		# Blocking the current_uri works
-		self._assert_insert_blocked(Event.new_for_values(subject_current_uri="t"))
+		self._assert_insert_blocked(Event.new_for_values(
+			interpretation=Interpretation.MOVE_EVENT,
+			subject_current_uri="t"))
 
 		# But if we only set uri (and leave it up to Zeitgeist to set current_uri
 		# to the same value?


Follow ups