use Cdb\Exception as CdbException;
use Cdb\Reader as CdbReader;
use Cdb\Writer as CdbWriter;
+use CLDRPluralRuleParser\Evaluator;
/**
* Class for caching the contents of localisation files, Messages*.php
$storeClass = 'LCStoreStaticArray';
break;
case 'detect':
- $storeClass = $wgCacheDirectory ? 'LCStoreCDB' : 'LCStoreDB';
+ if ( !empty( $conf['storeDirectory'] ) ) {
+ $storeClass = 'LCStoreCDB';
+ } else {
+ $cacheDir = $wgCacheDirectory ?: wfTempDir();
+ if ( $cacheDir ) {
+ $storeConf['directory'] = $cacheDir;
+ $storeClass = 'LCStoreCDB';
+ } else {
+ $storeClass = 'LCStoreDB';
+ }
+ }
break;
default:
throw new MWException(
return null;
}
try {
- $compiledRules = CLDRPluralRuleEvaluator::compile( $rules );
+ $compiledRules = Evaluator::compile( $rules );
} catch ( CLDRPluralRuleError $e ) {
wfDebugLog( 'l10n', $e->getMessage() );
$this->recachedLangs[$code] = true;
# Initial values
- $initialData = array_combine(
- self::$allKeys,
- array_fill( 0, count( self::$allKeys ), null ) );
+ $initialData = array_fill_keys( self::$allKeys, null );
$coreData = $initialData;
$deps = array();
$messageDirs = $this->getMessagesDirs();
# Load non-JSON localisation data for extensions
- $extensionData = array_combine(
- $codeSequence,
- array_fill( 0, count( $codeSequence ), $initialData ) );
+ $extensionData = array_fill_keys( $codeSequence, $initialData );
foreach ( $wgExtensionMessagesFiles as $extension => $fileName ) {
if ( isset( $messageDirs[$extension] ) ) {
# This extension has JSON message data; skip the PHP shim
* This will work on any MediaWiki installation.
*/
class LCStoreDB implements LCStore {
+ /** @var string */
private $currentLang;
+ /** @var bool */
private $writesDone = false;
-
- /** @var DatabaseBase */
+ /** @var IDatabase */
private $dbw;
/** @var array */
private $batch = array();
-
+ /** @var bool */
private $readOnly = false;
public function get( $code, $key ) {
- if ( $this->writesDone ) {
- $db = wfGetDB( DB_MASTER );
+ if ( $this->writesDone && $this->dbw ) {
+ $db = $this->dbw; // see the changes in finishWrite()
} else {
$db = wfGetDB( DB_SLAVE );
}
- $row = $db->selectRow( 'l10n_cache', array( 'lc_value' ),
- array( 'lc_lang' => $code, 'lc_key' => $key ), __METHOD__ );
- if ( $row ) {
- return unserialize( $db->decodeBlob( $row->lc_value ) );
- } else {
- return null;
- }
+
+ $value = $db->selectField(
+ 'l10n_cache',
+ 'lc_value',
+ array( 'lc_lang' => $code, 'lc_key' => $key ),
+ __METHOD__
+ );
+
+ return ( $value !== false ) ? unserialize( $db->decodeBlob( $value ) ) : null;
}
public function startWrite( $code ) {
}
$this->dbw = wfGetDB( DB_MASTER );
+ $this->readOnly = $this->dbw->isReadOnly();
$this->currentLang = $code;
$this->batch = array();
throw new MWException( __CLASS__ . ': must call startWrite() before finishWrite()' );
}
- $this->dbw->begin( __METHOD__ );
+ $this->dbw->startAtomic( __METHOD__ );
try {
- $this->dbw->delete( 'l10n_cache',
- array( 'lc_lang' => $this->currentLang ), __METHOD__ );
+ $this->dbw->delete(
+ 'l10n_cache',
+ array( 'lc_lang' => $this->currentLang ),
+ __METHOD__
+ );
foreach ( array_chunk( $this->batch, 500 ) as $rows ) {
$this->dbw->insert( 'l10n_cache', $rows, __METHOD__ );
}
throw $e;
}
}
- $this->dbw->commit( __METHOD__ );
+ $this->dbw->endAtomic( __METHOD__ );
$this->currentLang = null;
$this->batch = array();
$this->batch[] = array(
'lc_lang' => $this->currentLang,
'lc_key' => $key,
- 'lc_value' => $this->dbw->encodeBlob( serialize( $value ) ) );
+ 'lc_value' => $this->dbw->encodeBlob( serialize( $value ) )
+ );
}
}