Mercurial > geeqie.yaz
annotate src/exiv2.cc @ 1025:448d174454e1
fixed possible endless loop
author | nadvornik |
---|---|
date | Sun, 31 Aug 2008 18:53:11 +0000 |
parents | 9865e22d05f3 |
children | 95c418661be8 |
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 { | |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
64 Exiv2::Image::AutoPtr image; |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
65 Exiv2::Image::AutoPtr sidecar; |
185 | 66 Exiv2::ExifData::const_iterator exifIter; /* for exif_get_next_item */ |
67 Exiv2::IptcData::const_iterator iptcIter; /* for exif_get_next_item */ | |
200 | 68 #if EXIV2_TEST_VERSION(0,16,0) |
185 | 69 Exiv2::XmpData::const_iterator xmpIter; /* for exif_get_next_item */ |
200 | 70 #endif |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
71 bool have_sidecar; |
184 | 72 |
449 | 73 /* the icc profile in jpeg is not technically exif - store it here */ |
74 unsigned char *cp_data; | |
75 guint cp_length; | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
76 |
449 | 77 _ExifData(gchar *path, gchar *sidecar_path) |
184 | 78 { |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
79 have_sidecar = false; |
449 | 80 cp_data = NULL; |
81 cp_length = 0; | |
496
a1f13fab6686
fixed a bug in opening files with non-utf8 locales in exiv2.cc
nadvornik
parents:
495
diff
changeset
|
82 gchar *pathl = path_from_utf8(path); |
a1f13fab6686
fixed a bug in opening files with non-utf8 locales in exiv2.cc
nadvornik
parents:
495
diff
changeset
|
83 image = Exiv2::ImageFactory::open(pathl); |
a1f13fab6686
fixed a bug in opening files with non-utf8 locales in exiv2.cc
nadvornik
parents:
495
diff
changeset
|
84 g_free(pathl); |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
85 // g_assert (image.get() != 0); |
184 | 86 image->readMetadata(); |
200 | 87 |
88 #if EXIV2_TEST_VERSION(0,16,0) | |
506
fc9c8a3e1a8b
Handle the newline in DEBUG_N() macro instead of adding one
zas_
parents:
496
diff
changeset
|
89 DEBUG_2("xmp count %li", image->xmpData().count()); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
90 if (sidecar_path && image->xmpData().empty()) |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
91 { |
496
a1f13fab6686
fixed a bug in opening files with non-utf8 locales in exiv2.cc
nadvornik
parents:
495
diff
changeset
|
92 gchar *sidecar_pathl = path_from_utf8(sidecar_path); |
a1f13fab6686
fixed a bug in opening files with non-utf8 locales in exiv2.cc
nadvornik
parents:
495
diff
changeset
|
93 sidecar = Exiv2::ImageFactory::open(sidecar_pathl); |
a1f13fab6686
fixed a bug in opening files with non-utf8 locales in exiv2.cc
nadvornik
parents:
495
diff
changeset
|
94 g_free(sidecar_pathl); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
95 sidecar->readMetadata(); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
96 have_sidecar = sidecar->good(); |
506
fc9c8a3e1a8b
Handle the newline in DEBUG_N() macro instead of adding one
zas_
parents:
496
diff
changeset
|
97 DEBUG_2("sidecar xmp count %li", sidecar->xmpData().count()); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
98 } |
449 | 99 |
452
0a69a779395a
fixed color profile code for older versions of exiv2
nadvornik
parents:
449
diff
changeset
|
100 #endif |
0a69a779395a
fixed color profile code for older versions of exiv2
nadvornik
parents:
449
diff
changeset
|
101 #if EXIV2_TEST_VERSION(0,14,0) |
449 | 102 if (image->mimeType() == std::string("image/jpeg")) |
103 { | |
104 /* try to get jpeg color profile */ | |
105 Exiv2::BasicIo &io = image->io(); | |
106 gint open = io.isopen(); | |
107 if (!open) io.open(); | |
108 unsigned char *mapped = (unsigned char*)io.mmap(); | |
109 if (mapped) exif_jpeg_parse_color(this, mapped, io.size()); | |
110 io.munmap(); | |
111 if (!open) io.close(); | |
112 } | |
995 | 113 #endif |
184 | 114 } |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
115 |
449 | 116 ~_ExifData() |
117 { | |
118 if (cp_data) g_free(cp_data); | |
119 } | |
120 | |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
121 void writeMetadata() |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
122 { |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
123 if (have_sidecar) sidecar->writeMetadata(); |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
124 image->writeMetadata(); |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
125 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
126 |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
127 Exiv2::ExifData &exifData () |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
128 { |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
129 return image->exifData(); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
130 } |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
131 |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
132 Exiv2::IptcData &iptcData () |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
133 { |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
134 return image->iptcData(); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
135 } |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
136 |
200 | 137 #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
|
138 Exiv2::XmpData &xmpData () |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
139 { |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
140 return have_sidecar ? sidecar->xmpData() : image->xmpData(); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
141 } |
200 | 142 #endif |
184 | 143 |
178 | 144 }; |
145 | |
184 | 146 extern "C" { |
178 | 147 |
449 | 148 ExifData *exif_read(gchar *path, gchar *sidecar_path) |
178 | 149 { |
506
fc9c8a3e1a8b
Handle the newline in DEBUG_N() macro instead of adding one
zas_
parents:
496
diff
changeset
|
150 DEBUG_1("exif read %s, sidecar: %s", path, sidecar_path ? sidecar_path : "-"); |
178 | 151 try { |
449 | 152 return new ExifData(path, sidecar_path); |
178 | 153 } |
154 catch (Exiv2::AnyError& e) { | |
155 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
|
156 return NULL; |
178 | 157 } |
179
37004d5a584a
and first version that actually shows some exif data (see advanced view)
nadvornik
parents:
178
diff
changeset
|
158 |
178 | 159 } |
160 | |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
161 int exif_write(ExifData *exif) |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
162 { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
163 try { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
164 exif->writeMetadata(); |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
165 return 1; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
166 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
167 catch (Exiv2::AnyError& e) { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
168 std::cout << "Caught Exiv2 exception '" << e << "'\n"; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
169 return 0; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
170 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
171 |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
172 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
173 |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
174 |
178 | 175 void exif_free(ExifData *exif) |
176 { | |
182 | 177 |
178 delete exif; | |
178 | 179 } |
180 | |
184 | 181 ExifItem *exif_get_item(ExifData *exif, const gchar *key) |
178 | 182 { |
183 | 183 try { |
452
0a69a779395a
fixed color profile code for older versions of exiv2
nadvornik
parents:
449
diff
changeset
|
184 Exiv2::Metadatum *item = NULL; |
185 | 185 try { |
186 Exiv2::ExifKey ekey(key); | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
187 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
|
188 if (pos == exif->exifData().end()) return NULL; |
185 | 189 item = &*pos; |
190 } | |
191 catch (Exiv2::AnyError& e) { | |
192 try { | |
193 Exiv2::IptcKey ekey(key); | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
194 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
|
195 if (pos == exif->iptcData().end()) return NULL; |
185 | 196 item = &*pos; |
197 } | |
198 catch (Exiv2::AnyError& e) { | |
200 | 199 #if EXIV2_TEST_VERSION(0,16,0) |
185 | 200 Exiv2::XmpKey ekey(key); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
201 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
|
202 if (pos == exif->xmpData().end()) return NULL; |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
203 item = &*pos; |
200 | 204 #endif |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
205 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
206 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
207 return (ExifItem *)item; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
208 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
209 catch (Exiv2::AnyError& e) { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
210 std::cout << "Caught Exiv2 exception '" << e << "'\n"; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
211 return NULL; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
212 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
213 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
214 |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
215 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
|
216 { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
217 try { |
452
0a69a779395a
fixed color profile code for older versions of exiv2
nadvornik
parents:
449
diff
changeset
|
218 Exiv2::Metadatum *item = NULL; |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
219 try { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
220 Exiv2::ExifKey ekey(key); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
221 exif->exifData().add(ekey, NULL); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
222 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
|
223 pos--; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
224 item = &*pos; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
225 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
226 catch (Exiv2::AnyError& e) { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
227 try { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
228 Exiv2::IptcKey ekey(key); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
229 exif->iptcData().add(ekey, NULL); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
230 Exiv2::IptcData::iterator pos = exif->iptcData().end(); |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
231 pos--; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
232 item = &*pos; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
233 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
234 catch (Exiv2::AnyError& e) { |
200 | 235 #if EXIV2_TEST_VERSION(0,16,0) |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
236 Exiv2::XmpKey ekey(key); |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
237 exif->xmpData().add(ekey, NULL); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
238 Exiv2::XmpData::iterator pos = exif->xmpData().end(); |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
239 pos--; |
185 | 240 item = &*pos; |
200 | 241 #endif |
185 | 242 } |
243 } | |
184 | 244 return (ExifItem *)item; |
183 | 245 } |
246 catch (Exiv2::AnyError& e) { | |
184 | 247 std::cout << "Caught Exiv2 exception '" << e << "'\n"; |
248 return NULL; | |
249 } | |
250 } | |
251 | |
252 | |
253 ExifItem *exif_get_first_item(ExifData *exif) | |
254 { | |
255 try { | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
256 exif->exifIter = exif->exifData().begin(); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
257 exif->iptcIter = exif->iptcData().begin(); |
200 | 258 #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
|
259 exif->xmpIter = exif->xmpData().begin(); |
200 | 260 #endif |
995 | 261 if (exif->exifIter != exif->exifData().end()) |
185 | 262 { |
263 const Exiv2::Metadatum *item = &*exif->exifIter; | |
264 exif->exifIter++; | |
265 return (ExifItem *)item; | |
266 } | |
995 | 267 if (exif->iptcIter != exif->iptcData().end()) |
185 | 268 { |
269 const Exiv2::Metadatum *item = &*exif->iptcIter; | |
270 exif->iptcIter++; | |
271 return (ExifItem *)item; | |
272 } | |
200 | 273 #if EXIV2_TEST_VERSION(0,16,0) |
995 | 274 if (exif->xmpIter != exif->xmpData().end()) |
185 | 275 { |
276 const Exiv2::Metadatum *item = &*exif->xmpIter; | |
277 exif->xmpIter++; | |
278 return (ExifItem *)item; | |
279 } | |
200 | 280 #endif |
185 | 281 return NULL; |
282 | |
184 | 283 } |
284 catch (Exiv2::AnyError& e) { | |
285 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
183 | 286 return NULL; |
287 } | |
178 | 288 } |
289 | |
290 ExifItem *exif_get_next_item(ExifData *exif) | |
291 { | |
184 | 292 try { |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
293 if (exif->exifIter != exif->exifData().end()) |
185 | 294 { |
295 const Exiv2::Metadatum *item = &*exif->exifIter; | |
296 exif->exifIter++; | |
297 return (ExifItem *)item; | |
298 } | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
299 if (exif->iptcIter != exif->iptcData().end()) |
185 | 300 { |
301 const Exiv2::Metadatum *item = &*exif->iptcIter; | |
302 exif->iptcIter++; | |
303 return (ExifItem *)item; | |
304 } | |
200 | 305 #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
|
306 if (exif->xmpIter != exif->xmpData().end()) |
185 | 307 { |
308 const Exiv2::Metadatum *item = &*exif->xmpIter; | |
309 exif->xmpIter++; | |
310 return (ExifItem *)item; | |
311 } | |
200 | 312 #endif |
185 | 313 return NULL; |
184 | 314 } |
315 catch (Exiv2::AnyError& e) { | |
316 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
317 return NULL; | |
318 } | |
178 | 319 } |
320 | |
185 | 321 char *exif_item_get_tag_name(ExifItem *item) |
178 | 322 { |
184 | 323 try { |
324 if (!item) return NULL; | |
185 | 325 return g_strdup(((Exiv2::Metadatum *)item)->key().c_str()); |
184 | 326 } |
327 catch (Exiv2::AnyError& e) { | |
328 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
329 return NULL; | |
330 } | |
178 | 331 } |
332 | |
333 guint exif_item_get_tag_id(ExifItem *item) | |
334 { | |
184 | 335 try { |
336 if (!item) return 0; | |
185 | 337 return ((Exiv2::Metadatum *)item)->tag(); |
184 | 338 } |
339 catch (Exiv2::AnyError& e) { | |
340 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
341 return 0; | |
342 } | |
178 | 343 } |
344 | |
345 guint exif_item_get_elements(ExifItem *item) | |
346 { | |
184 | 347 try { |
348 if (!item) return 0; | |
185 | 349 return ((Exiv2::Metadatum *)item)->count(); |
184 | 350 } |
351 catch (Exiv2::AnyError& e) { | |
352 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
185 | 353 return 0; |
184 | 354 } |
178 | 355 } |
356 | |
357 char *exif_item_get_data(ExifItem *item, guint *data_len) | |
358 { | |
414
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
359 try { |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
360 if (!item) return 0; |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
361 Exiv2::Metadatum *md = (Exiv2::Metadatum *)item; |
855 | 362 if (data_len) *data_len = md->size(); |
414
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
363 char *data = (char *)g_malloc(md->size()); |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
364 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
|
365 g_assert(res == md->size()); |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
366 return data; |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
367 } |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
368 catch (Exiv2::AnyError& e) { |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
369 std::cout << "Caught Exiv2 exception '" << e << "'\n"; |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
370 return NULL; |
49c1cbe058ae
partially fixed reading embedded color profiles with exiv2
nadvornik
parents:
304
diff
changeset
|
371 } |
178 | 372 } |
373 | |
182 | 374 char *exif_item_get_description(ExifItem *item) |
178 | 375 { |
184 | 376 try { |
377 if (!item) return NULL; | |
185 | 378 return g_strdup(((Exiv2::Metadatum *)item)->tagLabel().c_str()); |
184 | 379 } |
185 | 380 catch (std::exception& e) { |
381 // std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
184 | 382 return NULL; |
383 } | |
178 | 384 } |
385 | |
386 /* | |
387 invalidTypeId, unsignedByte, asciiString, unsignedShort, | |
388 unsignedLong, unsignedRational, signedByte, undefined, | |
389 signedShort, signedLong, signedRational, string, | |
390 date, time, comment, directory, | |
391 xmpText, xmpAlt, xmpBag, xmpSeq, | |
995 | 392 langAlt, lastTypeId |
178 | 393 */ |
394 | |
184 | 395 static guint format_id_trans_tbl [] = { |
396 EXIF_FORMAT_UNKNOWN, | |
397 EXIF_FORMAT_BYTE_UNSIGNED, | |
398 EXIF_FORMAT_STRING, | |
399 EXIF_FORMAT_SHORT_UNSIGNED, | |
400 EXIF_FORMAT_LONG_UNSIGNED, | |
401 EXIF_FORMAT_RATIONAL_UNSIGNED, | |
402 EXIF_FORMAT_BYTE, | |
403 EXIF_FORMAT_UNDEFINED, | |
404 EXIF_FORMAT_SHORT, | |
405 EXIF_FORMAT_LONG, | |
406 EXIF_FORMAT_RATIONAL, | |
407 EXIF_FORMAT_STRING, | |
408 EXIF_FORMAT_STRING, | |
409 EXIF_FORMAT_STRING, | |
410 EXIF_FORMAT_UNDEFINED, | |
411 EXIF_FORMAT_STRING, | |
412 EXIF_FORMAT_STRING, | |
413 EXIF_FORMAT_STRING, | |
414 EXIF_FORMAT_STRING | |
415 }; | |
416 | |
417 | |
178 | 418 |
419 guint exif_item_get_format_id(ExifItem *item) | |
420 { | |
184 | 421 try { |
422 if (!item) return EXIF_FORMAT_UNKNOWN; | |
185 | 423 guint id = ((Exiv2::Metadatum *)item)->typeId(); |
184 | 424 if (id >= (sizeof(format_id_trans_tbl) / sizeof(format_id_trans_tbl[0])) ) return EXIF_FORMAT_UNKNOWN; |
425 return format_id_trans_tbl[id]; | |
426 } | |
427 catch (Exiv2::AnyError& e) { | |
428 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
429 return EXIF_FORMAT_UNKNOWN; | |
430 } | |
178 | 431 } |
184 | 432 |
178 | 433 const char *exif_item_get_format_name(ExifItem *item, gint brief) |
434 { | |
184 | 435 try { |
436 if (!item) return NULL; | |
185 | 437 return ((Exiv2::Metadatum *)item)->typeName(); |
184 | 438 } |
439 catch (Exiv2::AnyError& e) { | |
440 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
441 return NULL; | |
442 } | |
178 | 443 } |
444 | |
445 | |
446 gchar *exif_item_get_data_as_text(ExifItem *item) | |
447 { | |
183 | 448 try { |
184 | 449 if (!item) return NULL; |
676 | 450 Exiv2::Metadatum *metadatum = (Exiv2::Metadatum *)item; |
677 | 451 #if EXIV2_TEST_VERSION(0,17,0) |
676 | 452 return g_strdup(metadatum->print().c_str()); |
453 #else | |
454 std::stringstream str; | |
455 Exiv2::Exifdatum *exifdatum; | |
456 Exiv2::Iptcdatum *iptcdatum; | |
686 | 457 #if EXIV2_TEST_VERSION(0,16,0) |
676 | 458 Exiv2::Xmpdatum *xmpdatum; |
686 | 459 #endif |
855 | 460 if ((exifdatum = dynamic_cast<Exiv2::Exifdatum *>(metadatum))) |
676 | 461 str << *exifdatum; |
462 else if ((iptcdatum = dynamic_cast<Exiv2::Iptcdatum *>(metadatum))) | |
463 str << *iptcdatum; | |
464 #if EXIV2_TEST_VERSION(0,16,0) | |
465 else if ((xmpdatum = dynamic_cast<Exiv2::Xmpdatum *>(metadatum))) | |
466 str << *xmpdatum; | |
467 #endif | |
468 | |
469 return g_strdup(str.str().c_str()); | |
470 #endif | |
183 | 471 } |
472 catch (Exiv2::AnyError& e) { | |
473 return NULL; | |
474 } | |
178 | 475 } |
476 | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
477 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
|
478 { |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
479 try { |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
480 if (!item) return NULL; |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
481 Exiv2::Metadatum *em = (Exiv2::Metadatum *)item; |
200 | 482 #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
|
483 std::string str = em->toString(idx); |
200 | 484 #else |
485 std::string str = em->toString(); // FIXME | |
486 #endif | |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
487 if (idx == 0 && str == "") str = em->toString(); |
995 | 488 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
|
489 { |
995 | 490 std::string::size_type pos = str.find_first_of(' '); |
491 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
|
492 } |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
493 |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
494 return g_strdup(str.c_str()); |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
495 } |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
496 catch (Exiv2::AnyError& e) { |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
497 return NULL; |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
498 } |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
499 } |
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
500 |
178 | 501 |
502 gint exif_item_get_integer(ExifItem *item, gint *value) | |
503 { | |
184 | 504 try { |
505 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
|
506 *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
|
507 return 1; |
184 | 508 } |
509 catch (Exiv2::AnyError& e) { | |
510 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
511 return 0; | |
512 } | |
178 | 513 } |
514 | |
515 ExifRational *exif_item_get_rational(ExifItem *item, gint *sign) | |
516 { | |
184 | 517 try { |
518 if (!item) return NULL; | |
185 | 519 Exiv2::Rational v = ((Exiv2::Metadatum *)item)->toRational(); |
184 | 520 static ExifRational ret; |
521 ret.num = v.first; | |
522 ret.den = v.second; | |
485 | 523 if (sign) *sign = (((Exiv2::Metadatum *)item)->typeId() == Exiv2::signedRational); |
184 | 524 return &ret; |
525 } | |
526 catch (Exiv2::AnyError& e) { | |
527 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
528 return NULL; | |
529 } | |
178 | 530 } |
531 | |
182 | 532 const gchar *exif_get_tag_description_by_key(const gchar *key) |
178 | 533 { |
184 | 534 try { |
535 Exiv2::ExifKey ekey(key); | |
536 return Exiv2::ExifTags::tagLabel(ekey.tag(), ekey.ifdId ()); | |
537 } | |
538 catch (Exiv2::AnyError& e) { | |
539 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
540 return NULL; | |
541 } | |
178 | 542 } |
543 | |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
544 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
|
545 { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
546 try { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
547 if (!item) return 0; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
548 ((Exiv2::Metadatum *)item)->setValue(std::string(str)); |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
549 return 1; |
1008 | 550 } |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
551 catch (Exiv2::AnyError& e) { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
552 return 0; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
553 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
554 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
555 |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
556 int exif_item_delete(ExifData *exif, ExifItem *item) |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
557 { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
558 try { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
559 if (!item) return 0; |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
560 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
|
561 if (((Exiv2::Metadatum *)item) == &*i) { |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
562 i = exif->exifData().erase(i); |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
563 return 1; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
564 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
565 } |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
566 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
|
567 if (((Exiv2::Metadatum *)item) == &*i) { |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
568 i = exif->iptcData().erase(i); |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
569 return 1; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
570 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
571 } |
200 | 572 #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
|
573 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
|
574 if (((Exiv2::Metadatum *)item) == &*i) { |
188
0584cb78aa14
write comment and keywords to xmp, sidecars are used if exist
nadvornik
parents:
187
diff
changeset
|
575 i = exif->xmpData().erase(i); |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
576 return 1; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
577 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
578 } |
995 | 579 #endif |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
580 return 0; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
581 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
582 catch (Exiv2::AnyError& e) { |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
583 return 0; |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
584 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
585 } |
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
586 |
449 | 587 void exif_add_jpeg_color_profile(ExifData *exif, unsigned char *cp_data, guint cp_length) |
588 { | |
589 if (exif->cp_data) g_free(exif->cp_data); | |
590 exif->cp_data = cp_data; | |
591 exif->cp_length =cp_length; | |
592 } | |
593 | |
1008 | 594 guchar *exif_get_color_profile(ExifData *exif, guint *data_len) |
449 | 595 { |
596 if (exif->cp_data) | |
597 { | |
598 if (data_len) *data_len = exif->cp_length; | |
599 return (unsigned char *) g_memdup(exif->cp_data, exif->cp_length); | |
600 } | |
601 ExifItem *prof_item = exif_get_item(exif, "Exif.Image.InterColorProfile"); | |
602 if (prof_item && exif_item_get_format_id(prof_item) == EXIF_FORMAT_UNDEFINED) | |
603 return (unsigned char *) exif_item_get_data(prof_item, data_len); | |
604 return NULL; | |
605 } | |
606 | |
1008 | 607 #if EXIV2_TEST_VERSION(0,17,90) |
187
9eafc4957f1a
write support in Exiv2 wrapper; for now only string values
nadvornik
parents:
186
diff
changeset
|
608 |
1008 | 609 guchar *exif_get_preview(ExifData *exif, guint *data_len) |
610 { | |
611 if (!exif) return NULL; | |
612 try { | |
613 | |
614 Exiv2::PreviewImageList list(*exif->image); | |
615 list.read(); | |
616 | |
617 Exiv2::PreviewImageList::iterator pos = list.begin(); | |
618 if (pos != list.end()) | |
619 { | |
620 Exiv2::DataBuf buf = pos->copy(); | |
621 std::pair<Exiv2::byte*, long> p = buf.release(); | |
622 | |
623 *data_len = p.second; | |
624 return p.first; | |
625 } | |
626 return NULL; | |
627 } | |
628 catch (Exiv2::AnyError& e) { | |
629 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
630 return NULL; | |
631 } | |
632 } | |
633 | |
634 void exif_free_preview(guchar *buf) | |
635 { | |
636 delete[] (Exiv2::byte*)buf; | |
637 } | |
638 #endif | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
639 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
640 } |
1008 | 641 #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
|
642 |
995 | 643 /* 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
|
644 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
|
645 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
646 class RawFile { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
647 public: |
995 | 648 |
1008 | 649 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
|
650 ~RawFile(); |
995 | 651 |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
652 const Exiv2::Value *find(uint16_t tag, uint16_t group); |
995 | 653 |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
654 unsigned long preview_offset(); |
995 | 655 |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
656 private: |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
657 int type; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
658 Exiv2::TiffComponent::AutoPtr rootDir; |
1008 | 659 Exiv2::BasicIo &io_; |
660 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
|
661 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
|
662 unsigned long offset; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
663 }; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
664 |
1008 | 665 typedef struct _UnmapData UnmapData; |
666 struct _UnmapData | |
667 { | |
668 guchar *ptr; | |
669 guchar *map_data; | |
670 size_t map_len; | |
671 }; | |
672 | |
673 static GList *exif_unmap_list = 0; | |
674 | |
675 extern "C" guchar *exif_get_preview(ExifData *exif, guint *data_len) | |
676 { | |
677 unsigned long offset; | |
678 | |
679 if (!exif) return NULL; | |
680 const char* path = exif->image->io().path().c_str(); | |
681 | |
682 /* given image pathname, first do simple (and fast) file extension test */ | |
683 if (!filter_file_class(path, FORMAT_CLASS_RAWIMAGE)) return 0; | |
684 | |
685 try { | |
686 struct stat st; | |
687 guchar *map_data; | |
688 size_t map_len; | |
689 UnmapData *ud; | |
690 int fd; | |
691 | |
692 RawFile rf(exif->image->io()); | |
693 offset = rf.preview_offset(); | |
694 DEBUG_1("%s: offset %lu", path, offset); | |
695 | |
696 fd = open(path, O_RDONLY); | |
697 if (fd == -1) | |
698 { | |
699 return 0; | |
700 } | |
701 | |
702 if (fstat(fd, &st) == -1) | |
703 { | |
704 close(fd); | |
705 return 0; | |
706 } | |
707 map_len = st.st_size; | |
708 map_data = (guchar *) mmap(0, map_len, PROT_READ, MAP_PRIVATE, fd, 0); | |
709 close(fd); | |
710 if (map_data == MAP_FAILED) | |
711 { | |
712 return 0; | |
713 } | |
714 *data_len = map_len - offset; | |
715 ud = g_new(UnmapData, 1); | |
716 ud->ptr = map_data + offset; | |
717 ud->map_data = map_data; | |
718 ud->map_len = map_len; | |
719 | |
720 exif_unmap_list = g_list_prepend(exif_unmap_list, ud); | |
721 return ud->ptr; | |
722 | |
723 } | |
724 catch (Exiv2::AnyError& e) { | |
725 std::cout << "Caught Exiv2 exception '" << e << "'\n"; | |
726 } | |
727 return NULL; | |
728 | |
729 } | |
730 | |
731 void exif_free_preview(guchar *buf) | |
732 { | |
733 GList *work = exif_unmap_list; | |
734 | |
735 while (work) | |
736 { | |
737 UnmapData *ud = (UnmapData *)work->data; | |
738 if (ud->ptr == buf) | |
739 { | |
740 munmap(ud->map_data, ud->map_len); | |
741 exif_unmap_list = g_list_remove_link(exif_unmap_list, work); | |
742 g_free(ud); | |
743 return; | |
744 } | |
1025 | 745 work = work->next; |
1008 | 746 } |
747 g_assert_not_reached(); | |
748 } | |
749 | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
750 using namespace Exiv2; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
751 |
1008 | 752 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
|
753 { |
1008 | 754 /* |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
755 struct stat st; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
756 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
|
757 { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
758 throw Error(14); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
759 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
760 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
|
761 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
|
762 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
|
763 { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
764 throw Error(14); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
765 } |
1008 | 766 */ |
767 if (io.open() != 0) { | |
768 throw Error(9, io.path(), strError()); | |
769 } | |
770 | |
771 map_data = io.mmap(); | |
772 map_len = io.size(); | |
773 | |
774 | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
775 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
|
776 |
200 | 777 #if EXIV2_TEST_VERSION(0,16,0) |
201 | 778 TiffHeaderBase *tiffHeader = NULL; |
200 | 779 #else |
201 | 780 TiffHeade2 *tiffHeader = NULL; |
200 | 781 #endif |
201 | 782 Cr2Header *cr2Header = NULL; |
783 | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
784 switch (type) { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
785 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
|
786 tiffHeader = new TiffHeade2(); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
787 break; |
201 | 788 case Exiv2::ImageType::cr2: |
789 cr2Header = new Cr2Header(); | |
790 break; | |
200 | 791 #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
|
792 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
|
793 tiffHeader = new OrfHeader(); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
794 break; |
200 | 795 #endif |
796 #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
|
797 case Exiv2::ImageType::raf: |
995 | 798 if (map_len < 84 + 4) throw Error(14); |
799 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
|
800 return; |
200 | 801 #endif |
191 | 802 case Exiv2::ImageType::crw: |
803 { | |
804 // Parse the image, starting with a CIFF header component | |
805 Exiv2::CiffHeader::AutoPtr parseTree(new Exiv2::CiffHeader); | |
806 parseTree->read(map_data, map_len); | |
995 | 807 CiffComponent *entry = parseTree->findComponent(0x2007, 0); |
191 | 808 if (entry) offset = entry->pData() - map_data; |
809 return; | |
810 } | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
811 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
812 default: |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
813 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
|
814 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
815 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
816 // 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
|
817 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
818 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
|
819 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
820 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
|
821 if (0 == rootDir.get()) { |
995 | 822 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
|
823 } |
201 | 824 |
825 if (tiffHeader) | |
826 { | |
827 if (!tiffHeader->read(map_data, map_len)) throw Error(3, "TIFF"); | |
200 | 828 #if EXIV2_TEST_VERSION(0,16,0) |
201 | 829 rootDir->setStart(map_data + tiffHeader->offset()); |
200 | 830 #else |
201 | 831 rootDir->setStart(map_data + tiffHeader->ifdOffset()); |
200 | 832 #endif |
201 | 833 } |
834 | |
835 if (cr2Header) | |
836 { | |
837 rootDir->setStart(map_data + cr2Header->offset()); | |
838 } | |
839 | |
840 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
|
841 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
842 TiffReader reader(map_data, |
995 | 843 map_len, |
844 rootDir.get(), | |
845 state); | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
846 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
847 rootDir->accept(reader); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
848 |
995 | 849 if (tiffHeader) |
201 | 850 delete tiffHeader; |
995 | 851 if (cr2Header) |
201 | 852 delete cr2Header; |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
853 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
854 |
609
b690cecbf5b8
Use function(void) instead of function() for declaring functions which
zas_
parents:
586
diff
changeset
|
855 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
|
856 { |
1008 | 857 io_.munmap(); |
858 io_.close(); | |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
859 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
860 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
861 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
|
862 { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
863 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
|
864 rootDir->accept(finder); |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
865 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
|
866 if (te) |
194 | 867 { |
495 | 868 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
|
869 return te->pValue(); |
194 | 870 } |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
871 else |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
872 return NULL; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
873 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
874 |
609
b690cecbf5b8
Use function(void) instead of function() for declaring functions which
zas_
parents:
586
diff
changeset
|
875 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
|
876 { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
877 const Value *val; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
878 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
|
879 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
880 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
|
881 { |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
882 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
|
883 if (val) return val->toLong(); |
995 | 884 |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
885 return 0; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
886 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
887 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
888 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
|
889 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
|
890 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
891 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
|
892 if (val) return val->toLong(); |
995 | 893 |
186
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
894 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
|
895 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
|
896 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
897 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
|
898 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
|
899 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
900 return 0; |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
901 } |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
902 |
bd3fc1aa7fe9
a hack to read raw previews with exiv2 0.16, however it should be fixed
nadvornik
parents:
185
diff
changeset
|
903 |
1008 | 904 #endif |
178 | 905 |
906 | |
995 | 907 #endif |
178 | 908 /* HAVE_EXIV2 */ |