Mercurial > geeqie.yaz
annotate src/exiv2.cc @ 1069:aeae25d5d50d
infrastructure for preprocessing of metadata
author | nadvornik |
---|---|
date | Sat, 18 Oct 2008 18:22:57 +0000 |
parents | 90dcc0060e22 |
children | abf48b53216b |
rev | line source |
---|---|
475 | 1 /* |
2 * Geeqie | |
3 * Copyright (C) 2008 The Geeqie Team | |
4 * | |
5 * Author: Vladimir Nadvornik | |
6 * | |
7 * This software is released under the GNU General Public License (GNU GPL). | |
8 * Please read the included file COPYING for more information. | |
9 * This software comes with no warranty of any kind, use at your own risk! | |
10 */ | |
178 | 11 |
686 | 12 #include "config.h" |
178 | 13 |
14 #ifdef HAVE_EXIV2 | |
15 | |
16 #include <exiv2/image.hpp> | |
17 #include <exiv2/exif.hpp> | |
18 #include <iostream> | |
19 | |
200 | 20 // EXIV2_TEST_VERSION is defined in Exiv2 0.15 and newer. |
21 #ifndef EXIV2_TEST_VERSION | |
22 # define EXIV2_TEST_VERSION(major,minor,patch) \ | |
23 ( EXIV2_VERSION >= EXIV2_MAKE_VERSION(major,minor,patch) ) | |
24 #endif | |
25 | |
26 | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
27 #include <sys/types.h> |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
28 #include <sys/stat.h> |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
29 #include <unistd.h> |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
30 #include <fcntl.h> |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
31 #include <sys/mman.h> |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
32 |
1008 | 33 #if !EXIV2_TEST_VERSION(0,17,90) |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
34 #include <exiv2/tiffparser.hpp> |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
35 #include <exiv2/tiffcomposite.hpp> |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
36 #include <exiv2/tiffvisitor.hpp> |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
37 #include <exiv2/tiffimage.hpp> |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
38 #include <exiv2/cr2image.hpp> |
191 | 39 #include <exiv2/crwimage.hpp> |
200 | 40 #if EXIV2_TEST_VERSION(0,16,0) |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
41 #include <exiv2/orfimage.hpp> |
200 | 42 #endif |
43 #if EXIV2_TEST_VERSION(0,13,0) | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
44 #include <exiv2/rafimage.hpp> |
200 | 45 #endif |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
46 #include <exiv2/futils.hpp> |
1008 | 47 #else |
48 #include <exiv2/preview.hpp> | |
49 #endif | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
50 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
51 |
178 | 52 extern "C" { |
995 | 53 #include <glib.h> |
507 | 54 |
281 | 55 #include "main.h" |
178 | 56 #include "exif.h" |
507 | 57 |
586 | 58 #include "filefilter.h" |
496
a1f13fab6686
fixed a bug in opening files with non-utf8 locales in exiv2.cc
nadvornik
parents:
495
diff
changeset
|
59 #include "ui_fileops.h" |
184 | 60 } |
178 | 61 |
62 struct _ExifData | |
63 { | |
185 | 64 Exiv2::ExifData::const_iterator exifIter; /* for exif_get_next_item */ |
65 Exiv2::IptcData::const_iterator iptcIter; /* for exif_get_next_item */ | |
200 | 66 #if EXIV2_TEST_VERSION(0,16,0) |
185 | 67 Exiv2::XmpData::const_iterator xmpIter; /* for exif_get_next_item */ |
200 | 68 #endif |
184 | 69 |
1069 | 70 virtual ~_ExifData() |
71 { | |
72 } | |
73 | |
74 virtual void writeMetadata() | |
184 | 75 { |
1069 | 76 g_critical("Unsupported method of writing metadata"); |
77 } | |
78 | |
79 virtual ExifData *original() | |
80 { | |
81 return NULL; | |
82 } | |
83 | |
84 virtual Exiv2::Image *image() = 0; | |
85 | |
86 virtual Exiv2::ExifData &exifData() = 0; | |
87 | |
88 virtual Exiv2::IptcData &iptcData() = 0; | |
200 | 89 |
90 #if EXIV2_TEST_VERSION(0,16,0) | |
1069 | 91 virtual Exiv2::XmpData &xmpData() = 0; |
92 #endif | |
93 | |
94 virtual void add_jpeg_color_profile(unsigned char *cp_data, guint cp_length) = 0; | |
95 | |
96 virtual guchar *get_jpeg_color_profile(guint *data_len) = 0; | |
97 }; | |
98 | |
99 // This allows read-only access to the original metadata | |
100 struct _ExifDataOriginal : public _ExifData | |
101 { | |
102 protected: | |
103 Exiv2::Image::AutoPtr image_; | |
104 | |
105 /* the icc profile in jpeg is not technically exif - store it here */ | |
106 unsigned char *cp_data_; | |
107 guint cp_length_; | |
108 | |
109 public: | |
110 | |
111 _ExifDataOriginal(gchar *path) | |
112 { | |
113 cp_data_ = NULL; | |
114 cp_length_ = 0; | |
115 gchar *pathl = path_from_utf8(path); | |
116 image_ = Exiv2::ImageFactory::open(pathl); | |
117 g_free(pathl); | |
118 // g_assert (image.get() != 0); | |
119 image_->readMetadata(); | |
120 | |
121 #if EXIV2_TEST_VERSION(0,16,0) | |
122 if (image_->mimeType() == "application/rdf+xml") | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
123 { |
1069 | 124 //Exiv2 sidecar converts xmp to exif and iptc, we don't want it. |
125 image_->clearExifData(); | |
126 image_->clearIptcData(); | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
127 } |
1069 | 128 #endif |
449 | 129 |
452
0a69a779395a
fixed color profile code for older versions of exiv2
nadvornik
parents:
449
diff
changeset
|
130 #if EXIV2_TEST_VERSION(0,14,0) |
1069 | 131 if (image_->mimeType() == "image/jpeg") |
449 | 132 { |
133 /* try to get jpeg color profile */ | |
1069 | 134 Exiv2::BasicIo &io = image_->io(); |
449 | 135 gint open = io.isopen(); |
136 if (!open) io.open(); | |
137 unsigned char *mapped = (unsigned char*)io.mmap(); | |
138 if (mapped) exif_jpeg_parse_color(this, mapped, io.size()); | |
139 io.munmap(); | |
140 if (!open) io.close(); | |
141 } | |
995 | 142 #endif |
184 | 143 } |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
144 |
1069 | 145 virtual ~_ExifDataOriginal() |
449 | 146 { |
1069 | 147 if (cp_data_) g_free(cp_data_); |
449 | 148 } |
149 | |
1069 | 150 virtual Exiv2::Image *image() |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
151 { |
1069 | 152 return image_.get(); |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
153 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
154 |
1069 | 155 virtual Exiv2::ExifData &exifData () |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
156 { |
1069 | 157 return image_->exifData(); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
158 } |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
159 |
1069 | 160 virtual Exiv2::IptcData &iptcData () |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
161 { |
1069 | 162 return image_->iptcData(); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
163 } |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
164 |
200 | 165 #if EXIV2_TEST_VERSION(0,16,0) |
1069 | 166 virtual Exiv2::XmpData &xmpData () |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
167 { |
1069 | 168 return image_->xmpData(); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
169 } |
200 | 170 #endif |
184 | 171 |
1069 | 172 virtual void add_jpeg_color_profile(unsigned char *cp_data, guint cp_length) |
173 { | |
174 if (cp_data_) g_free(cp_data_); | |
175 cp_data_ = cp_data; | |
176 cp_length_ = cp_length; | |
177 } | |
178 | |
179 virtual guchar *get_jpeg_color_profile(guint *data_len) | |
180 { | |
181 if (cp_data_) | |
182 { | |
183 if (data_len) *data_len = cp_length_; | |
184 return (unsigned char *) g_memdup(cp_data_, cp_length_); | |
185 } | |
186 return NULL; | |
187 } | |
178 | 188 }; |
189 | |
1069 | 190 // This allows read-write access to the metadata |
191 struct _ExifDataProcessed : public _ExifData | |
192 { | |
193 protected: | |
194 _ExifDataOriginal *imageData_; | |
195 _ExifDataOriginal *sidecarData_; | |
196 | |
197 Exiv2::ExifData exifData_; | |
198 Exiv2::IptcData iptcData_; | |
199 #if EXIV2_TEST_VERSION(0,16,0) | |
200 Exiv2::XmpData xmpData_; | |
201 #endif | |
202 | |
203 public: | |
204 _ExifDataProcessed(gchar *path, gchar *sidecar_path) | |
205 { | |
206 imageData_ = new _ExifDataOriginal(path); | |
207 sidecarData_ = NULL; | |
208 #if EXIV2_TEST_VERSION(0,16,0) | |
209 xmpData_ = imageData_->xmpData(); | |
210 DEBUG_2("xmp count %li", xmpData_.count()); | |
211 if (sidecar_path && xmpData_.empty()) | |
212 { | |
213 sidecarData_ = new _ExifDataOriginal(sidecar_path); | |
214 xmpData_ = sidecarData_->xmpData(); | |
215 } | |
216 #endif | |
217 exifData_ = imageData_->exifData(); | |
218 iptcData_ = imageData_->iptcData(); | |
219 } | |
220 | |
221 virtual ~_ExifDataProcessed() | |
222 { | |
223 if (imageData_) delete imageData_; | |
224 if (sidecarData_) delete sidecarData_; | |
225 } | |
226 | |
227 virtual ExifData *original() | |
228 { | |
229 return imageData_; | |
230 } | |
231 | |
232 virtual void writeMetadata() | |
233 { | |
234 | |
235 if (sidecarData_) | |
236 { | |
237 sidecarData_->image()->setXmpData(xmpData_); | |
238 //Exiv2 sidecar converts xmp to exif and iptc, we don't want it. | |
239 sidecarData_->image()->clearExifData(); | |
240 sidecarData_->image()->clearIptcData(); | |
241 sidecarData_->image()->writeMetadata(); | |
242 } | |
243 else | |
244 { | |
245 imageData_->image()->setExifData(exifData_); | |
246 imageData_->image()->setIptcData(iptcData_); | |
247 imageData_->image()->setXmpData(xmpData_); | |
248 imageData_->image()->writeMetadata(); | |
249 } | |
250 } | |
251 | |
252 virtual Exiv2::Image *image() | |
253 { | |
254 return imageData_->image(); | |
255 } | |
256 | |
257 virtual Exiv2::ExifData &exifData () | |
258 { | |
259 return exifData_; | |
260 } | |
261 | |
262 virtual Exiv2::IptcData &iptcData () | |
263 { | |
264 return iptcData_; | |
265 } | |
266 | |
267 #if EXIV2_TEST_VERSION(0,16,0) | |
268 virtual Exiv2::XmpData &xmpData () | |
269 { | |
270 return xmpData_; | |
271 } | |
272 #endif | |
273 | |
274 virtual void add_jpeg_color_profile(unsigned char *cp_data, guint cp_length) | |
275 { | |
276 imageData_->add_jpeg_color_profile(cp_data, cp_length); | |
277 } | |
278 | |
279 virtual guchar *get_jpeg_color_profile(guint *data_len) | |
280 { | |
281 return imageData_->get_jpeg_color_profile(data_len); | |
282 } | |
283 }; | |
284 | |
285 | |
286 | |
287 | |
184 | 288 extern "C" { |
178 | 289 |
449 | 290 ExifData *exif_read(gchar *path, gchar *sidecar_path) |
178 | 291 { |
506
fc9c8a3e1a8b
Handle the newline in DEBUG_N() macro instead of adding one
zas_
parents:
496
diff
changeset
|
292 DEBUG_1("exif read %s, sidecar: %s", path, sidecar_path ? sidecar_path : "-"); |
178 | 293 try { |
1069 | 294 return new _ExifDataProcessed(path, sidecar_path); |
178 | 295 } |
296 catch (Exiv2::AnyError& e) { | |
297 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
298 return NULL; |
178 | 299 } |
179
37004d5a584a
and first version that actually shows some exif data (see advanced view)
nadvornik
parents:
178
diff
changeset
|
300 |
178 | 301 } |
302 | |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
303 int exif_write(ExifData *exif) |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
304 { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
305 try { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
306 exif->writeMetadata(); |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
307 return 1; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
308 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
309 catch (Exiv2::AnyError& e) { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
310 std::cout << "Caught Exiv2 exception '" << e << "'\n"; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
311 return 0; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
312 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
313 |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
314 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
315 |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
316 |
178 | 317 void exif_free(ExifData *exif) |
318 { | |
1069 | 319 g_assert(dynamic_cast<_ExifDataProcessed *>(exif)); // this should not be called on ExifDataOriginal |
182 | 320 delete exif; |
178 | 321 } |
322 | |
1069 | 323 ExifData *exif_get_original(ExifData *exif) |
324 { | |
325 return exif->original(); | |
326 } | |
327 | |
328 | |
184 | 329 ExifItem *exif_get_item(ExifData *exif, const gchar *key) |
178 | 330 { |
183 | 331 try { |
452
0a69a779395a
fixed color profile code for older versions of exiv2
nadvornik
parents:
449
diff
changeset
|
332 Exiv2::Metadatum *item = NULL; |
185 | 333 try { |
334 Exiv2::ExifKey ekey(key); | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
335 Exiv2::ExifData::iterator pos = exif->exifData().findKey(ekey); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
336 if (pos == exif->exifData().end()) return NULL; |
185 | 337 item = &*pos; |
338 } | |
339 catch (Exiv2::AnyError& e) { | |
340 try { | |
341 Exiv2::IptcKey ekey(key); | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
342 Exiv2::IptcData::iterator pos = exif->iptcData().findKey(ekey); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
343 if (pos == exif->iptcData().end()) return NULL; |
185 | 344 item = &*pos; |
345 } | |
346 catch (Exiv2::AnyError& e) { | |
200 | 347 #if EXIV2_TEST_VERSION(0,16,0) |
185 | 348 Exiv2::XmpKey ekey(key); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
349 Exiv2::XmpData::iterator pos = exif->xmpData().findKey(ekey); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
350 if (pos == exif->xmpData().end()) return NULL; |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
351 item = &*pos; |
200 | 352 #endif |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
353 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
354 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
355 return (ExifItem *)item; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
356 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
357 catch (Exiv2::AnyError& e) { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
358 std::cout << "Caught Exiv2 exception '" << e << "'\n"; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
359 return NULL; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
360 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
361 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
362 |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
363 ExifItem *exif_add_item(ExifData *exif, const gchar *key) |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
364 { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
365 try { |
452
0a69a779395a
fixed color profile code for older versions of exiv2
nadvornik
parents:
449
diff
changeset
|
366 Exiv2::Metadatum *item = NULL; |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
367 try { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
368 Exiv2::ExifKey ekey(key); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
369 exif->exifData().add(ekey, NULL); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
370 Exiv2::ExifData::iterator pos = exif->exifData().end(); // a hack, there should be a better way to get the currently added item |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
371 pos--; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
372 item = &*pos; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
373 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
374 catch (Exiv2::AnyError& e) { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
375 try { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
376 Exiv2::IptcKey ekey(key); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
377 exif->iptcData().add(ekey, NULL); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
378 Exiv2::IptcData::iterator pos = exif->iptcData().end(); |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
379 pos--; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
380 item = &*pos; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
381 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
382 catch (Exiv2::AnyError& e) { |
200 | 383 #if EXIV2_TEST_VERSION(0,16,0) |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
384 Exiv2::XmpKey ekey(key); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
385 exif->xmpData().add(ekey, NULL); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
386 Exiv2::XmpData::iterator pos = exif->xmpData().end(); |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
387 pos--; |
185 | 388 item = &*pos; |
200 | 389 #endif |
185 | 390 } |
391 } | |
184 | 392 return (ExifItem *)item; |
183 | 393 } |
394 catch (Exiv2::AnyError& e) { | |
184 | 395 std::cout << "Caught Exiv2 exception '" << e << "'\n"; |
396 return NULL; | |
397 } | |
398 } | |
399 | |
400 | |
401 ExifItem *exif_get_first_item(ExifData *exif) | |
402 { | |
403 try { | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
404 exif->exifIter = exif->exifData().begin(); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
405 exif->iptcIter = exif->iptcData().begin(); |
200 | 406 #if EXIV2_TEST_VERSION(0,16,0) |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
407 exif->xmpIter = exif->xmpData().begin(); |
200 | 408 #endif |
995 | 409 if (exif->exifIter != exif->exifData().end()) |
185 | 410 { |
411 const Exiv2::Metadatum *item = &*exif->exifIter; | |
412 exif->exifIter++; | |
413 return (ExifItem *)item; | |
414 } | |
995 | 415 if (exif->iptcIter != exif->iptcData().end()) |
185 | 416 { |
417 const Exiv2::Metadatum *item = &*exif->iptcIter; | |
418 exif->iptcIter++; | |
419 return (ExifItem *)item; | |
420 } | |
200 | 421 #if EXIV2_TEST_VERSION(0,16,0) |
995 | 422 if (exif->xmpIter != exif->xmpData().end()) |
185 | 423 { |
424 const Exiv2::Metadatum *item = &*exif->xmpIter; | |
425 exif->xmpIter++; | |
426 return (ExifItem *)item; | |
427 } | |
200 | 428 #endif |
185 | 429 return NULL; |
430 | |
184 | 431 } |
432 catch (Exiv2::AnyError& e) { | |
433 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
183 | 434 return NULL; |
435 } | |
178 | 436 } |
437 | |
438 ExifItem *exif_get_next_item(ExifData *exif) | |
439 { | |
184 | 440 try { |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
441 if (exif->exifIter != exif->exifData().end()) |
185 | 442 { |
443 const Exiv2::Metadatum *item = &*exif->exifIter; | |
444 exif->exifIter++; | |
445 return (ExifItem *)item; | |
446 } | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
447 if (exif->iptcIter != exif->iptcData().end()) |
185 | 448 { |
449 const Exiv2::Metadatum *item = &*exif->iptcIter; | |
450 exif->iptcIter++; | |
451 return (ExifItem *)item; | |
452 } | |
200 | 453 #if EXIV2_TEST_VERSION(0,16,0) |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
454 if (exif->xmpIter != exif->xmpData().end()) |
185 | 455 { |
456 const Exiv2::Metadatum *item = &*exif->xmpIter; | |
457 exif->xmpIter++; | |
458 return (ExifItem *)item; | |
459 } | |
200 | 460 #endif |
185 | 461 return NULL; |
184 | 462 } |
463 catch (Exiv2::AnyError& e) { | |
464 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
465 return NULL; | |
466 } | |
178 | 467 } |
468 | |
185 | 469 char *exif_item_get_tag_name(ExifItem *item) |
178 | 470 { |
184 | 471 try { |
472 if (!item) return NULL; | |
185 | 473 return g_strdup(((Exiv2::Metadatum *)item)->key().c_str()); |
184 | 474 } |
475 catch (Exiv2::AnyError& e) { | |
476 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
477 return NULL; | |
478 } | |
178 | 479 } |
480 | |
481 guint exif_item_get_tag_id(ExifItem *item) | |
482 { | |
184 | 483 try { |
484 if (!item) return 0; | |
185 | 485 return ((Exiv2::Metadatum *)item)->tag(); |
184 | 486 } |
487 catch (Exiv2::AnyError& e) { | |
488 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
489 return 0; | |
490 } | |
178 | 491 } |
492 | |
493 guint exif_item_get_elements(ExifItem *item) | |
494 { | |
184 | 495 try { |
496 if (!item) return 0; | |
185 | 497 return ((Exiv2::Metadatum *)item)->count(); |
184 | 498 } |
499 catch (Exiv2::AnyError& e) { | |
500 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
185 | 501 return 0; |
184 | 502 } |
178 | 503 } |
504 | |
505 char *exif_item_get_data(ExifItem *item, guint *data_len) | |
506 { | |
414
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
507 try { |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
508 if (!item) return 0; |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
509 Exiv2::Metadatum *md = (Exiv2::Metadatum *)item; |
855 | 510 if (data_len) *data_len = md->size(); |
414
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
511 char *data = (char *)g_malloc(md->size()); |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
512 long res = md->copy((Exiv2::byte *)data, Exiv2::littleEndian /* should not matter */); |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
513 g_assert(res == md->size()); |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
514 return data; |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
515 } |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
516 catch (Exiv2::AnyError& e) { |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
517 std::cout << "Caught Exiv2 exception '" << e << "'\n"; |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
518 return NULL; |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
519 } |
178 | 520 } |
521 | |
182 | 522 char *exif_item_get_description(ExifItem *item) |
178 | 523 { |
184 | 524 try { |
525 if (!item) return NULL; | |
1053
77ca9a5d42be
fixed charset of exiv2 strings in non-utf8 locales
nadvornik
parents:
1052
diff
changeset
|
526 return g_locale_to_utf8(((Exiv2::Metadatum *)item)->tagLabel().c_str(), -1, NULL, NULL, NULL); |
184 | 527 } |
185 | 528 catch (std::exception& e) { |
529 // std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
184 | 530 return NULL; |
531 } | |
178 | 532 } |
533 | |
534 /* | |
535 invalidTypeId, unsignedByte, asciiString, unsignedShort, | |
536 unsignedLong, unsignedRational, signedByte, undefined, | |
537 signedShort, signedLong, signedRational, string, | |
538 date, time, comment, directory, | |
539 xmpText, xmpAlt, xmpBag, xmpSeq, | |
995 | 540 langAlt, lastTypeId |
178 | 541 */ |
542 | |
184 | 543 static guint format_id_trans_tbl [] = { |
544 EXIF_FORMAT_UNKNOWN, | |
545 EXIF_FORMAT_BYTE_UNSIGNED, | |
546 EXIF_FORMAT_STRING, | |
547 EXIF_FORMAT_SHORT_UNSIGNED, | |
548 EXIF_FORMAT_LONG_UNSIGNED, | |
549 EXIF_FORMAT_RATIONAL_UNSIGNED, | |
550 EXIF_FORMAT_BYTE, | |
551 EXIF_FORMAT_UNDEFINED, | |
552 EXIF_FORMAT_SHORT, | |
553 EXIF_FORMAT_LONG, | |
554 EXIF_FORMAT_RATIONAL, | |
555 EXIF_FORMAT_STRING, | |
556 EXIF_FORMAT_STRING, | |
557 EXIF_FORMAT_STRING, | |
558 EXIF_FORMAT_UNDEFINED, | |
559 EXIF_FORMAT_STRING, | |
560 EXIF_FORMAT_STRING, | |
561 EXIF_FORMAT_STRING, | |
562 EXIF_FORMAT_STRING | |
563 }; | |
564 | |
565 | |
178 | 566 |
567 guint exif_item_get_format_id(ExifItem *item) | |
568 { | |
184 | 569 try { |
570 if (!item) return EXIF_FORMAT_UNKNOWN; | |
185 | 571 guint id = ((Exiv2::Metadatum *)item)->typeId(); |
184 | 572 if (id >= (sizeof(format_id_trans_tbl) / sizeof(format_id_trans_tbl[0])) ) return EXIF_FORMAT_UNKNOWN; |
573 return format_id_trans_tbl[id]; | |
574 } | |
575 catch (Exiv2::AnyError& e) { | |
576 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
577 return EXIF_FORMAT_UNKNOWN; | |
578 } | |
178 | 579 } |
184 | 580 |
178 | 581 const char *exif_item_get_format_name(ExifItem *item, gint brief) |
582 { | |
184 | 583 try { |
584 if (!item) return NULL; | |
185 | 585 return ((Exiv2::Metadatum *)item)->typeName(); |
184 | 586 } |
587 catch (Exiv2::AnyError& e) { | |
588 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
589 return NULL; | |
590 } | |
178 | 591 } |
592 | |
593 | |
594 gchar *exif_item_get_data_as_text(ExifItem *item) | |
595 { | |
183 | 596 try { |
184 | 597 if (!item) return NULL; |
676 | 598 Exiv2::Metadatum *metadatum = (Exiv2::Metadatum *)item; |
677 | 599 #if EXIV2_TEST_VERSION(0,17,0) |
1053
77ca9a5d42be
fixed charset of exiv2 strings in non-utf8 locales
nadvornik
parents:
1052
diff
changeset
|
600 return g_locale_to_utf8(metadatum->print().c_str(), -1, NULL, NULL, NULL); |
676 | 601 #else |
602 std::stringstream str; | |
603 Exiv2::Exifdatum *exifdatum; | |
604 Exiv2::Iptcdatum *iptcdatum; | |
686 | 605 #if EXIV2_TEST_VERSION(0,16,0) |
676 | 606 Exiv2::Xmpdatum *xmpdatum; |
686 | 607 #endif |
855 | 608 if ((exifdatum = dynamic_cast<Exiv2::Exifdatum *>(metadatum))) |
676 | 609 str << *exifdatum; |
610 else if ((iptcdatum = dynamic_cast<Exiv2::Iptcdatum *>(metadatum))) | |
611 str << *iptcdatum; | |
612 #if EXIV2_TEST_VERSION(0,16,0) | |
613 else if ((xmpdatum = dynamic_cast<Exiv2::Xmpdatum *>(metadatum))) | |
614 str << *xmpdatum; | |
615 #endif | |
616 | |
1053
77ca9a5d42be
fixed charset of exiv2 strings in non-utf8 locales
nadvornik
parents:
1052
diff
changeset
|
617 return g_locale_to_utf8(str.str().c_str(), -1, NULL, NULL, NULL); |
676 | 618 #endif |
183 | 619 } |
620 catch (Exiv2::AnyError& e) { | |
621 return NULL; | |
622 } | |
178 | 623 } |
624 | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
625 gchar *exif_item_get_string(ExifItem *item, int idx) |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
626 { |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
627 try { |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
628 if (!item) return NULL; |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
629 Exiv2::Metadatum *em = (Exiv2::Metadatum *)item; |
200 | 630 #if EXIV2_TEST_VERSION(0,16,0) |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
631 std::string str = em->toString(idx); |
200 | 632 #else |
633 std::string str = em->toString(); // FIXME | |
634 #endif | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
635 if (idx == 0 && str == "") str = em->toString(); |
995 | 636 if (str.length() > 5 && str.substr(0, 5) == "lang=") |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
637 { |
995 | 638 std::string::size_type pos = str.find_first_of(' '); |
639 if (pos != std::string::npos) str = str.substr(pos+1); | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
640 } |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
641 |
1053
77ca9a5d42be
fixed charset of exiv2 strings in non-utf8 locales
nadvornik
parents:
1052
diff
changeset
|
642 // return g_locale_to_utf8(str.c_str(), -1, NULL, NULL, NULL); // FIXME |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
643 return g_strdup(str.c_str()); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
644 } |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
645 catch (Exiv2::AnyError& e) { |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
646 return NULL; |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
647 } |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
648 } |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
649 |
178 | 650 |
651 gint exif_item_get_integer(ExifItem *item, gint *value) | |
652 { | |
184 | 653 try { |
654 if (!item) return 0; | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
655 *value = ((Exiv2::Metadatum *)item)->toLong(); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
656 return 1; |
184 | 657 } |
658 catch (Exiv2::AnyError& e) { | |
659 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
660 return 0; | |
661 } | |
178 | 662 } |
663 | |
1058
b600689a677e
Fix up few signed vs unsigned warnings: exif_item_get_rational() last parameter is now of guint type.
zas_
parents:
1055
diff
changeset
|
664 ExifRational *exif_item_get_rational(ExifItem *item, gint *sign, guint n) |
178 | 665 { |
184 | 666 try { |
667 if (!item) return NULL; | |
1052 | 668 if (n >= exif_item_get_elements(item)) return NULL; |
669 Exiv2::Rational v = ((Exiv2::Metadatum *)item)->toRational(n); | |
184 | 670 static ExifRational ret; |
671 ret.num = v.first; | |
672 ret.den = v.second; | |
485 | 673 if (sign) *sign = (((Exiv2::Metadatum *)item)->typeId() == Exiv2::signedRational); |
184 | 674 return &ret; |
675 } | |
676 catch (Exiv2::AnyError& e) { | |
677 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
678 return NULL; | |
679 } | |
178 | 680 } |
681 | |
1053
77ca9a5d42be
fixed charset of exiv2 strings in non-utf8 locales
nadvornik
parents:
1052
diff
changeset
|
682 gchar *exif_get_tag_description_by_key(const gchar *key) |
178 | 683 { |
184 | 684 try { |
685 Exiv2::ExifKey ekey(key); | |
1053
77ca9a5d42be
fixed charset of exiv2 strings in non-utf8 locales
nadvornik
parents:
1052
diff
changeset
|
686 return g_locale_to_utf8(Exiv2::ExifTags::tagLabel(ekey.tag(), ekey.ifdId ()), -1, NULL, NULL, NULL); |
184 | 687 } |
688 catch (Exiv2::AnyError& e) { | |
689 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
690 return NULL; | |
691 } | |
178 | 692 } |
693 | |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
694 int exif_item_set_string(ExifItem *item, const char *str) |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
695 { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
696 try { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
697 if (!item) return 0; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
698 ((Exiv2::Metadatum *)item)->setValue(std::string(str)); |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
699 return 1; |
1008 | 700 } |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
701 catch (Exiv2::AnyError& e) { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
702 return 0; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
703 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
704 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
705 |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
706 int exif_item_delete(ExifData *exif, ExifItem *item) |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
707 { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
708 try { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
709 if (!item) return 0; |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
710 for (Exiv2::ExifData::iterator i = exif->exifData().begin(); i != exif->exifData().end(); ++i) { |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
711 if (((Exiv2::Metadatum *)item) == &*i) { |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
712 i = exif->exifData().erase(i); |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
713 return 1; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
714 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
715 } |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
716 for (Exiv2::IptcData::iterator i = exif->iptcData().begin(); i != exif->iptcData().end(); ++i) { |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
717 if (((Exiv2::Metadatum *)item) == &*i) { |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
718 i = exif->iptcData().erase(i); |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
719 return 1; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
720 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
721 } |
200 | 722 #if EXIV2_TEST_VERSION(0,16,0) |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
723 for (Exiv2::XmpData::iterator i = exif->xmpData().begin(); i != exif->xmpData().end(); ++i) { |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
724 if (((Exiv2::Metadatum *)item) == &*i) { |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
725 i = exif->xmpData().erase(i); |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
726 return 1; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
727 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
728 } |
995 | 729 #endif |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
730 return 0; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
731 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
732 catch (Exiv2::AnyError& e) { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
733 return 0; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
734 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
735 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
736 |
449 | 737 void exif_add_jpeg_color_profile(ExifData *exif, unsigned char *cp_data, guint cp_length) |
738 { | |
1069 | 739 exif->add_jpeg_color_profile(cp_data, cp_length); |
449 | 740 } |
741 | |
1008 | 742 guchar *exif_get_color_profile(ExifData *exif, guint *data_len) |
449 | 743 { |
1069 | 744 guchar *ret = exif->get_jpeg_color_profile(data_len); |
745 if (ret) return ret; | |
746 | |
449 | 747 ExifItem *prof_item = exif_get_item(exif, "Exif.Image.InterColorProfile"); |
748 if (prof_item && exif_item_get_format_id(prof_item) == EXIF_FORMAT_UNDEFINED) | |
1069 | 749 ret = (guchar *)exif_item_get_data(prof_item, data_len); |
750 return ret; | |
449 | 751 } |
752 | |
1008 | 753 #if EXIV2_TEST_VERSION(0,17,90) |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
754 |
1060 | 755 guchar *exif_get_preview(ExifData *exif, guint *data_len, gint requested_width, gint requested_height) |
1008 | 756 { |
757 if (!exif) return NULL; | |
1048
95c418661be8
updated preview loader to work with current svn version of libexiv2
nadvornik
parents:
1025
diff
changeset
|
758 |
1069 | 759 const char* path = exif->image()->io().path().c_str(); |
1048
95c418661be8
updated preview loader to work with current svn version of libexiv2
nadvornik
parents:
1025
diff
changeset
|
760 /* given image pathname, first do simple (and fast) file extension test */ |
1060 | 761 gboolean is_raw = filter_file_class(path, FORMAT_CLASS_RAWIMAGE); |
762 | |
763 if (!is_raw && requested_width == 0) return NULL; | |
1048
95c418661be8
updated preview loader to work with current svn version of libexiv2
nadvornik
parents:
1025
diff
changeset
|
764 |
1008 | 765 try { |
766 | |
1069 | 767 Exiv2::PreviewManager pm(*exif->image()); |
1048
95c418661be8
updated preview loader to work with current svn version of libexiv2
nadvornik
parents:
1025
diff
changeset
|
768 |
1064 | 769 Exiv2::PreviewPropertiesList list = pm.getPreviewProperties(); |
1008 | 770 |
1048
95c418661be8
updated preview loader to work with current svn version of libexiv2
nadvornik
parents:
1025
diff
changeset
|
771 if (!list.empty()) |
1008 | 772 { |
1060 | 773 Exiv2::PreviewPropertiesList::iterator pos; |
774 Exiv2::PreviewPropertiesList::iterator last = --list.end(); | |
775 | |
776 if (requested_width == 0) | |
777 { | |
778 pos = last; // the largest | |
779 } | |
780 else | |
781 { | |
782 pos = list.begin(); | |
783 while (pos != last) | |
784 { | |
785 if (pos->width_ >= (uint32_t)requested_width && | |
786 pos->height_ >= (uint32_t)requested_height) break; | |
787 ++pos; | |
788 } | |
789 | |
790 // we are not interested in smaller thumbnails in normal image formats - we can use full image instead | |
791 if (!is_raw) | |
792 { | |
793 if (pos->width_ < (uint32_t)requested_width || pos->height_ < (uint32_t)requested_height) return NULL; | |
794 } | |
795 } | |
1048
95c418661be8
updated preview loader to work with current svn version of libexiv2
nadvornik
parents:
1025
diff
changeset
|
796 |
1064 | 797 Exiv2::PreviewImage image = pm.getPreviewImage(*pos); |
1048
95c418661be8
updated preview loader to work with current svn version of libexiv2
nadvornik
parents:
1025
diff
changeset
|
798 |
1064 | 799 Exiv2::DataBuf buf = image.copy(); |
1008 | 800 std::pair<Exiv2::byte*, long> p = buf.release(); |
801 | |
802 *data_len = p.second; | |
1048
95c418661be8
updated preview loader to work with current svn version of libexiv2
nadvornik
parents:
1025
diff
changeset
|
803 return p.first; |
1008 | 804 } |
805 return NULL; | |
806 } | |
807 catch (Exiv2::AnyError& e) { | |
808 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
809 return NULL; | |
810 } | |
811 } | |
812 | |
813 void exif_free_preview(guchar *buf) | |
814 { | |
815 delete[] (Exiv2::byte*)buf; | |
816 } | |
817 #endif | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
818 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
819 } |
1008 | 820 #if !EXIV2_TEST_VERSION(0,17,90) |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
821 |
995 | 822 /* This is a dirty hack to support raw file preview, bassed on |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
823 tiffparse.cpp from Exiv2 examples */ |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
824 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
825 class RawFile { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
826 public: |
995 | 827 |
1008 | 828 RawFile(Exiv2::BasicIo &io); |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
829 ~RawFile(); |
995 | 830 |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
831 const Exiv2::Value *find(uint16_t tag, uint16_t group); |
995 | 832 |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
833 unsigned long preview_offset(); |
995 | 834 |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
835 private: |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
836 int type; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
837 Exiv2::TiffComponent::AutoPtr rootDir; |
1008 | 838 Exiv2::BasicIo &io_; |
839 const Exiv2::byte *map_data; | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
840 size_t map_len; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
841 unsigned long offset; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
842 }; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
843 |
1008 | 844 typedef struct _UnmapData UnmapData; |
845 struct _UnmapData | |
846 { | |
847 guchar *ptr; | |
848 guchar *map_data; | |
849 size_t map_len; | |
850 }; | |
851 | |
852 static GList *exif_unmap_list = 0; | |
853 | |
1060 | 854 extern "C" guchar *exif_get_preview(ExifData *exif, guint *data_len, gint requested_width, gint requested_height) |
1008 | 855 { |
856 unsigned long offset; | |
857 | |
858 if (!exif) return NULL; | |
1069 | 859 const char* path = exif->image()->io().path().c_str(); |
1008 | 860 |
861 /* given image pathname, first do simple (and fast) file extension test */ | |
1048
95c418661be8
updated preview loader to work with current svn version of libexiv2
nadvornik
parents:
1025
diff
changeset
|
862 if (!filter_file_class(path, FORMAT_CLASS_RAWIMAGE)) return NULL; |
1008 | 863 |
864 try { | |
865 struct stat st; | |
866 guchar *map_data; | |
867 size_t map_len; | |
868 UnmapData *ud; | |
869 int fd; | |
870 | |
1069 | 871 RawFile rf(exif->image()->io()); |
1008 | 872 offset = rf.preview_offset(); |
873 DEBUG_1("%s: offset %lu", path, offset); | |
874 | |
875 fd = open(path, O_RDONLY); | |
876 if (fd == -1) | |
877 { | |
1048
95c418661be8
updated preview loader to work with current svn version of libexiv2
nadvornik
parents:
1025
diff
changeset
|
878 return NULL; |
1008 | 879 } |
880 | |
881 if (fstat(fd, &st) == -1) | |
882 { | |
883 close(fd); | |
1048
95c418661be8
updated preview loader to work with current svn version of libexiv2
nadvornik
parents:
1025
diff
changeset
|
884 return NULL; |
1008 | 885 } |
886 map_len = st.st_size; | |
887 map_data = (guchar *) mmap(0, map_len, PROT_READ, MAP_PRIVATE, fd, 0); | |
888 close(fd); | |
889 if (map_data == MAP_FAILED) | |
890 { | |
1048
95c418661be8
updated preview loader to work with current svn version of libexiv2
nadvornik
parents:
1025
diff
changeset
|
891 return NULL; |
1008 | 892 } |
893 *data_len = map_len - offset; | |
894 ud = g_new(UnmapData, 1); | |
895 ud->ptr = map_data + offset; | |
896 ud->map_data = map_data; | |
897 ud->map_len = map_len; | |
898 | |
899 exif_unmap_list = g_list_prepend(exif_unmap_list, ud); | |
900 return ud->ptr; | |
901 | |
902 } | |
903 catch (Exiv2::AnyError& e) { | |
904 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
905 } | |
906 return NULL; | |
907 | |
908 } | |
909 | |
910 void exif_free_preview(guchar *buf) | |
911 { | |
912 GList *work = exif_unmap_list; | |
913 | |
914 while (work) | |
915 { | |
916 UnmapData *ud = (UnmapData *)work->data; | |
917 if (ud->ptr == buf) | |
918 { | |
919 munmap(ud->map_data, ud->map_len); | |
920 exif_unmap_list = g_list_remove_link(exif_unmap_list, work); | |
921 g_free(ud); | |
922 return; | |
923 } | |
1025 | 924 work = work->next; |
1008 | 925 } |
926 g_assert_not_reached(); | |
927 } | |
928 | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
929 using namespace Exiv2; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
930 |
1008 | 931 RawFile::RawFile(BasicIo &io) : io_(io), map_data(NULL), map_len(0), offset(0) |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
932 { |
1008 | 933 /* |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
934 struct stat st; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
935 if (fstat(fd, &st) == -1) |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
936 { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
937 throw Error(14); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
938 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
939 map_len = st.st_size; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
940 map_data = (Exiv2::byte *) mmap(0, map_len, PROT_READ, MAP_PRIVATE, fd, 0); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
941 if (map_data == MAP_FAILED) |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
942 { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
943 throw Error(14); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
944 } |
1008 | 945 */ |
946 if (io.open() != 0) { | |
947 throw Error(9, io.path(), strError()); | |
948 } | |
949 | |
950 map_data = io.mmap(); | |
951 map_len = io.size(); | |
952 | |
953 | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
954 type = Exiv2::ImageFactory::getType(map_data, map_len); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
955 |
200 | 956 #if EXIV2_TEST_VERSION(0,16,0) |
201 | 957 TiffHeaderBase *tiffHeader = NULL; |
200 | 958 #else |
201 | 959 TiffHeade2 *tiffHeader = NULL; |
200 | 960 #endif |
201 | 961 Cr2Header *cr2Header = NULL; |
962 | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
963 switch (type) { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
964 case Exiv2::ImageType::tiff: |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
965 tiffHeader = new TiffHeade2(); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
966 break; |
201 | 967 case Exiv2::ImageType::cr2: |
968 cr2Header = new Cr2Header(); | |
969 break; | |
200 | 970 #if EXIV2_TEST_VERSION(0,16,0) |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
971 case Exiv2::ImageType::orf: |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
972 tiffHeader = new OrfHeader(); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
973 break; |
200 | 974 #endif |
975 #if EXIV2_TEST_VERSION(0,13,0) | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
976 case Exiv2::ImageType::raf: |
995 | 977 if (map_len < 84 + 4) throw Error(14); |
978 offset = getULong(map_data + 84, bigEndian); | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
979 return; |
200 | 980 #endif |
191 | 981 case Exiv2::ImageType::crw: |
982 { | |
983 // Parse the image, starting with a CIFF header component | |
984 Exiv2::CiffHeader::AutoPtr parseTree(new Exiv2::CiffHeader); | |
985 parseTree->read(map_data, map_len); | |
995 | 986 CiffComponent *entry = parseTree->findComponent(0x2007, 0); |
191 | 987 if (entry) offset = entry->pData() - map_data; |
988 return; | |
989 } | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
990 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
991 default: |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
992 throw Error(3, "RAW"); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
993 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
994 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
995 // process tiff-like formats |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
996 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
997 TiffCompFactoryFct createFct = TiffCreator::create; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
998 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
999 rootDir = createFct(Tag::root, Group::none); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1000 if (0 == rootDir.get()) { |
995 | 1001 throw Error(1, "No root element defined in TIFF structure"); |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1002 } |
201 | 1003 |
1004 if (tiffHeader) | |
1005 { | |
1006 if (!tiffHeader->read(map_data, map_len)) throw Error(3, "TIFF"); | |
200 | 1007 #if EXIV2_TEST_VERSION(0,16,0) |
201 | 1008 rootDir->setStart(map_data + tiffHeader->offset()); |
200 | 1009 #else |
201 | 1010 rootDir->setStart(map_data + tiffHeader->ifdOffset()); |
200 | 1011 #endif |
201 | 1012 } |
1013 | |
1014 if (cr2Header) | |
1015 { | |
1016 rootDir->setStart(map_data + cr2Header->offset()); | |
1017 } | |
1018 | |
1019 TiffRwState::AutoPtr state(new TiffRwState(tiffHeader ? tiffHeader->byteOrder() : littleEndian, 0, createFct)); | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1020 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1021 TiffReader reader(map_data, |
995 | 1022 map_len, |
1023 rootDir.get(), | |
1024 state); | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1025 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1026 rootDir->accept(reader); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1027 |
995 | 1028 if (tiffHeader) |
201 | 1029 delete tiffHeader; |
995 | 1030 if (cr2Header) |
201 | 1031 delete cr2Header; |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1032 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1033 |
609
b690cecbf5b8
Use function(void) instead of function() for declaring functions which
zas_
parents:
586
diff
changeset
|
1034 RawFile::~RawFile(void) |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1035 { |
1008 | 1036 io_.munmap(); |
1037 io_.close(); | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1038 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1039 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1040 const Value * RawFile::find(uint16_t tag, uint16_t group) |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1041 { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1042 TiffFinder finder(tag, group); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1043 rootDir->accept(finder); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1044 TiffEntryBase* te = dynamic_cast<TiffEntryBase*>(finder.result()); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1045 if (te) |
194 | 1046 { |
495 | 1047 DEBUG_1("(tag: %04x %04x) ", tag, group); |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1048 return te->pValue(); |
194 | 1049 } |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1050 else |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1051 return NULL; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1052 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1053 |
609
b690cecbf5b8
Use function(void) instead of function() for declaring functions which
zas_
parents:
586
diff
changeset
|
1054 unsigned long RawFile::preview_offset(void) |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1055 { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1056 const Value *val; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1057 if (offset) return offset; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1058 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1059 if (type == Exiv2::ImageType::cr2) |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1060 { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1061 val = find(0x111, Group::ifd0); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1062 if (val) return val->toLong(); |
995 | 1063 |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1064 return 0; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1065 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1066 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1067 val = find(0x201, Group::sub0_0); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1068 if (val) return val->toLong(); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1069 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1070 val = find(0x201, Group::ifd0); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1071 if (val) return val->toLong(); |
995 | 1072 |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1073 val = find(0x201, Group::ignr); // for PEF files, originally it was probably ifd2 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1074 if (val) return val->toLong(); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1075 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1076 val = find(0x111, Group::sub0_1); // dng |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1077 if (val) return val->toLong(); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1078 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1079 return 0; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1080 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1081 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
1082 |
1008 | 1083 #endif |
178 | 1084 |
1085 | |
995 | 1086 #endif |
178 | 1087 /* HAVE_EXIV2 */ |
1055
1646720364cf
Adding a vim modeline to all files - patch by Klaus Ethgen
nadvornik
parents:
1053
diff
changeset
|
1088 /* vim: set shiftwidth=8 softtabstop=0 cindent cinoptions={1s: */ |