diff options
author | Christian Fetzer <fetzer.ch@googlemail.com> | 2012-09-12 16:46:56 +0200 |
---|---|---|
committer | Christian Fetzer <fetzer.ch@googlemail.com> | 2012-09-13 13:20:20 +0200 |
commit | 44ba8a2f05d240de364048cd52cb2ebca562cffd (patch) | |
tree | 91ab56445876bf75d51c36ba210b3f1621d971ac /lib/libexif | |
parent | 13e3ada783db4fc77cc13e3edb95ba8456ae6399 (diff) |
[libexif] Added character set conversion to UserComment
closes #12628
Diffstat (limited to 'lib/libexif')
-rw-r--r-- | lib/libexif/ExifParse.cpp | 31 | ||||
-rw-r--r-- | lib/libexif/libexif.h | 7 |
2 files changed, 33 insertions, 5 deletions
diff --git a/lib/libexif/ExifParse.cpp b/lib/libexif/ExifParse.cpp index 4f39a51b51..635d82f600 100644 --- a/lib/libexif/ExifParse.cpp +++ b/lib/libexif/ExifParse.cpp @@ -451,11 +451,32 @@ void CExifParse::ProcessDir(const unsigned char* const DirStart, case TAG_USERCOMMENT: { - const int EXIF_COMMENT_HDR_LENGTH = 8; // All comment tags have 8 bytes of header info - int length = max(ByteCount - EXIF_COMMENT_HDR_LENGTH, 0); - length = min(length, MAX_COMMENT); - strncpy(m_ExifInfo->Comments, (char *)ValuePtr+EXIF_COMMENT_HDR_LENGTH, length); -// FixComment(comment); // Ensure comment is printable + // The UserComment allows comments without the charset limitations of ImageDescription. + // Therefore the UserComment field is prefixed by a CharacterCode field (8 Byte): + // - ASCII: 'ASCII\0\0\0' + // - Unicode: 'UNICODE\0' + // - JIS X208-1990: 'JIS\0\0\0\0\0' + // - Unknown: '\0\0\0\0\0\0\0\0' (application specific) + + m_ExifInfo->CommentsCharset = EXIF_COMMENT_CHARSET_UNKNOWN; + + const int EXIF_COMMENT_CHARSET_LENGTH = 8; + if (ByteCount >= EXIF_COMMENT_CHARSET_LENGTH) + { + // As some implementations use spaces instead of \0 for the padding, + // we're not so strict and check only the prefix. + if (memcmp(ValuePtr, "ASCII", 5) == 0) + m_ExifInfo->CommentsCharset = EXIF_COMMENT_CHARSET_ASCII; + else if (memcmp(ValuePtr, "UNICODE", 7) == 0) + m_ExifInfo->CommentsCharset = EXIF_COMMENT_CHARSET_UNICODE; + else if (memcmp(ValuePtr, "JIS", 3) == 0) + m_ExifInfo->CommentsCharset = EXIF_COMMENT_CHARSET_JIS; + + int length = ByteCount - EXIF_COMMENT_CHARSET_LENGTH; + length = min(length, MAX_COMMENT); + memcpy(m_ExifInfo->Comments, ValuePtr + EXIF_COMMENT_CHARSET_LENGTH, length); +// FixComment(comment); // Ensure comment is printable + } } break; diff --git a/lib/libexif/libexif.h b/lib/libexif/libexif.h index f7dc532f0d..605bbebdcc 100644 --- a/lib/libexif/libexif.h +++ b/lib/libexif/libexif.h @@ -75,6 +75,12 @@ typedef struct { char ImageType[MAX_IPTC_STRING]; } IPTCInfo_t; +#define EXIF_COMMENT_CHARSET_CONVERTED -1 // Comments contains converted data +#define EXIF_COMMENT_CHARSET_UNKNOWN 0 // Exif: Unknown +#define EXIF_COMMENT_CHARSET_ASCII 2 // Exif: Ascii +#define EXIF_COMMENT_CHARSET_UNICODE 3 // Exif: Unicode (UTF-16) +#define EXIF_COMMENT_CHARSET_JIS 4 // Exif: JIS X208-1990 + #define MAX_COMMENT 2000 #define MAX_DATE_COPIES 10 @@ -101,6 +107,7 @@ typedef struct { int ExposureMode; int ISOequivalent; int LightSource; + int CommentsCharset; // EXIF_COMMENT_CHARSET_* char Comments[MAX_COMMENT]; char Description[MAX_COMMENT]; |