int motorola_intel; /* 1 Motorola; 0 Intel */
char *UserComment;
+ int UserCommentLength;
char UserCommentEncoding[12];
char *Thumbnail;
case TAG_FMT_STRING:
if ( value) {
- length = php_strnlen(value,length);
+ /*length = php_strnlen(value,length); would disable UNICODE comments*/
info_value->length = length;
info_value->value.s = estrndup(value,length);
} else {
void add_assoc_image_info( pval *value, int sub_array, image_info_type *image_info, int section_index)
{
char buffer[64], *val, *name, uname[64];
- int idx=0, unknown=0;
+ int idx=0, unknown=0, len;
image_info_value *info_value;
if ( image_info->info_list[section_index].count)
break;
case TAG_FMT_STRING:
- if ( !(val = info_value->value.s)) val = "";
+ if ( !(val = info_value->value.s)) {
+ val = "";
+ len = 0;
+ } else {
+ len = info_value->length;
+ }
if (section_index==SECTION_COMMENT) {
- add_index_string(tmpi, idx++, val, 1);
+ add_index_stringl(tmpi, idx++, val, len, 1);
} else {
- add_assoc_string(tmpi, name, val, 1);
+ add_assoc_stringl(tmpi, name, val, len , 1);
}
break;
*/
static void exif_process_COM (image_info_type *image_info, uchar *value, int length)
{
- exif_add_image_info( image_info, SECTION_COMMENT, "Comment", TAG_COMPUTED_VALUE, TAG_FMT_STRING, length-2, value+2);
+ exif_add_image_info( image_info, SECTION_COMMENT, "Comment", TAG_COMPUTED_VALUE, TAG_FMT_STRING, php_strnlen(value+2, length-2), value+2);
}
/* }}} */
* Process UserComment in IFD. */
static int exif_process_user_comment(char **pszInfoPtr,char *szEncoding,char *szValuePtr,int ByteCount)
{
- int a;
+ int a, size;
*szEncoding = '\0';
/* Copy the comment */
strcpy( szEncoding, szValuePtr);
szValuePtr = szValuePtr+8;
ByteCount -= 8;
- return exif_process_string_raw(pszInfoPtr, szValuePtr, ByteCount);
+ size = exif_process_string_raw(pszInfoPtr, szValuePtr, ByteCount);
+ return size ? size-1 : 0;
}
if ( !memcmp(szValuePtr, "ASCII\0\0\0", 8)) {
strcpy( szEncoding, szValuePtr);
if (a) for (a=ByteCount-1;a && szValuePtr[a]==' ';a--) (szValuePtr)[a] = '\0';
/* normal text without encoding */
- return exif_process_string(pszInfoPtr, szValuePtr, ByteCount);
+ size = exif_process_string(pszInfoPtr, szValuePtr, ByteCount);
+ return size ? size-1 : 0;
}
/* }}} */
break;
case TAG_USERCOMMENT:
- exif_process_user_comment(&(ImageInfo->UserComment),ImageInfo->UserCommentEncoding,value_ptr,byte_count);
+ ImageInfo->UserCommentLength = exif_process_user_comment(&(ImageInfo->UserComment),ImageInfo->UserCommentEncoding,value_ptr,byte_count);
break;
/* this is only a comment if type is string! */
/* correctly would be to set components as length
* but we are ignoring length for those types where it is not the same as byte_count
*/
+ if (format==TAG_FMT_STRING) {
+ byte_count = php_strnlen(value_ptr,byte_count);
+ }
exif_add_image_info( ImageInfo, section_index, exif_get_tagname(tag,tagname), tag, format, byte_count, value_ptr);
if ( outside) efree( outside);
}
exif_add_image_info( &ImageInfo, SECTION_COMPUTED, "FocusDistance", TAG_NONE, TAG_FMT_STRING, strlen(tmp), tmp);
}
if (ImageInfo.UserComment) {
- exif_add_image_info( &ImageInfo, SECTION_COMPUTED, "UserComment", TAG_NONE, TAG_FMT_STRING, strlen(ImageInfo.UserComment), ImageInfo.UserComment);
+ exif_add_image_info( &ImageInfo, SECTION_COMPUTED, "UserComment", TAG_NONE, TAG_FMT_STRING, ImageInfo.UserCommentLength, ImageInfo.UserComment);
if ( (len=strlen(ImageInfo.UserCommentEncoding))) {
exif_add_image_info( &ImageInfo, SECTION_COMPUTED, "UserCommentEncoding", TAG_NONE, TAG_FMT_STRING, len, ImageInfo.UserCommentEncoding);
}
--TEST--
Check for exif_read_data
--SKIPIF--
-<?php if (!extension_loaded("exif")) print "skip";?>
+<?php if (!extension_loaded("exif") || !function_exists('mb_convert_encoding')) print "skip";?>
--POST--
--GET--
--FILE--
$accept = '';
foreach($image as $idx=>$section) {
$accept .= $section;
+ if ($idx=="COMPUTED" && array_key_exists("UserCommentEncoding",$section) && $section["UserCommentEncoding"]=="UNICODE") {
+ $section["UserComment"] = mb_convert_encoding($section["UserComment"],"ISO-8859-1","UCS-2BE");
+ }
foreach($section as $name=>$value) {
- if ( $idx!='FILE' || $name!='FileDateTime') {
+ if ($idx!='FILE' || $name!='FileDateTime') {
$accept .= substr($name,0,2);
$accept .= $value;
}
echo $accept;
?>
--EXPECT--
-ArrayFitest3.jpgFi1237Fi2SeANY_TAG, IFD0, THUMBNAIL, COMMENTArrayhtwidth="1" height="1"He1Wi1Is1UsÄÖÜßäöüUsUNICODECoPhoto (c) M.Boerger, Edited by M.Boerger.CoPhoto (c) M.BoergerCoEdited by M.Boerger.ArrayCoPhoto (c) M.BoergerUsUNICODEArrayJP134JP523Array0Comment #1.1Comment #2.2Comment #3end
\ No newline at end of file
+ArrayFitest3.jpgFi1237SeCOMPUTED, ANY_TAG, IFD0, THUMBNAIL, COMMENT, EXIFArrayCoPhoto (c) M.BoergerCoEdited by M.Boerger.htwidth="1" height="1"He1Wi1Is1UsÄÖÜßäöüUsUNICODEArrayCoPhoto (c) M.BoergerUsUNICODEArrayJP134JP523Array0Comment #1.1Comment #2.2Comment #3end
\ No newline at end of file