33 const PLACEHOLDER =
"\x7fPLACEHOLDER\x7f";
46 'jpe' =>
'image/jpeg',
47 'jpeg' =>
'image/jpeg',
48 'jpg' =>
'image/jpeg',
50 'tif' =>
'image/tiff',
51 'tiff' =>
'image/tiff',
52 'xbm' =>
'image/x-xbitmap',
53 'svg' =>
'image/svg+xml',
65 $path =
rtrim( $path,
'/' ) .
'/';
71 self::processUrlMatch( $match, $rFlags );
72 $url = $match[
'file'][0];
76 substr( $url, 0, 2 ) ===
'//' ||
83 $anchor =
strpos( $url,
'#' );
84 if ( $anchor !==
false ) {
85 $url =
substr( $url, 0, $anchor );
93 $files[] = $path . $url;
116 if ( $ie8Compat &&
filesize( $file ) >= self::DATA_URI_SIZE_LIMIT ) {
120 if (
$type ===
null ) {
121 $type = self::getMimeType( $file );
146 $contents =
preg_replace(
"/<\\?xml.*?\\?>/",
'', $contents );
148 if (
preg_match(
'/^[\r\n\t\x20-\x7e]+$/', $contents ) ) {
153 $encoded =
strtr( $encoded, [
168 if ( !$ie8Compat ||
strlen( $uri ) < self::DATA_URI_SIZE_LIMIT ) {
175 if ( !$ie8Compat ||
strlen( $uri ) < self::DATA_URI_SIZE_LIMIT ) {
195 return '"' .
$value .
'"';
221 if (
preg_match(
'!^[\w\d:@/~.%+;,?&=-]+$!', $url ) ) {
224 return 'url("' .
strtr( $url, [
'\\' =>
'\\\\',
'"' =>
'\\"' ] ) .
'")';
239 public static function remap(
$source, $local, $remote, $embedData =
true ) {
251 if (
substr( $remote, -1 ) ==
'/' ) {
252 $remote =
substr( $remote, 0, -1 );
264 $pattern =
'/(?!' . self::EMBED_REGEX .
')(' . self::COMMENT_REGEX .
')/s';
268 function ( $match ) use ( &$comments ) {
269 $comments[] = $match[ 0 ];
270 return CSSMin::PLACEHOLDER . ( count( $comments ) - 1 ) .
'x';
279 $pattern =
'/(?:^|[;{])\K[^;{}]*' . self::getUrlRegex() .
'[^;}]*(?=[;}]|$)/';
283 function ( $matchOuter ) use ( $local, $remote, $embedData ) {
284 $rule = $matchOuter[0];
291 CSSMin::PLACEHOLDER .
307 function ( $match ) use ( $local, $remote ) {
308 self::processUrlMatch( $match );
310 $remapped =
CSSMin::remapOne( $match[
'file'], $match[
'query'], $local, $remote,
false );
322 function ( $match ) use ( $embedAll, $local, $remote, &
$mimeTypes ) {
323 self::processUrlMatch( $match );
325 $embed = $embedAll || $match[
'embed'];
334 $url = $match[
'file'] . $match[
'query'];
335 $file =
"{$local}/{$match['file']}";
337 !self::isRemoteUrl( $url ) && !self::isLocalUrl( $url )
352 if ( !$embedData || $ruleWithEmbedded === $ruleWithRemapped ) {
355 }
elseif ( $embedData && $needsEmbedFallback ) {
359 return "$ruleWithEmbedded;$ruleWithRemapped!ie";
367 $pattern =
'/' . self::PLACEHOLDER .
'(\d+)x/';
369 return $comments[ $match[1] ];
382 if (
substr( $maybeUrl, 0, 2 ) ===
'//' ||
parse_url( $maybeUrl, PHP_URL_SCHEME ) ) {
395 return isset( $maybeUrl[1] ) && $maybeUrl[0] ===
'/' && $maybeUrl[1] !==
'/';
403 if ( $urlRegex ===
null ) {
426 'url\(\s*(?P<file0>[^\s\'"][^\?\)]+?)(?P<query0>\?[^\)]*?|)\s*\)' .
428 '|url\(\s*\'(?P<file1>[^\?\']+?)(?P<query1>\?[^\']*?|)\'\s*\)' .
430 '|url\(\s*"(?P<file2>[^\?"]+?)(?P<query2>\?[^"]*?|)"\s*\)' .
437 if ( $flags & PREG_SET_ORDER ) {
441 if (
isset( $match[
'file0'] ) && $match[
'file0'][1] !== -1 ) {
442 $match[
'file'] = $match[
'file0'];
443 $match[
'query'] = $match[
'query0'];
444 }
elseif (
isset( $match[
'file1'] ) && $match[
'file1'][1] !== -1 ) {
445 $match[
'file'] = $match[
'file1'];
446 $match[
'query'] = $match[
'query1'];
448 if ( !
isset( $match[
'file2'] ) || $match[
'file2'][1] === -1 ) {
449 throw new Exception(
'URL must be non-empty' );
451 $match[
'file'] = $match[
'file2'];
452 $match[
'query'] = $match[
'query2'];
455 if (
isset( $match[
'file0'] ) && $match[
'file0'] !==
'' ) {
456 $match[
'file'] = $match[
'file0'];
457 $match[
'query'] = $match[
'query0'];
458 }
elseif (
isset( $match[
'file1'] ) && $match[
'file1'] !==
'' ) {
459 $match[
'file'] = $match[
'file1'];
460 $match[
'query'] = $match[
'query1'];
462 if ( !
isset( $match[
'file2'] ) || $match[
'file2'] ===
'' ) {
463 throw new Exception(
'URL must be non-empty' );
465 $match[
'file'] = $match[
'file2'];
466 $match[
'query'] = $match[
'query2'];
495 self::isRemoteUrl( $url ) ||
496 self::isLocalUrl( $url ) ||
497 substr( $url, 0, 1 ) ===
'#'
502 if ( $local ===
false ) {
504 $url = $remote .
'/' . $url;
507 $url =
"{$remote}/{$file}";
509 $localFile =
"{$local}/{$file}";
512 $data = self::encodeImageAsDataURI( $localFile );
513 if (
$data !==
false ) {
518 $url = OutputPage::transformFilePath( $remote, $local, $file );
543 [
'; ',
': ',
' {',
'{ ',
', ',
'} ',
';}',
'( ',
' )',
'[ ',
' ]' ],
544 [
';',
':',
'{',
'{',
',',
'}',
'}',
'(',
')',
'[',
']' ],
and that you know you can do these things To protect your we need to make restrictions that forbid anyone to deny you these rights or to ask you to surrender the rights These restrictions translate to certain responsibilities for you if you distribute copies of the or if you modify it For if you distribute copies of such a whether gratis or for a you must give the recipients all the rights that you have You must make sure that receive or can get the source code And you must show them these terms so they know their rights We protect your rights with two and(2) offer you this license which gives you legal permission to copy
wfExpandUrl( $url, $defaultProto=PROTO_CURRENT)
Expand a potentially local URL to a fully-qualified URL.
wfRemoveDotSegments( $urlPath)
Remove all dot-segments in the provided URL path.
static serializeStringValue( $value)
Serialize a string (escape and quote) for use as a CSS string value.
static buildUrlValue( $url)
Build a CSS 'url()' value for the given URL, quoting parentheses (and other funny characters) and esc...
static encodeImageAsDataURI( $file, $type=null, $ie8Compat=true)
Encode an image file as a data URI.
static getMimeType( $file)
static string[] $mimeTypes
List of common image files extensions and MIME-types.
static isRemoteUrl( $maybeUrl)
Is this CSS rule referencing a remote URL?
static getLocalFileReferences( $source, $path)
Get a list of local files referenced in a stylesheet (includes non-existent files).
static encodeStringAsDataURI( $contents, $type, $ie8Compat=true)
Encode file contents as a data URI with chosen MIME type.
static minify( $css)
Removes whitespace from CSS data.
static isLocalUrl( $maybeUrl)
Is this CSS rule referencing a local URL?
static processUrlMatch(array &$match, $flags=0)
static remapOne( $file, $query, $local, $remote, $embed)
Remap or embed a CSS URL path.
const DATA_URI_SIZE_LIMIT
Internet Explorer data URI length limit.
static remap( $source, $local, $remote, $embedData=true)
Remaps CSS URL paths and automatically embeds data URIs for CSS rules or url() values preceded by an ...
null means default in associative array with keys and values unescaped Should be merged with default with a value of false meaning to suppress the attribute in associative array with keys and values unescaped noclasses just before the function returns a value If you return true
null for the local wiki Added should default to null in handler for backwards compatibility add a value to it if you want to add a cookie that have to vary cache options can modify $query
$data
Utility to generate mapping file used in mw.Title (phpCharToUpper.json)
The wiki should then use memcached to cache various data To use multiple just add more items to the array To increase the weight of a make its entry a array("192.168.0.1:11211", 2))
if(!is_readable( $file)) $ext