[tracker/media-art-enhancements: 10/16] libtracker-common: Refactor tracker_media_art_get_path()
- From: Martyn James Russell <mr src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/media-art-enhancements: 10/16] libtracker-common: Refactor tracker_media_art_get_path()
- Date: Wed, 14 Dec 2011 16:32:26 +0000 (UTC)
commit bcd9954a1fb6a8d1b257db8aa1c922e32e5d0aba
Author: Sam Thursfield <sam thursfield codethink co uk>
Date: Thu Oct 20 17:41:24 2011 +0100
libtracker-common: Refactor tracker_media_art_get_path()
src/libtracker-common/tracker-media-art.c | 88 +++++++++++++---------------
1 files changed, 41 insertions(+), 47 deletions(-)
---
diff --git a/src/libtracker-common/tracker-media-art.c b/src/libtracker-common/tracker-media-art.c
index 67db900..b5dfa5c 100644
--- a/src/libtracker-common/tracker-media-art.c
+++ b/src/libtracker-common/tracker-media-art.c
@@ -203,33 +203,34 @@ media_art_checksum_for_data (GChecksumType checksum_type,
/**
* tracker_media_art_get_path:
* @artist: the artist
- * @album: the album
+ * @title: the title
* @prefix: For example "album"
* @uri: NULL or the uri of the file
* @path: the location to store the local path
* @local_uri: the location to store the local uri or NULL
*
- * Get the path to media art for a given album or song. Newly allocated data in
+ * Get the path to media art for a given resource. Newly allocated data in
* @path and @local_uri must be freed with g_free.
*
* Since: 0.10.14
*/
void
tracker_media_art_get_path (const gchar *artist,
- const gchar *album,
+ const gchar *title,
const gchar *prefix,
const gchar *uri,
gchar **path,
gchar **local_uri)
{
const gchar *space_checksum = "7215ee9c7d9dc229d2921a40e899ec5f";
+ const gchar *a, *b;
gchar *art_filename;
gchar *dir;
- gchar *artist_down, *album_down;
- gchar *artist_stripped, *album_stripped;
- gchar *artist_norm, *album_norm;
- gchar *artist_checksum, *album_checksum;
+ gchar *artist_down, *title_down;
+ gchar *artist_stripped, *title_stripped;
+ gchar *artist_norm, *title_norm;
+ gchar *artist_checksum = NULL, *title_checksum = NULL;
/* http://live.gnome.org/MediaArtStorageSpec */
@@ -241,35 +242,28 @@ tracker_media_art_get_path (const gchar *artist,
*local_uri = NULL;
}
- if (!artist && !album) {
+ if (!artist && !title) {
return;
}
- if (!artist) {
- artist_stripped = g_strdup (" ");
- } else {
+ if (artist) {
artist_stripped = tracker_media_art_strip_invalid_entities (artist);
+ artist_norm = g_utf8_normalize (artist_stripped, -1, G_NORMALIZE_NFKD);
+ artist_down = g_utf8_strdown (artist_norm, -1);
+ artist_checksum = media_art_checksum_for_data (G_CHECKSUM_MD5,
+ (const guchar *) artist_down,
+ strlen (artist_down));
}
- if (!album) {
- album_stripped = g_strdup (" ");
- } else {
- album_stripped = tracker_media_art_strip_invalid_entities (album);
+ if (title) {
+ title_stripped = tracker_media_art_strip_invalid_entities (title);
+ title_norm = g_utf8_normalize (title_stripped, -1, G_NORMALIZE_NFKD);
+ title_down = g_utf8_strdown (title_norm, -1);
+ title_checksum = media_art_checksum_for_data (G_CHECKSUM_MD5,
+ (const guchar *) title_down,
+ strlen (title_down));
}
- artist_norm = g_utf8_normalize (artist_stripped, -1, G_NORMALIZE_NFKD);
- album_norm = g_utf8_normalize (album_stripped, -1, G_NORMALIZE_NFKD);
-
- artist_down = g_utf8_strdown (artist_norm, -1);
- album_down = g_utf8_strdown (album_norm, -1);
-
- /* g_print ("[%s] [%s]\n", artist_down, album_down); */
-
- g_free (artist_norm);
- g_free (album_norm);
- g_free (artist_stripped);
- g_free (album_stripped);
-
dir = g_build_filename (g_get_user_cache_dir (),
"media-art",
NULL);
@@ -278,26 +272,28 @@ tracker_media_art_get_path (const gchar *artist,
g_mkdir_with_parents (dir, 0770);
}
- artist_checksum = media_art_checksum_for_data (G_CHECKSUM_MD5,
- (const guchar *) artist_down,
- strlen (artist_down));
- album_checksum = media_art_checksum_for_data (G_CHECKSUM_MD5,
- (const guchar *) album_down,
- strlen (album_down));
+ if (artist) {
+ a = artist_checksum;
+ b = title ? title_checksum : space_checksum;
+ } else {
+ a = title_checksum;
+ b = space_checksum;
+ }
- g_free (artist_down);
- g_free (album_down);
+ art_filename = g_strdup_printf ("%s-%s-%s.jpeg", prefix ? prefix : "album", a, b);
if (artist) {
- art_filename = g_strdup_printf ("%s-%s-%s.jpeg",
- prefix ? prefix : "album",
- artist_checksum,
- album_checksum);
- } else {
- art_filename = g_strdup_printf ("%s-%s-%s.jpeg",
- prefix ? prefix : "album",
- album_checksum,
- space_checksum);
+ g_free (artist_checksum);
+ g_free (artist_stripped);
+ g_free (artist_down);
+ g_free (artist_norm);
+ }
+
+ if (title) {
+ g_free (title_checksum);
+ g_free (title_stripped);
+ g_free (title_down);
+ g_free (title_norm);
}
if (path) {
@@ -329,6 +325,4 @@ tracker_media_art_get_path (const gchar *artist,
g_free (dir);
g_free (art_filename);
- g_free (artist_checksum);
- g_free (album_checksum);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]