MediaWiki
1.33.1
|
Handler for SVG images. More...
Public Member Functions | |
canAnimateThumbnail ( $file) | |
We do not support making animated svg thumbnails. More... | |
doTransform ( $image, $dstPath, $dstUrl, $params, $flags=0) | |
formatMetadata ( $file, $context=false) | |
getAvailableLanguages (File $file) | |
Which languages (systemLanguage attribute) is supported. More... | |
getCommonMetaArray (File $file) | |
Get an array of standard (FormatMetadata type) metadata values. More... | |
getDefaultRenderLanguage (File $file) | |
What language to render file in if none selected. More... | |
getImageSize ( $file, $path, $metadata=false) | |
getLongDesc ( $file) | |
Subtitle for the image. More... | |
getMatchedLanguage ( $userPreferredLanguage, array $svgLanguages) | |
SVG's systemLanguage matching rules state: 'The systemLanguage attribute ... More... | |
getMetadata ( $file, $filename) | |
getMetadataType ( $image) | |
Get a string describing the type of metadata, for display purposes. More... | |
getParamMap () | |
Get an associative array mapping magic word IDs to parameter names. More... | |
getThumbType ( $ext, $mime, $params=null) | |
Get the thumbnail extension and MIME type for a given source MIME type. More... | |
isAnimatedImage ( $file) | |
isEnabled () | |
False if the handler is disabled for all files. More... | |
isMetadataValid ( $image, $metadata) | |
Check if the metadata string is valid for this handler. More... | |
isVectorized ( $file) | |
The material is vectorized and thus scaling is lossless. More... | |
makeParamString ( $params) | |
mustRender ( $file) | |
True if handled types cannot be displayed directly in a browser but can be rendered. More... | |
normaliseParams ( $image, &$params) | |
parseParamString ( $str) | |
Parse a param string made with makeParamString back into an array. More... | |
rasterize ( $srcPath, $dstPath, $width, $height, $lang=false) | |
Transform an SVG file to PNG This function can be called outside of thumbnail contexts. More... | |
unpackMetadata ( $metadata) | |
validateParam ( $name, $value) | |
Public Member Functions inherited from ImageHandler | |
canRender ( $file) | |
getDimensionsString ( $file) | |
getImageArea ( $image) | |
Function that returns the number of pixels to be thumbnailed. More... | |
getImageSize ( $image, $path) | |
Get an image size array like that returned by getimagesize(), or false if it can't be determined. More... | |
getScriptedTransform ( $image, $script, $params) | |
getShortDesc ( $file) | |
sanitizeParamsForBucketing ( $params) | |
Returns a normalised params array for which parameters have been cleaned up for bucketing purposes. More... | |
validateThumbParams (&$width, &$height, $srcWidth, $srcHeight, $mimeType) | |
Validate thumbnail parameters and fill in the correct height. More... | |
Public Member Functions inherited from MediaHandler | |
canRotate () | |
True if the handler can rotate the media. More... | |
convertMetadataVersion ( $metadata, $version=1) | |
Convert metadata version. More... | |
filterThumbnailPurgeList (&$files, $options) | |
Remove files from the purge list. More... | |
formatMetadataHelper ( $metadataArray, $context=false) | |
sorts the visible/invisible field. More... | |
getContentHeaders ( $metadata) | |
Get useful response headers for GET/HEAD requests for a file with the given metadata. More... | |
getEntireText (File $file) | |
Get the text of the entire document. More... | |
getLength ( $file) | |
If its an audio file, return the length of the file. More... | |
getPageDimensions (File $image, $page) | |
Get an associative array of page dimensions Currently "width" and "height" are understood, but this might be expanded in the future. More... | |
getPageText (File $image, $page) | |
Generic getter for text layer. More... | |
getRotation ( $file) | |
On supporting image formats, try to read out the low-level orientation of the file and return the angle that the file needs to be rotated to be viewed. More... | |
getTransform ( $image, $dstPath, $dstUrl, $params) | |
Get a MediaTransformOutput object representing the transformed output. More... | |
getWarningConfig ( $file) | |
Gets configuration for the file warning message. More... | |
isExpensiveToThumbnail ( $file) | |
True if creating thumbnails from the file is large or otherwise resource-intensive. More... | |
isMultiPage ( $file) | |
True if the type has multi-page capabilities. More... | |
pageCount (File $file) | |
Page count for a multi-page document, false if unsupported or unknown. More... | |
parserTransformHook ( $parser, $file) | |
Modify the parser object post-transform. More... | |
removeBadFile ( $dstPath, $retval=0) | |
Check for zero-sized thumbnails. More... | |
supportsBucketing () | |
Returns whether or not this handler supports the chained generation of thumbnails according to buckets. More... | |
verifyUpload ( $fileName) | |
File validation hook called on upload. More... | |
Static Public Member Functions | |
static | rasterizeImagickExt ( $srcPath, $dstPath, $width, $height) |
Static Public Member Functions inherited from MediaHandler | |
static | fitBoxWidth ( $boxWidth, $boxHeight, $maxHeight) |
Calculate the largest thumbnail width for a given original file size such that the thumbnail's height is at most $maxHeight. More... | |
static | getGeneralLongDesc ( $file) |
Used instead of getLongDesc if there is no handler registered for file. More... | |
static | getGeneralShortDesc ( $file) |
Used instead of getShortDesc if there is no handler registered for file. More... | |
static | getHandler ( $type) |
Get a MediaHandler for a given MIME type from the instance cache. More... | |
static | getMetadataVersion () |
Get metadata version. More... | |
static | getPageRangesByDimensions ( $pagesByDimensions) |
Converts a dimensions array about a potentially multipage document from an exhaustive list of ordered page numbers to a list of page ranges. More... | |
Public Attributes | |
const | SVG_METADATA_VERSION = 2 |
Public Attributes inherited from MediaHandler | |
const | MAX_ERR_LOG_SIZE = 65535 |
Max length of error logged by logErrorForExternalProcess() More... | |
const | METADATA_BAD = false |
const | METADATA_COMPATIBLE = 2 |
const | METADATA_GOOD = true |
const | TRANSFORM_LATER = 1 |
Protected Member Functions | |
getLanguageFromParams (array $params) | |
Determines render language from image parameters. More... | |
getScriptParams ( $params) | |
normaliseParamsInternal ( $image, $params) | |
Code taken out of normaliseParams() for testability. More... | |
visibleMetadataFields () | |
Get a list of metadata items which should be displayed when the metadata table is collapsed. More... | |
Protected Member Functions inherited from MediaHandler | |
logErrorForExternalProcess ( $retval, $err, $cmd) | |
Log an error that occurred in an external process. More... | |
Static Private Attributes | |
static array | $metaConversion |
A list of metadata tags that can be converted to the commonly used exif tags. More... | |
Additional Inherited Members | |
Static Protected Member Functions inherited from MediaHandler | |
static | addMeta (&$array, $visibility, $type, $id, $value, $param=false) |
This is used to generate an array element for each metadata value That array is then used to generate the table of metadata values on the image page. More... | |
Handler for SVG images.
Definition at line 32 of file SvgHandler.php.
SvgHandler::canAnimateThumbnail | ( | $file | ) |
We do not support making animated svg thumbnails.
File | $file |
Reimplemented from MediaHandler.
Definition at line 166 of file SvgHandler.php.
SvgHandler::doTransform | ( | $image, | |
$dstPath, | |||
$dstUrl, | |||
$params, | |||
$flags = 0 |
|||
) |
File | $image | |
string | $dstPath | |
string | $dstUrl | |
array | $params | |
int | $flags |
Reimplemented from MediaHandler.
Reimplemented in MockSvgHandler.
Definition at line 227 of file SvgHandler.php.
References $image, $lang, $params, getLanguageFromParams(), normaliseParams(), rasterize(), text, unpackMetadata(), use, wfDebugLog(), wfHostname(), wfMessage(), wfMkdirParents(), wfRandomString(), and wfTempDir().
SvgHandler::formatMetadata | ( | $file, | |
$context = false |
|||
) |
File | $file | |
bool | IContextSource | $context | Context to use (optional) |
Reimplemented from MediaHandler.
Definition at line 494 of file SvgHandler.php.
References $file, $name, $value, MediaHandler\addMeta(), as, unpackMetadata(), and visibleMetadataFields().
SvgHandler::getAvailableLanguages | ( | File | $file | ) |
Which languages (systemLanguage attribute) is supported.
File | $file |
Reimplemented from MediaHandler.
Definition at line 94 of file SvgHandler.php.
References $file, $lang, as, SVGReader\LANG_FULL_MATCH, and unpackMetadata().
SvgHandler::getCommonMetaArray | ( | File | $file | ) |
Get an array of standard (FormatMetadata type) metadata values.
The returned data is largely the same as that from getMetadata(), but formatted in a standard, stable, handler-independent way. The idea being that some values like ImageDescription or Artist are universal and should be retrievable in a handler generic way.
The specific properties are the type of properties that can be handled by the FormatMetadata class. These values are exposed to the user via the filemetadata parser function.
Details of the response format of this function can be found at https://www.mediawiki.org/wiki/Manual:File_metadata_handling tl/dr: the response is an associative array of properties keyed by name, but the value can be complex. You probably want to call one of the FormatMetadata::flatten* functions on the property values before using them, or call FormatMetadata::getFormattedData() on the full response array, which transforms all values into prettified, human-readable text.
Subclasses overriding this function must return a value which is a valid API response fragment (all associative array keys are valid XML tagnames).
Note, if the file simply has no metadata, but the handler supports this interface, it should return an empty array, not false.
File | $file |
Reimplemented from MediaHandler.
Definition at line 604 of file SvgHandler.php.
References $file, $name, $value, as, and unpackMetadata().
SvgHandler::getDefaultRenderLanguage | ( | File | $file | ) |
What language to render file in if none selected.
Reimplemented from MediaHandler.
Definition at line 157 of file SvgHandler.php.
SvgHandler::getImageSize | ( | $file, | |
$path, | |||
$metadata = false |
|||
) |
|
protected |
Determines render language from image parameters.
array | $params |
Definition at line 147 of file SvgHandler.php.
References $params.
Referenced by doTransform(), and makeParamString().
SvgHandler::getLongDesc | ( | $file | ) |
Subtitle for the image.
Different from the base class so it can be denoted that SVG's have a "nominal" resolution, and not a fixed one, as well as so animation can be denoted.
File | $file |
Reimplemented from ImageHandler.
Definition at line 413 of file SvgHandler.php.
References $file, $wgLang, isAnimatedImage(), unpackMetadata(), and wfMessage().
SvgHandler::getMatchedLanguage | ( | $userPreferredLanguage, | |
array | $svgLanguages | ||
) |
SVG's systemLanguage matching rules state: 'The systemLanguage
attribute ...
[e]valuates to "true" if one of the languages indicated by user preferences exactly equals one of the languages given in the value of this parameter, or if one of the languages indicated by user preferences exactly equals a prefix of one of the languages given in the value of this parameter such that the first tag character following the prefix is "-".'
Return the first element of $svgLanguages that matches $userPreferredLanguage
string | $userPreferredLanguage | |
array | $svgLanguages |
Reimplemented from MediaHandler.
Definition at line 125 of file SvgHandler.php.
References as.
SvgHandler::getMetadata | ( | $file, | |
$filename | |||
) |
Reimplemented from MediaHandler.
Definition at line 439 of file SvgHandler.php.
References $e, SVGMetadataExtractor\getMetadata(), serialize(), SVG_METADATA_VERSION, and wfDebug().
SvgHandler::getMetadataType | ( | $image | ) |
Get a string describing the type of metadata, for display purposes.
File | $image |
Reimplemented from MediaHandler.
Definition at line 466 of file SvgHandler.php.
SvgHandler::getParamMap | ( | ) |
Get an associative array mapping magic word IDs to parameter names.
Will be used by the parser to identify parameters.
Reimplemented from ImageHandler.
Definition at line 587 of file SvgHandler.php.
|
protected |
array | $params |
Reimplemented from ImageHandler.
Definition at line 595 of file SvgHandler.php.
References $params.
SvgHandler::getThumbType | ( | $ext, | |
$mime, | |||
$params = null |
|||
) |
Get the thumbnail extension and MIME type for a given source MIME type.
string | $ext | Extension of original file |
string | $mime | MIME type of original file |
array | null | $params | Handler specific rendering parameters |
Reimplemented from MediaHandler.
Definition at line 400 of file SvgHandler.php.
SvgHandler::isAnimatedImage | ( | $file | ) |
File | $file |
Reimplemented from MediaHandler.
Definition at line 69 of file SvgHandler.php.
References $file, and unpackMetadata().
Referenced by getLongDesc().
SvgHandler::isEnabled | ( | ) |
False if the handler is disabled for all files.
Reimplemented from MediaHandler.
Definition at line 46 of file SvgHandler.php.
References $wgSVGConverter, $wgSVGConverters, and wfDebug().
SvgHandler::isMetadataValid | ( | $image, | |
$metadata | |||
) |
Check if the metadata string is valid for this handler.
If it returns MediaHandler::METADATA_BAD (or false), Image will reload the metadata from the file and update the database. MediaHandler::METADATA_GOOD for if the metadata is a-ok, MediaHandler::METADATA_COMPATIBLE if metadata is old but backwards compatible (which may or may not trigger a metadata reload).
File | $image | |
string | $metadata | The metadata in serialized form |
Reimplemented from MediaHandler.
Definition at line 470 of file SvgHandler.php.
References MediaHandler\METADATA_BAD, MediaHandler\METADATA_COMPATIBLE, MediaHandler\METADATA_GOOD, and unpackMetadata().
SvgHandler::isVectorized | ( | $file | ) |
The material is vectorized and thus scaling is lossless.
File | $file |
Reimplemented from MediaHandler.
Definition at line 61 of file SvgHandler.php.
SvgHandler::makeParamString | ( | $params | ) |
array | $params | Name=>value pairs of parameters |
Reimplemented from ImageHandler.
Definition at line 563 of file SvgHandler.php.
References $code, $lang, $params, and getLanguageFromParams().
SvgHandler::mustRender | ( | $file | ) |
True if handled types cannot be displayed directly in a browser but can be rendered.
File | $file |
Reimplemented from MediaHandler.
Definition at line 57 of file SvgHandler.php.
SvgHandler::normaliseParams | ( | $image, | |
& | $params | ||
) |
File | $image | |
array | &$params |
Reimplemented from ImageHandler.
Definition at line 175 of file SvgHandler.php.
References $image, $params, and normaliseParamsInternal().
Referenced by doTransform().
|
protected |
Code taken out of normaliseParams() for testability.
File | $image | |
array | $params |
Definition at line 193 of file SvgHandler.php.
References $image, $params, $wgSVGMaxSize, and File\scaleHeight().
Referenced by normaliseParams().
SvgHandler::parseParamString | ( | $str | ) |
Parse a param string made with makeParamString back into an array.
string | $str | The parameter string without file name (e.g. 122px) |
Reimplemented from ImageHandler.
Definition at line 576 of file SvgHandler.php.
SvgHandler::rasterize | ( | $srcPath, | |
$dstPath, | |||
$width, | |||
$height, | |||
$lang = false |
|||
) |
Transform an SVG file to PNG This function can be called outside of thumbnail contexts.
string | $srcPath | |
string | $dstPath | |
string | $width | |
string | $height | |
bool | string | $lang | Language code of the language to render the SVG in |
MWException |
Definition at line 317 of file SvgHandler.php.
References $lang, $wgSVGConverter, $wgSVGConverterPath, $wgSVGConverters, MediaHandler\logErrorForExternalProcess(), MediaHandler\removeBadFile(), wfDebug(), and wfShellExecWithStderr().
Referenced by doTransform().
|
static |
Definition at line 366 of file SvgHandler.php.
SvgHandler::unpackMetadata | ( | $metadata | ) |
Definition at line 455 of file SvgHandler.php.
References unserialize().
Referenced by doTransform(), formatMetadata(), getAvailableLanguages(), getCommonMetaArray(), getImageSize(), getLongDesc(), isAnimatedImage(), and isMetadataValid().
SvgHandler::validateParam | ( | $name, | |
$value | |||
) |
string | $name | Parameter name |
mixed | $value | Parameter value |
Reimplemented from ImageHandler.
Definition at line 542 of file SvgHandler.php.
References $name, $value, and Language\isValidCode().
|
protected |
Get a list of metadata items which should be displayed when the metadata table is collapsed.
Reimplemented from MediaHandler.
Definition at line 483 of file SvgHandler.php.
Referenced by formatMetadata().
|
staticprivate |
A list of metadata tags that can be converted to the commonly used exif tags.
This allows messages to be reused, and consistent tag names for {{#formatmetadata:..}}
Definition at line 39 of file SvgHandler.php.
const SvgHandler::SVG_METADATA_VERSION = 2 |
Definition at line 33 of file SvgHandler.php.
Referenced by getMetadata(), SvgHandlerTest\testGetAvailableLanguages(), and SvgHandlerTest\testNormaliseParamsInternal().