From a1789ddde42033f1b05cc4929491214ee6e79383 Mon Sep 17 00:00:00 2001 From: Pierre Schmitz Date: Thu, 17 Dec 2015 09:15:42 +0100 Subject: Update to MediaWiki 1.26.0 --- .../maintenance/updateLexerList.php | 60 ++++++++++++++++++++++ 1 file changed, 60 insertions(+) create mode 100644 extensions/SyntaxHighlight_GeSHi/maintenance/updateLexerList.php (limited to 'extensions/SyntaxHighlight_GeSHi/maintenance/updateLexerList.php') diff --git a/extensions/SyntaxHighlight_GeSHi/maintenance/updateLexerList.php b/extensions/SyntaxHighlight_GeSHi/maintenance/updateLexerList.php new file mode 100644 index 00000000..75beb9b5 --- /dev/null +++ b/extensions/SyntaxHighlight_GeSHi/maintenance/updateLexerList.php @@ -0,0 +1,60 @@ + + * @ingroup Maintenance + */ + +use KzykHys\Pygments\Pygments; + +$IP = getenv( 'MW_INSTALL_PATH' ) ?: __DIR__ . '/../../..'; + +require_once "$IP/maintenance/Maintenance.php"; + +class UpdateLanguageList extends Maintenance { + public function __construct() { + parent::__construct(); + $this->addDescription( 'Update list of lexers supported by SyntaxHighlight_GeSHi' ); + } + + public function execute() { + global $wgPygmentizePath; + + function lang_filter( $val ) { + return preg_match( '/^[a-zA-Z0-9\-_]+$/', $val ); + } + + $header = '// Generated by ' . basename( __FILE__ ) . "\n\n"; + + $pygments = new Pygments( $wgPygmentizePath ); + $lexers = array_keys( $pygments->getLexers() ); + sort( $lexers ); + + $code = "| (?=\())/i', '', $code ); + $code = preg_replace( "/^ +/m", "\t", $code ); + + file_put_contents( __DIR__ . '/../SyntaxHighlight_GeSHi.lexers.php', $code ); + $this->output( "Updated language list written to SyntaxHighlight_GeSHi.lexers.php\n" ); + } +} + +$maintClass = "UpdateLanguageList"; +require_once ( RUN_MAINTENANCE_IF_MAIN ); -- cgit v1.2.2 From 257401d8b2cf661adf36c84b0e3fd1cf85e33c22 Mon Sep 17 00:00:00 2001 From: Pierre Schmitz Date: Fri, 18 Dec 2015 06:04:58 +0100 Subject: Update to MediaWiki 1.26.1 --- .../maintenance/updateLexerList.php | 23 +++++++++++++++++++--- 1 file changed, 20 insertions(+), 3 deletions(-) (limited to 'extensions/SyntaxHighlight_GeSHi/maintenance/updateLexerList.php') diff --git a/extensions/SyntaxHighlight_GeSHi/maintenance/updateLexerList.php b/extensions/SyntaxHighlight_GeSHi/maintenance/updateLexerList.php index 75beb9b5..b5a7fc5a 100644 --- a/extensions/SyntaxHighlight_GeSHi/maintenance/updateLexerList.php +++ b/extensions/SyntaxHighlight_GeSHi/maintenance/updateLexerList.php @@ -22,7 +22,7 @@ * @ingroup Maintenance */ -use KzykHys\Pygments\Pygments; +use Symfony\Component\Process\ProcessBuilder; $IP = getenv( 'MW_INSTALL_PATH' ) ?: __DIR__ . '/../../..'; @@ -43,8 +43,25 @@ class UpdateLanguageList extends Maintenance { $header = '// Generated by ' . basename( __FILE__ ) . "\n\n"; - $pygments = new Pygments( $wgPygmentizePath ); - $lexers = array_keys( $pygments->getLexers() ); + $lexers = array(); + + $builder = new ProcessBuilder(); + $builder->setPrefix( $wgPygmentizePath ); + + $process = $builder->add( '-L' )->add( 'lexer' )->getProcess(); + $process->run(); + + if ( !$process->isSuccessful() ) { + throw new \RuntimeException( $process->getErrorOutput() ); + } + + $output = $process->getOutput(); + foreach ( explode( "\n", $output ) as $line ) { + if ( substr( $line, 0, 1 ) === '*' ) { + $newLexers = explode( ', ', trim( $line, "* :\n" ) ); + $lexers = array_merge( $lexers, $newLexers ); + } + } sort( $lexers ); $code = "