aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorÆvar Arnfjörð Bjarmason <avar@users.mediawiki.org>2005-07-21 00:59:08 +0000
committerÆvar Arnfjörð Bjarmason <avar@users.mediawiki.org>2005-07-21 00:59:08 +0000
commit9b7263ecc0a95568853331e5db06ad3a7f11250d (patch)
tree3551c991ab138db8cf373de0f55799293aa6c895
parente642c5b21b98a101f22be628edb9286668cfcc22 (diff)
downloadmediawikicore-9b7263ecc0a95568853331e5db06ad3a7f11250d.tar.gz
mediawikicore-9b7263ecc0a95568853331e5db06ad3a7f11250d.zip
* Fixed a bug where tags would be wrongly rejected ( === => == )
* Added break; to the switch statement in FormatExif::getFormattedData() which fixed numerous bugs * Using @ to hide errors in Exif::isRational() * Support formatting of FocalPlaneResolutionUnit * Added debug info to Exif::validate() * Fixed a debug error in Exif::isShort()
Notes
Notes: http://mediawiki.org/wiki/Special:Code/MediaWiki/10218
-rw-r--r--includes/Exif.php66
1 files changed, 58 insertions, 8 deletions
diff --git a/includes/Exif.php b/includes/Exif.php
index b3bf3699bf88..f826da95da89 100644
--- a/includes/Exif.php
+++ b/includes/Exif.php
@@ -209,7 +209,7 @@ class Exif {
'SpatialFrequencyResponse' => MW_EXIF_UNDEFINED, # Spatial frequency response
'FocalPlaneXResolution' => MW_EXIF_RATIONAL, # Focal plane X resolution
'FocalPlaneYResolution' => MW_EXIF_RATIONAL, # Focal plane Y resolution
- 'FocalPlaneResolutionUnit' => MW_EXIF_SHORT, # Focal plane resolution unit
+ 'FocalPlaneResolutionUnit' => MW_EXIF_SHORT, # Focal plane resolution unit #p46
'SubjectLocation' => MW_EXIF_SHORT, # Subject location
'ExposureIndex' => MW_EXIF_RATIONAL, # Exposure index
'SensingMethod' => MW_EXIF_SHORT, # Sensing method #p46
@@ -382,7 +382,7 @@ class Exif {
* @return bool
*/
function isByte( $in ) {
- if ( sprintf('%d', $in) === $in && $in >= 0 && $in <= 255 ) {
+ if ( sprintf('%d', $in) == $in && $in >= 0 && $in <= 255 ) {
$this->debug( $in, __FUNCTION__, true );
return true;
} else {
@@ -411,17 +411,17 @@ class Exif {
}
function isShort( $in ) {
- if ( sprintf('%d', $in) === $in && $in >= 0 && $in <= 65536 ) {
+ if ( sprintf('%d', $in) == $in && $in >= 0 && $in <= 65536 ) {
$this->debug( $in, __FUNCTION__, true );
return true;
} else {
- $this->debug( $in, __FUNCTION__, true );
+ $this->debug( $in, __FUNCTION__, false );
return false;
}
}
function isLong( $in ) {
- if ( sprintf('%d', $in) === $in && $in >= 0 && $in <= 4294967296 ) {
+ if ( sprintf('%d', $in) == $in && $in >= 0 && $in <= 4294967296 ) {
$this->debug( $in, __FUNCTION__, true );
return true;
} else {
@@ -431,7 +431,7 @@ class Exif {
}
function isRational( $in ) {
- if ( preg_match( "/^(\d+)\/(\d+[1-9]|[1-9]\d*)$/", $in, $m ) ) { # Avoid division by zero
+ if ( @preg_match( "/^(\d+)\/(\d+[1-9]|[1-9]\d*)$/", $in, $m ) ) { # Avoid division by zero
return $this->isLong( $m[1] ) && $this->isLong( $m[2] );
} else {
$this->debug( $in, __FUNCTION__, 'fed a non-fraction value' );
@@ -440,10 +440,11 @@ class Exif {
}
function isUndefined( $in ) {
- $this->debug( $in, __FUNCTION__ );
if ( preg_match( "/^\d{4}$/", $in ) ) { // Allow ExifVersion and FlashpixVersion
+ $this->debug( $in, __FUNCTION__, true );
return true;
} else {
+ $this->debug( $in, __FUNCTION__, false );
return false;
}
}
@@ -476,25 +477,35 @@ class Exif {
* @return bool
*/
function validate( $tag, $val ) {
+ $debug = "tag is '$tag'";
// Fucks up if not typecast
switch( (string)$this->mFlatExifTags[$tag] ) {
case (string)MW_EXIF_BYTE:
+ $this->debug( $val, __FUNCTION__, $debug );
return $this->isByte( $val );
case (string)MW_EXIF_ASCII:
+ $this->debug( $val, __FUNCTION__, $debug );
return $this->isASCII( $val );
case (string)MW_EXIF_SHORT:
+ $this->debug( $val, __FUNCTION__, $debug );
return $this->isShort( $val );
case (string)MW_EXIF_LONG:
+ $this->debug( $val, __FUNCTION__, $debug );
return $this->isLong( $val );
case (string)MW_EXIF_RATIONAL:
+ $this->debug( $val, __FUNCTION__, $debug );
return $this->isRational( $val );
case (string)MW_EXIF_UNDEFINED:
+ $this->debug( $val, __FUNCTION__, $debug );
return $this->isUndefined( $val );
case (string)MW_EXIF_SLONG:
+ $this->debug( $val, __FUNCTION__, $debug );
return $this->isSlong( $val );
case (string)MW_EXIF_SRATIONAL:
+ $this->debug( $val, __FUNCTION__, $debug );
return $this->isSrational( $val );
case (string)MW_EXIF_SHORT.','.MW_EXIF_LONG:
+ $this->debug( $val, __FUNCTION__, $debug );
return $this->isShort( $val ) || $this->isLong( $val );
default:
$this->debug( $val, __FUNCTION__, "The tag '$tag' is unknown" );
@@ -539,7 +550,7 @@ class FormatExif {
* @access private
*/
var $mExif;
-
+
/**
* Constructor
*
@@ -574,6 +585,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'PhotometricInterpretation':
switch( $val ) {
@@ -584,6 +596,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'Orientation':
switch( $val ) {
@@ -594,6 +607,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'PlanarConfiguration':
switch( $val ) {
@@ -604,6 +618,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
// TODO: YCbCrSubSampling
// TODO: YCbCrPositioning
@@ -617,6 +632,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
// TODO: YCbCrCoefficients #p27 (see annex E)
case 'ExifVersion': case 'FlashpixVersion':
@@ -632,6 +648,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'ComponentsConfiguration':
switch( $val ) {
@@ -642,6 +659,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'DateTime':
case 'DateTimeOriginal':
@@ -658,6 +676,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'MeteringMode':
switch( $val ) {
@@ -668,6 +687,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'LightSource':
switch( $val ) {
@@ -680,8 +700,20 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
// TODO: Flash
+ case 'FocalPlaneResolutionUnit':
+ switch( $val ) {
+ case 2:
+ $tags[$tag] = $this->msg( $tag, $val );
+ break;
+ default:
+ $tags[$tag] = $val;
+ break;
+ }
+ break;
+
case 'SensingMethod':
switch( $val ) {
case 1: case 2: case 3: case 4: case 5: case 7: case 8:
@@ -691,6 +723,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'FileSource':
switch( $val ) {
@@ -701,6 +734,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'SceneType':
switch( $val ) {
@@ -711,6 +745,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'CustomRendered':
switch( $val ) {
@@ -721,6 +756,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'ExposureMode':
switch( $val ) {
@@ -731,6 +767,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'WhiteBalance':
switch( $val ) {
@@ -741,6 +778,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'SceneCaptureType':
switch( $val ) {
@@ -751,6 +789,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'GainControl':
switch( $val ) {
@@ -761,6 +800,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'Contrast':
switch( $val ) {
@@ -771,6 +811,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'Saturation':
switch( $val ) {
@@ -781,6 +822,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'Sharpness':
switch( $val ) {
@@ -791,6 +833,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'SubjectDistanceRange':
switch( $val ) {
@@ -801,6 +844,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'GPSLatitudeRef':
case 'GPSDestLatitudeRef':
@@ -812,6 +856,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'GPSLongitudeRef':
case 'GPSDestLongitudeRef':
@@ -823,6 +868,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'GPSStatus':
switch( $val ) {
@@ -833,6 +879,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'GPSMeasureMode':
switch( $val ) {
@@ -843,6 +890,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'GPSSpeedRef':
case 'GPSDestDistanceRef':
@@ -854,6 +902,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'GPSTrackRef':
case 'GPSImgDirectionRef':
@@ -866,6 +915,7 @@ class FormatExif {
$tags[$tag] = $val;
break;
}
+ break;
case 'GPSDateStamp':
$tags[$tag] = $wgLang->date( substr( $val, 0, 4 ) . substr( $val, 5, 2 ) . substr( $val, 8, 2 ) . '000000' );