[gnome-music/wip/jfelder/tracker3-rebased: 4/46] grltrackerwrapper: Port album queries to new Tracker/Grilo expectatives
- From: Jean Felder <jfelder src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-music/wip/jfelder/tracker3-rebased: 4/46] grltrackerwrapper: Port album queries to new Tracker/Grilo expectatives
- Date: Sun, 2 Aug 2020 07:44:49 +0000 (UTC)
commit 3243560ed44e22ae83646b7c3e211dab963af5e2
Author: Carlos Garnacho <carlosg gnome org>
Date: Sun May 31 15:10:29 2020 +0200
grltrackerwrapper: Port album queries to new Tracker/Grilo expectatives
For Tracker 3, the miner service must be queried specifically, and it is better
to specify here that we are querying from the tracker:Audio graph.
For Grilo, the variable names are slightly different, and IDs are now URNs, not
tracker:id()s.
gnomemusic/grilowrappers/grltrackerwrapper.py | 91 +++++++++++++++++----------
1 file changed, 58 insertions(+), 33 deletions(-)
---
diff --git a/gnomemusic/grilowrappers/grltrackerwrapper.py b/gnomemusic/grilowrappers/grltrackerwrapper.py
index d59a56a3..ba3f7a07 100644
--- a/gnomemusic/grilowrappers/grltrackerwrapper.py
+++ b/gnomemusic/grilowrappers/grltrackerwrapper.py
@@ -174,24 +174,36 @@ class GrlTrackerWrapper(GObject.GObject):
query = """
SELECT
- rdf:type(?album)
- tracker:id(?album) AS ?id
- nie:title(?album) AS ?title
- ?composer AS ?composer
- ?album_artist AS ?album_artist
- nmm:artistName(?performer) AS ?artist
- nie:url(?song) AS ?url
- YEAR(MAX(nie:contentCreated(?song))) AS ?creation_date
+ ?type ?id ?title ?composer ?albumArtist
+ ?artist ?url ?creationDate
WHERE {
- ?album a nmm:MusicAlbum .
- ?song a nmm:MusicPiece ;
- nmm:musicAlbum ?album ;
- nmm:performer ?performer .
- OPTIONAL { ?song nmm:composer/nmm:artistName ?composer . }
- OPTIONAL { ?album nmm:albumArtist/nmm:artistName ?album_artist . }
- %(location_filter)s
- } GROUP BY ?album
+ SERVICE <dbus:org.freedesktop.Tracker3.Miner.Files> {
+ GRAPH tracker:Audio {
+ SELECT
+ %(media_type)s AS ?type
+ ?album AS ?id
+ nie:title(?album) AS ?title
+ ?composer
+ ?albumArtist
+ nmm:artistName(?artist) AS ?artist
+ nie:isStoredAs(?song) AS ?url
+ YEAR(MAX(nie:contentCreated(?song))) AS ?creationDate
+ WHERE {
+ ?album a nmm:MusicAlbum .
+ ?song a nmm:MusicPiece ;
+ nmm:musicAlbum ?album ;
+ nmm:artist ?artist .
+ OPTIONAL { ?song nmm:composer/
+ nmm:artistName ?composer . }
+ OPTIONAL { ?album nmm:albumArtist/
+ nmm:artistName ?albumArtist . }
+ %(location_filter)s
+ } GROUP BY ?album
+ }
+ }
+ }
""".replace('\n', ' ').strip() % {
+ "media_type": int(Grl.MediaType.CONTAINER),
'location_filter': self._tracker_wrapper.location_filter()
}
@@ -484,27 +496,40 @@ class GrlTrackerWrapper(GObject.GObject):
query = """
SELECT
- rdf:type(?album)
- tracker:id(?album) AS ?id
- nie:title(?album) AS ?title
- ?composer AS ?composer
- ?album_artist AS ?album_artist
- nmm:artistName(?performer) AS ?artist
- nie:url(?song) AS ?url
- YEAR(MAX(nie:contentCreated(?song))) AS ?creation_date
+ ?type ?id ?title ?composer ?albumArtist
+ ?artist ?url ?creationDate
WHERE
{
- ?album a nmm:MusicAlbum .
- ?song a nmm:MusicPiece ;
- nmm:musicAlbum ?album ;
- nmm:performer ?performer .
- OPTIONAL { ?song nmm:composer/nmm:artistName ?composer . }
- OPTIONAL { ?album nmm:albumArtist/nmm:artistName ?album_artist . }
- %(location_filter)s
+ SERVICE <dbus:org.freedesktop.Tracker3.Miner.Files> {
+ GRAPH tracker:Audio {
+ SELECT
+ %(media_type)s AS ?type
+ ?album AS ?id
+ nie:title(?album) AS ?title
+ ?composer
+ ?albumArtist
+ nmm:artistName(?artist) AS ?artist
+ nie:isStoredAs(?song) AS ?url
+ YEAR(MAX(nie:contentCreated(?song))) AS ?creationDate
+ WHERE
+ {
+ ?album a nmm:MusicAlbum .
+ ?song a nmm:MusicPiece ;
+ nmm:musicAlbum ?album ;
+ nmm:artist ?artist .
+ OPTIONAL { ?song nmm:composer/
+ nmm:artistName ?composer . }
+ OPTIONAL { ?album nmm:albumArtist/
+ nmm:artistName ?albumArtist . }
+ %(location_filter)s
+ }
+ GROUP BY ?album
+ ORDER BY ?title ?albumArtist ?artist ?creationDate
+ }
+ }
}
- GROUP BY ?album
- ORDER BY ?title ?album_artist ?artist ?creation_date
""".replace('\n', ' ').strip() % {
+ "media_type": int(Grl.MediaType.CONTAINER),
'location_filter': self._tracker_wrapper.location_filter()
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]