<?php
/**
* Copyright (C) 2007 Ashar Voultoiz <hashar@altern.org>
*
* Based on dumpBackup:
* Copyright (C) 2005 Brion Vibber <brion@pobox.com>
*
* http://www.mediawiki.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
*
* @addtogroup Maintenance
*/
#
# Lacking documentation. Examples:
# php checkExtensions.php /opt/mw/extensions/CentralAuth/CentralAuth.i18n.php wgCentralAuthMessages
# php checkExtensions.php --extdir /opt/mw/extensions/
#
# BUGS: cant guess registered extensions :)
# TODO: let users set parameters to configure checklanguage.inc
// Filename for the extension i18n files database:
define( 'EXT_I18N_DB', 'i18n.db' );
$optionsWithArgs = array( 'extdir', 'lang' );
require_once( dirname(__FILE__).'/../commandLine.inc' );
require_once( 'languages.inc' );
require_once( 'checkLanguage.inc' );
class extensionLanguages extends languages {
private $mExt18nFilename, $mExtArrayName ;
private $mExtArray;
function __construct( $ext18nFilename, $extArrayName ) {
$this->mExt18nFilename = $ext18nFilename;
$this->mExtArrayName = $extArrayName;
$this->mIgnoredMessages = array();
$this->mOptionalMessages = array();
if ( file_exists( $this->mExt18nFilename ) ) {
require_once( $this->mExt18nFilename );
$foundarray = false;
if( isset( ${$this->mExtArrayName} ) ) {
// File provided in the db file
$foundarray = ${$this->mExtArrayName};
} else {
/* For extensions included elsewhere. For some reason other extensions
* break with the global statement, so recheck here.
*/
global ${$this->mExtArrayName};
if( is_array( ${$this->mExtArrayName} ) ) {
$foundarray = ${$this->mExtArrayName};
}
/* we might have been given a function name, test it too */
if( function_exists( $this->mExtArrayName ) ) {
// Load data
$funcName = $this->mExtArrayName ;
$foundarray = $funcName();
}
if(!$foundarray) {
// Provided array could not be found we try to guess it.
# Using the extension path ($m[1]) and filename ($m[2]):
$m = array();
preg_match( '%.*/(.*)/(.*).i18n\.php%', $this->mExt18nFilename, $m);
$arPathCandidate = 'wg' . $m[1].'Messages';
$arFileCandidate = 'wg' . $m[2].'Messages';
$funcCandidate = "ef{$m[2]}Messages";
// Try them:
if( isset($$arPathCandidate) && is_array( $$arPathCandidate ) ) {
print "warning> messages from guessed path array \$$arPathCandidate.\n";
$foundarray = $$arPathCandidate;
} elseif( isset($$arFileCandidate) && is_array( $$arFileCandidate ) ) {
print "warning> messages from guessed file array \$$arFileCandidate.\n";
$foundarray = $$arFileCandidate;
} elseif( function_exists( $funcCandidate ) ) {
print "warning> messages build from guessed function {$funcCandidate}().\n";
$foundarray = $funcCandidate();
}
}
# We are unlucky, return empty stuff
if(!$foundarray) {
print "ERROR> failed to guess an array to use.\n";
$this->mExtArray = null;
$this->mLanguages = null;
return;
}
}
$this->mExtArray = $foundarray ;
$this->mLanguages = array_keys( $this->mExtArray );
} else {
wfDie( "File $this->mExt18nFilename not found\n" );
}
}
protected function loadRawMessages( $code ) {
if ( isset( $this->mRawMessages[$code] ) ) {
return;
}
if( isset( $this->mExtArray[$code] ) ) {
$this->mRawMessages[$code] = $this->mExtArray[$code] ;
} else {
$this->mRawMessages[$code] = array();
}
}
public function getLanguages() {
return $this->mLanguages;
}
}
/**
* @param $filename Filename containing the extension i18n
* @param $arrayname The name of the array in the filename
* @param $filter Optional, restrict check to a given language code (default; null)
*/
function checkExtensionLanguage( $filename, $arrayname, $filter = null ) {
$extLanguages = new extensionLanguages($filename, $arrayname);
$langs = $extLanguages->getLanguages();
if( !$langs ) {
print "ERROR> \$$arrayname array does not exist.\n";
return false;
}
$nErrors = 0;
if( $filter ) {
$nErrors += checkLanguage( $extLanguages, $filter );
} else {
print "Will check ". count($langs) . " languages : " . implode(' ', $langs) .".\n";
foreach( $langs as $lang ) {
if( $lang == 'en' ) {
#print "Skipped english language\n";
continue;
}
$nErrors += checkLanguage( $extLanguages, $lang );
}
}
return $nErrors;
}
/**
* Read the db file, parse it, start the check.
*/
function checkExtensionRepository( $extdir, $db ) {
$fh = fopen( $extdir. '/' . $db, 'r' );
$line_number = 0;
while( $line = fgets( $fh ) ) {
$line_number++;
// Ignore comments
if( preg_match( '/^#/', $line ) ) {
continue;
}
// Load data from i18n database
$data = split( ' ', chop($line) );
$i18n_file = @$data[0];
$arrayname = @$data[1];
print "------------------------------------------------------\n";
print "Checking $i18n_file (\$$arrayname).\n";
// Check data
if( !file_exists( $extdir . '/' . $i18n_file ) ) {
print "ERROR> $i18n_file not found ($db:$line_number).\n";
continue;
}
# if( $arrayname == '' ) {
# print "warning> no array name for $i18n_file ($db:$line_number).\n";
# }
$i18n_file = $extdir . '/' . $i18n_file ;
global $myLang;
$nErrors = checkExtensionLanguage( $i18n_file, $arrayname, $myLang );
if($nErrors == 1 ) {
print "\nFound $nErrors error for this extension.\n";
} elseif($nErrors) {
print "\nFound $nErrors errors for this extension.\n";
} else {
print "Looks OK.\n";
}
print "\n";
}
}
function usage() {
// Usage
print <<<END
Usage:
php checkExtensions.php <filename> <arrayname>
php checkExtensions.php --extdir <extension repository>
Common option:
--lang <language code> : only check the given language.
END;
die;
}
// Play with options and arguments
$myLang = isset($options['lang']) ? $options['lang'] : null;
if( isset( $options['extdir'] ) ) {
$extdb = $options['extdir'] . '/' . EXT_I18N_DB ;
if( file_exists( $extdb ) ) {
checkExtensionRepository( $options['extdir'], EXT_I18N_DB );
} else {
print "$extdb does not exist\n";
}
} else {
// Check arguments
if ( isset( $argv[0] ) ) {
if (file_exists( $argv[0] ) ) {
$filename = $argv[0];
} else {
print "Unable to open file '{$argv[0]}'\n";
usage();
}
if ( isset( $argv[1] ) ) {
$arrayname = $argv[1];
} else {
print "You must give an array name to be checked\n";
usage();
}
global $myLang;
checkExtensionLanguage( $filename, $arrayname, $myLang );
} else {
usage();
}
}