mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/SyntaxHighlight_GeSHi
synced 2025-01-06 10:14:26 +00:00
af6654e5f9
All of the interactions with `pygmentize` have been refactored into a new class, conviently called Pygmentize. It is responsible for getting * pygments version (cached in APCu for 1 hour) * generated CSS (cached in WAN by version for 1 week) * lexer list (cached in APCu by version for 1 day) and actually highlighting stuff! Most code paths differentiate whether we're using a bundled version of pygments or one that has been explicitly configured. If using the bundled one, we take shortcuts since we already know the lexer list, have the CSS generated, etc. ResourceLoaderPygmentsModule is added to switch between loading generated CSS from the bundled file or Shellboxing out to get it from pygments. Bug: T289227 Change-Id: I2e82e5aa2a71604b87ffb4936204201d06678341
76 lines
2 KiB
PHP
76 lines
2 KiB
PHP
<?php
|
|
/**
|
|
* Copyright (C) 2021 Kunal Mehta <legoktm@debian.org>
|
|
*
|
|
* 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
|
|
*/
|
|
|
|
namespace MediaWiki\SyntaxHighlight;
|
|
|
|
use ResourceLoaderContext;
|
|
use ResourceLoaderFileModule;
|
|
|
|
/**
|
|
* At runtime switch between bundled CSS or dynamically generated
|
|
*/
|
|
class ResourceLoaderPygmentsModule extends ResourceLoaderFileModule {
|
|
|
|
/** @var bool */
|
|
private $useBundled;
|
|
|
|
/** @inheritDoc */
|
|
public function __construct(
|
|
array $options = [],
|
|
$localBasePath = null,
|
|
$remoteBasePath = null
|
|
) {
|
|
$this->useBundled = Pygmentize::useBundled();
|
|
if ( $this->useBundled ) {
|
|
$options['styles'][] = 'pygments.generated.css';
|
|
}
|
|
parent::__construct( $options, $localBasePath, $remoteBasePath );
|
|
}
|
|
|
|
/**
|
|
* We sometimes have generated styles
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function supportsURLLoading() {
|
|
return false;
|
|
}
|
|
|
|
/** @inheritDoc */
|
|
public function getStyles( ResourceLoaderContext $context ) {
|
|
$styles = parent::getStyles( $context );
|
|
if ( !$this->useBundled ) {
|
|
$styles['all'] = ( $styles['all'] ?? '' ) . Pygmentize::getGeneratedCSS();
|
|
}
|
|
|
|
return $styles;
|
|
}
|
|
|
|
/** @inheritDoc */
|
|
public function getDefinitionSummary( ResourceLoaderContext $context ) {
|
|
$summary = parent::getDefinitionSummary( $context );
|
|
if ( !$this->useBundled ) {
|
|
$summary[] = Pygmentize::getVersion();
|
|
}
|
|
return $summary;
|
|
}
|
|
|
|
}
|