Move it to the StringUtils class, and make it throw a dedicated exception. Update code in media/ to use the new method. Those seemed to be the only usages across all known MW code [1], so hard-deprecate the method as well. [1] - https://codesearch.wmcloud.org/search/?q=wfUnpack&files=&excludeFiles=&repos= Change-Id: I82ce96b6373443cf57a48b98595ca05290f37349
85 lines
2.1 KiB
PHP
85 lines
2.1 KiB
PHP
<?php
|
|
/**
|
|
* Handler for Microsoft's bitmap format.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
* http://www.gnu.org/copyleft/gpl.html
|
|
*
|
|
* @file
|
|
* @ingroup Media
|
|
*/
|
|
|
|
use MediaWiki\Libs\UnpackFailedException;
|
|
|
|
/**
|
|
* Handler for Microsoft's bitmap format; getimagesize() doesn't
|
|
* support these files
|
|
*
|
|
* @ingroup Media
|
|
*/
|
|
class BmpHandler extends BitmapHandler {
|
|
/**
|
|
* @param File $file
|
|
* @return bool
|
|
*/
|
|
public function mustRender( $file ) {
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Render files as PNG
|
|
*
|
|
* @param string $ext
|
|
* @param string $mime
|
|
* @param array|null $params
|
|
* @return array
|
|
*/
|
|
public function getThumbType( $ext, $mime, $params = null ) {
|
|
return [ 'png', 'image/png' ];
|
|
}
|
|
|
|
/**
|
|
* Get width and height from the bmp header.
|
|
*
|
|
* @param MediaHandlerState $state
|
|
* @param string $filename
|
|
* @return array
|
|
*/
|
|
public function getSizeAndMetadata( $state, $filename ) {
|
|
$f = fopen( $filename, 'rb' );
|
|
if ( !$f ) {
|
|
return [];
|
|
}
|
|
$header = fread( $f, 54 );
|
|
fclose( $f );
|
|
|
|
// Extract binary form of width and height from the header
|
|
$w = substr( $header, 18, 4 );
|
|
$h = substr( $header, 22, 4 );
|
|
|
|
// Convert the unsigned long 32 bits (little endian):
|
|
try {
|
|
$w = StringUtils::unpack( 'V', $w, 4 );
|
|
$h = StringUtils::unpack( 'V', $h, 4 );
|
|
} catch ( UnpackFailedException $e ) {
|
|
return [];
|
|
}
|
|
|
|
return [
|
|
'width' => $w[1],
|
|
'height' => $h[1]
|
|
];
|
|
}
|
|
}
|