|  |  |  | Tracker Extract Library Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
#include <libtracker-extract/tracker-extract.h>
                    TrackerExifData;
TrackerExifData *   tracker_exif_new                    (const guchar *buffer,
                                                         size_t len,
                                                         const gchar *uri);
void                tracker_exif_free                   (TrackerExifData *data);
gboolean            tracker_exif_read                   (const unsigned char *buffer,
                                                         size_t len,
                                                         const gchar *uri,
                                                         TrackerExifData *data);
Exchangeable Image File Format (EXIF) is a specification for the image file format used by digital cameras. The specification uses the existing JPEG, TIFF Rev. 6.0, and RIFF WAV file formats, with the addition of specific metadata tags. It is not supported in JPEG 2000, PNG, or GIF.
This API is provided to remove code duplication between extractors using these standards.
typedef struct {
	gchar *y_dimension;
	gchar *x_dimension;
	gchar *image_width;
	gchar *document_name;
	gchar *time;
	gchar *time_original;
	gchar *artist;
	gchar *user_comment;
	gchar *description;
	gchar *make;
	gchar *model;
	gchar *orientation;
	gchar *exposure_time;
	gchar *fnumber;
	gchar *flash;
	gchar *focal_length;
	gchar *iso_speed_ratings;
	gchar *metering_mode;
	gchar *white_balance;
	gchar *copyright;
	gchar *software;
	gchar *x_resolution;
	gchar *y_resolution;
	gint resolution_unit;
	/* ABI barrier (don't change things above this) */
	gchar *gps_altitude;
	gchar *gps_latitude;
	gchar *gps_longitude;
	gchar *gps_direction;
} TrackerExifData;
TrackerExifData * tracker_exif_new (const guchar *buffer,size_t len,const gchar *uri);
This function takes len bytes of buffer and runs it through the
EXIF library.
| 
 | a chunk of data with exif data in it. | 
| 
 | the size of buffer. | 
| 
 | the URI this is related to. | 
| Returns : | a newly allocated TrackerExifData struct if EXIF data was
found, NULLotherwise. Free the returned struct withtracker_exif_free(). | 
Since 0.10
void                tracker_exif_free                   (TrackerExifData *data);
Frees data and all TrackerExifData members. NULL will produce a
a warning.
| 
 | a TrackerExifData | 
Since 0.10
gboolean tracker_exif_read (const unsigned char *buffer,size_t len,const gchar *uri,TrackerExifData *data);
tracker_exif_read is deprecated and should not be used in newly-written code. 0.9. Use tracker_exif_new() instead.
This function takes len bytes of buffer and runs it through the
EXIF library. The result is that data is populated with the EXIF
data found in uri.
| 
 | a chunk of data with exif data in it. | 
| 
 | the size of buffer. | 
| 
 | the URI this is related to. | 
| 
 | a pointer to a TrackerExifData struture to populate. | 
| Returns : | TRUEif thedatawas populated successfully, otherwiseFALSEis returned. | 
Since 0.8