[gnome-music/wip/carlosg/tracker3: 14/17] trackerwrapper: Make play-count property updates go through tracker



commit 394153a893993cff3c0c9261bc120e5842108ac2
Author: Carlos Garnacho <carlosg gnome org>
Date:   Sun Jun 14 16:14:30 2020 +0200

    trackerwrapper: Make play-count property updates go through tracker
    
    This property cannot be written back via grilo with the Tracker3 ownership
    changes. This should be stored in the local store, thus it's better to
    handle it via the trackerwrapper writeback methods.

 gnomemusic/coresong.py       |  4 ++--
 gnomemusic/trackerwrapper.py | 26 ++++++++++++++++++++++++++
 2 files changed, 28 insertions(+), 2 deletions(-)
---
diff --git a/gnomemusic/coresong.py b/gnomemusic/coresong.py
index e5412d96..0c40fa07 100644
--- a/gnomemusic/coresong.py
+++ b/gnomemusic/coresong.py
@@ -136,8 +136,8 @@ class CoreSong(GObject.GObject):
             return
 
         self.props.media.set_play_count(self.props.play_count + 1)
-        self._coregrilo.writeback(
-            self.props.media, [Grl.METADATA_KEY_PLAY_COUNT])
+        self._coregrilo.writeback_tracker(
+            self.props.media, deque(["play-count"]))
 
     def set_last_played(self):
         if not self._is_tracker:
diff --git a/gnomemusic/trackerwrapper.py b/gnomemusic/trackerwrapper.py
index 29e86acf..2b884d23 100644
--- a/gnomemusic/trackerwrapper.py
+++ b/gnomemusic/trackerwrapper.py
@@ -594,6 +594,30 @@ class TrackerWrapper(GObject.GObject):
         self._tracker.update_async(
             update, GLib.PRIORITY_LOW, None, _update_favorite_cb)
 
+    def _update_play_count(self, media):
+        update = """
+        DELETE WHERE {
+            <%(urn)s> nie:usageCounter ?count .
+        };
+        INSERT DATA {
+            <%(urn)s> a nmm:MusicPiece ;
+                      nie:usageCounter %(count)d .
+        }
+        """.replace("\n", "").strip() % {
+            "urn": media.get_id(),
+            "count": media.get_play_count(),
+        }
+
+        def _update_play_count_cb(conn, res):
+            try:
+                conn.update_finish(res)
+            except GLib.Error as e:
+                self._log.warning("Unable to update play count: {}".format(
+                    e.message))
+
+        self._tracker.update_async(
+            update, GLib.PRIORITY_LOW, None, _update_play_count_cb)
+
     def _update_album(self, media, tags):
         query_delete = """
         DELETE {
@@ -683,6 +707,8 @@ class TrackerWrapper(GObject.GObject):
             self._update_reference(media, MbReference.RELEASE_GROUP, tags)
         elif tag == "favorite":
             self._update_favorite(media)
+        elif tag == "play-count":
+            self._update_play_count(media)
         else:
             self._log.warning("Unknown tag: '{}'".format(tag))
             self.update_tags(media, tags)


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