[tracker/media-art-detect: 6/6] tracker-extract, jpeg: Detect albumart
- From: Philip Van Hoof <pvanhoof src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/media-art-detect: 6/6] tracker-extract, jpeg: Detect albumart
- Date: Tue, 25 Oct 2011 09:58:48 +0000 (UTC)
commit ffd93011f34c7a273524523e9d46af296159f6ad
Author: Philip Van Hoof <philip codeminded be>
Date: Tue Oct 25 11:44:26 2011 +0200
tracker-extract, jpeg: Detect albumart
src/tracker-extract/tracker-extract-jpeg.c | 92 +++++++++++++++------------
1 files changed, 51 insertions(+), 41 deletions(-)
---
diff --git a/src/tracker-extract/tracker-extract-jpeg.c b/src/tracker-extract/tracker-extract-jpeg.c
index a9d15cb..61fa1d7 100644
--- a/src/tracker-extract/tracker-extract-jpeg.c
+++ b/src/tracker-extract/tracker-extract-jpeg.c
@@ -33,6 +33,7 @@
#include <libtracker-extract/tracker-extract.h>
#include <libtracker-sparql/tracker-sparql.h>
+#include "tracker-albumart.h"
#include "tracker-main.h"
#define CM_TO_INCH 0.393700787
@@ -160,6 +161,7 @@ tracker_extract_get_metadata (TrackerExtractInfo *info)
gboolean success = TRUE;
GString *where;
guint i;
+ gboolean is_albumart;
metadata = tracker_extract_info_get_metadata_builder (info);
preupdate = tracker_extract_info_get_preupdate_builder (info);
@@ -167,6 +169,7 @@ tracker_extract_get_metadata (TrackerExtractInfo *info)
file = tracker_extract_info_get_file (info);
filename = g_file_get_path (file);
+ is_albumart = tracker_is_albumart (file);
size = tracker_file_get_size (filename);
@@ -187,7 +190,12 @@ tracker_extract_get_metadata (TrackerExtractInfo *info)
tracker_sparql_builder_predicate (metadata, "a");
tracker_sparql_builder_object (metadata, "nfo:Image");
tracker_sparql_builder_predicate (metadata, "a");
- tracker_sparql_builder_object (metadata, "nmm:Photo");
+
+ if (is_albumart) {
+ tracker_sparql_builder_object (metadata, "nmm:MediaArt");
+ } else {
+ tracker_sparql_builder_object (metadata, "nmm:Photo");
+ }
cinfo.err = jpeg_std_error (&tejerr.jpeg);
tejerr.jpeg.error_exit = extract_jpeg_error_exit;
@@ -544,30 +552,53 @@ tracker_extract_get_metadata (TrackerExtractInfo *info)
tracker_sparql_builder_object_unvalidated (metadata, md.copyright);
}
- if (md.white_balance) {
- tracker_sparql_builder_predicate (metadata, "nmm:whiteBalance");
- tracker_sparql_builder_object (metadata, md.white_balance);
- }
+ if (!is_albumart) {
+ if (md.white_balance) {
+ tracker_sparql_builder_predicate (metadata, "nmm:whiteBalance");
+ tracker_sparql_builder_object (metadata, md.white_balance);
+ }
- if (md.fnumber) {
- gdouble value;
+ if (md.fnumber) {
+ gdouble value;
- value = g_strtod (md.fnumber, NULL);
- tracker_sparql_builder_predicate (metadata, "nmm:fnumber");
- tracker_sparql_builder_object_double (metadata, value);
- }
+ value = g_strtod (md.fnumber, NULL);
+ tracker_sparql_builder_predicate (metadata, "nmm:fnumber");
+ tracker_sparql_builder_object_double (metadata, value);
+ }
- if (md.flash) {
- tracker_sparql_builder_predicate (metadata, "nmm:flash");
- tracker_sparql_builder_object (metadata, md.flash);
- }
+ if (md.flash) {
+ tracker_sparql_builder_predicate (metadata, "nmm:flash");
+ tracker_sparql_builder_object (metadata, md.flash);
+ }
- if (md.focal_length) {
- gdouble value;
+ if (md.focal_length) {
+ gdouble value;
- value = g_strtod (md.focal_length, NULL);
- tracker_sparql_builder_predicate (metadata, "nmm:focalLength");
- tracker_sparql_builder_object_double (metadata, value);
+ value = g_strtod (md.focal_length, NULL);
+ tracker_sparql_builder_predicate (metadata, "nmm:focalLength");
+ tracker_sparql_builder_object_double (metadata, value);
+ }
+
+ if (md.exposure_time) {
+ gdouble value;
+
+ value = g_strtod (md.exposure_time, NULL);
+ tracker_sparql_builder_predicate (metadata, "nmm:exposureTime");
+ tracker_sparql_builder_object_double (metadata, value);
+ }
+
+ if (md.iso_speed_ratings) {
+ gdouble value;
+
+ value = g_strtod (md.iso_speed_ratings, NULL);
+ tracker_sparql_builder_predicate (metadata, "nmm:isoSpeed");
+ tracker_sparql_builder_object_double (metadata, value);
+ }
+
+ if (md.metering_mode) {
+ tracker_sparql_builder_predicate (metadata, "nmm:meteringMode");
+ tracker_sparql_builder_object (metadata, md.metering_mode);
+ }
}
if (md.artist) {
@@ -594,22 +625,6 @@ tracker_extract_get_metadata (TrackerExtractInfo *info)
g_free (uri);
}
- if (md.exposure_time) {
- gdouble value;
-
- value = g_strtod (md.exposure_time, NULL);
- tracker_sparql_builder_predicate (metadata, "nmm:exposureTime");
- tracker_sparql_builder_object_double (metadata, value);
- }
-
- if (md.iso_speed_ratings) {
- gdouble value;
-
- value = g_strtod (md.iso_speed_ratings, NULL);
- tracker_sparql_builder_predicate (metadata, "nmm:isoSpeed");
- tracker_sparql_builder_object_double (metadata, value);
- }
-
tracker_guarantee_date_from_file_mtime (metadata,
"nie:contentCreated",
md.date,
@@ -620,11 +635,6 @@ tracker_extract_get_metadata (TrackerExtractInfo *info)
tracker_sparql_builder_object_unvalidated (metadata, md.description);
}
- if (md.metering_mode) {
- tracker_sparql_builder_predicate (metadata, "nmm:meteringMode");
- tracker_sparql_builder_object (metadata, md.metering_mode);
- }
-
if (md.creator) {
gchar *uri = tracker_sparql_escape_uri_printf ("urn:contact:%s", md.creator);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]