# HG changeset patch # User gqview # Date 1116208191 0 # Node ID ee03f36e9e4ba0ba3cc9cb2fb77fdf41b591f534 # Parent 606fcf461a689b7e6e5d7e56cdfc4cb041b3ad1d Sun May 15 21:40:26 2005 John Ellis <johne@verizon.net> * format_raw.[ch]: New files to parse image data and exif offsets for the raw camera formats. * exif.c, image-load.c: Add support calls to format_raw.c functions above. * filelist.c: Add Fujifilm raw file extension to known formats. * thumb_standard.c (thumb_loader_std_start): Check for existing thumbnail file before checking for a failure mark. * src/Makefile.am: Add format_raw.[ch]. ##### Note: GQview CVS on sourceforge is not always up to date, please use ##### ##### an offical release when making enhancements and translation updates. ##### diff -r 606fcf461a68 -r ee03f36e9e4b ChangeLog --- a/ChangeLog Sat May 14 20:58:18 2005 +0000 +++ b/ChangeLog Mon May 16 01:49:51 2005 +0000 @@ -1,3 +1,14 @@ +Sun May 15 21:40:26 2005 John Ellis <johne@verizon.net> + + * format_raw.[ch]: New files to parse image data and exif offsets for + the raw camera formats. + * exif.c, image-load.c: Add support calls to format_raw.c functions + above. + * filelist.c: Add Fujifilm raw file extension to known formats. + * thumb_standard.c (thumb_loader_std_start): Check for existing + thumbnail file before checking for a failure mark. + * src/Makefile.am: Add format_raw.[ch]. + Sat May 14 13:04:23 2005 John Ellis <johne@verizon.net> * po/cs.po: Update Czech translation, diff -r 606fcf461a68 -r ee03f36e9e4b src/Makefile.am --- a/src/Makefile.am Sat May 14 20:58:18 2005 +0000 +++ b/src/Makefile.am Mon May 16 01:49:51 2005 +0000 @@ -84,6 +84,8 @@ exif.h \ filelist.c \ filelist.h \ + format_raw.c \ + format_raw.h \ fullscreen.c \ fullscreen.h \ globals.c \ diff -r 606fcf461a68 -r ee03f36e9e4b src/exif.c --- a/src/exif.c Sat May 14 20:58:18 2005 +0000 +++ b/src/exif.c Mon May 16 01:49:51 2005 +0000 @@ -70,6 +70,7 @@ #include "exif.h" +#include "format_raw.h" #include "ui_fileops.h" @@ -437,18 +438,22 @@ #define BYTE_ORDER_INTEL 1 #define BYTE_ORDER_MOTOROLA 2 - + + #define MARKER_UNKNOWN 0x00 #define MARKER_SOI 0xD8 #define MARKER_APP1 0xE1 -typedef struct { +/* These data structs are packed to make sure the + * byte alignment matches the on-disk data format. + */ +typedef struct __attribute__((packed)) { char byte_order[2]; uint16_t magic; uint32_t IFD_offset; } TIFFHeader; -typedef struct { +typedef struct __attribute__((packed)) { uint16_t tag; uint16_t format; uint32_t nb; @@ -1081,6 +1086,16 @@ if (res != 0) { + guint32 offset = 0; + + if (format_raw_img_exif_offsets(-1, f, size, NULL, &offset)) + { + res = parse_TIFF(exif, (unsigned char*)f + offset, size - offset); + } + } + + if (res != 0) + { exif_free(exif); exif = NULL; } diff -r 606fcf461a68 -r ee03f36e9e4b src/filelist.c --- a/src/filelist.c Sat May 14 20:58:18 2005 +0000 +++ b/src/filelist.c Mon May 16 01:49:51 2005 +0000 @@ -207,6 +207,11 @@ filter_add_if_missing("ico", "Icon file", ".ico;.cur", FALSE); filter_add_if_missing("ras", "Raster", ".ras", FALSE); filter_add_if_missing("svg", "Scalable Vector Graphics", ".svg", FALSE); + + /* These are the raw camera formats with embedded jpeg/exif. + * (see format_raw.c) + */ + filter_add_if_missing("raf", "Fujifilm raw camera format", ".raf", TRUE); } static GList *filter_to_list(const gchar *extensions) diff -r 606fcf461a68 -r ee03f36e9e4b src/format_raw.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/format_raw.c Mon May 16 01:49:51 2005 +0000 @@ -0,0 +1,86 @@ +/* + * GQView + * (C) 2005 John Ellis + * + * Authors: + * Original version 2005 Lars Ellenberg, base on dcraw by David coffin. + * + * This software is released under the GNU General Public License (GNU GPL). + * Please read the included file COPYING for more information. + * This software comes with no warranty of any kind, use at your own risk! + */ + +#ifdef HAVE_CONFIG_H +# include "config.h" +#endif + +#include <stdio.h> +#include <string.h> +#include <unistd.h> + +#include <glib.h> + +#include "intl.h" + +#include "format_raw.h" + +static gint format_raw_test_canon(int fd, const void *data, const guint len, + guint *image_offset, guint *exif_offset) +{ + return FALSE; +} + +static gint format_raw_test_fuji(int fd, const void *data, const guint len, + guint *image_offset, guint *exif_offset) +{ + if (len < 128 || + memcmp(data, "FUJIFILM", 8) != 0) + { + return FALSE; + } + + *image_offset = GUINT32_FROM_BE(*(guint32*)(data + 84)); + *exif_offset = *image_offset + 12; +printf("found a raw fuji file!\n"); + return TRUE; +} + +static gint format_raw_test_nikon(int fd, const void *data, const guint len, + guint *image_offset, guint *exif_offset) +{ + return FALSE; +} + + +gint format_raw_img_exif_offsets(int fd, const void *data, const guint len, + guint *image_offset, guint *exif_offset) +{ + guint32 io = 0; + guint32 eo = 0; + gint found; + + if (fd < 0 && !data) return FALSE; +#if 0 + if (len < 512) return FALSE; +#endif + + found = format_raw_test_canon(fd, data, len, &io, &eo) || + format_raw_test_fuji (fd, data, len, &io, &eo) || + format_raw_test_nikon(fd, data, len, &io, &eo); + + if (!found || + io >= len - 4 || + eo >= len || + memcmp(data + io, "\xff\xd8\xff\xe1", 4) != 0) /* jpeg marker */ + { + return FALSE; + } + + if (image_offset) *image_offset = io; + if (exif_offset) *exif_offset = eo; + + return TRUE; +} + + + diff -r 606fcf461a68 -r ee03f36e9e4b src/format_raw.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/format_raw.h Mon May 16 01:49:51 2005 +0000 @@ -0,0 +1,20 @@ +/* + * GQView + * (C) 2005 John Ellis + * + * Authors: + * Original version 2005 Lars Ellenberg, base on dcraw by David coffin. + * + * This software is released under the GNU General Public License (GNU GPL). + * Please read the included file COPYING for more information. + * This software comes with no warranty of any kind, use at your own risk! + */ + +#ifndef __FORMAT_RAW_H +#define __FORMAT_RAW_H + +gint format_raw_img_exif_offsets(int fd, const void *data, const guint len, + guint *image_offset, guint *exif_offset); + +#endif + diff -r 606fcf461a68 -r ee03f36e9e4b src/image-load.c --- a/src/image-load.c Sat May 14 20:58:18 2005 +0000 +++ b/src/image-load.c Mon May 16 01:49:51 2005 +0000 @@ -13,6 +13,7 @@ #include "gqview.h" #include "image-load.h" +#include "format_raw.h" #include "ui_fileops.h" #include <fcntl.h> @@ -210,6 +211,7 @@ { guchar buf[IMAGE_LOADER_BUFFER_SIZE]; int b; + unsigned int offset = 0; if (!il->loader || il->pixbuf) return FALSE; @@ -221,7 +223,9 @@ return FALSE; } - if (gdk_pixbuf_loader_write(il->loader, buf, b, NULL)) + format_raw_img_exif_offsets(il->load_fd, buf, b, &offset, NULL); + + if (gdk_pixbuf_loader_write(il->loader, buf + offset, b - offset, NULL)) { il->bytes_read += b; diff -r 606fcf461a68 -r ee03f36e9e4b src/thumb_standard.c --- a/src/thumb_standard.c Sat May 14 20:58:18 2005 +0000 +++ b/src/thumb_standard.c Mon May 16 01:49:51 2005 +0000 @@ -715,14 +715,14 @@ { gint found; - if (thumb_loader_std_fail_check(tl)) return FALSE; - tl->thumb_path = thumb_loader_std_cache_path(tl, FALSE, NULL, FALSE); tl->thumb_path_local = FALSE; found = isfile(tl->thumb_path); if (found && thumb_loader_std_setup(tl, tl->thumb_path)) return TRUE; + if (thumb_loader_std_fail_check(tl)) return FALSE; + return thumb_loader_std_next_source(tl, found); }