wiki.techinc.nl/includes/media/BmpHandler.php
Daimona Eaytoy 4be770a196 Deprecate and replace the wfUnpack global function
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
2024-01-17 21:17:24 +00:00

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]
];
}
}