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