diff options
author | Pierre Schmitz <pierre@archlinux.de> | 2013-01-18 16:46:04 +0100 |
---|---|---|
committer | Pierre Schmitz <pierre@archlinux.de> | 2013-01-18 16:46:04 +0100 |
commit | 63601400e476c6cf43d985f3e7b9864681695ed4 (patch) | |
tree | f7846203a952e38aaf66989d0a4702779f549962 /includes/filerepo/backend/lockmanager/LockManagerGroup.php | |
parent | 8ff01378c9e0207f9169b81966a51def645b6a51 (diff) |
Update to MediaWiki 1.20.2
this update includes:
* adjusted Arch Linux skin
* updated FluxBBAuthPlugin
* patch for https://bugzilla.wikimedia.org/show_bug.cgi?id=44024
Diffstat (limited to 'includes/filerepo/backend/lockmanager/LockManagerGroup.php')
-rw-r--r-- | includes/filerepo/backend/lockmanager/LockManagerGroup.php | 89 |
1 files changed, 0 insertions, 89 deletions
diff --git a/includes/filerepo/backend/lockmanager/LockManagerGroup.php b/includes/filerepo/backend/lockmanager/LockManagerGroup.php deleted file mode 100644 index 11e77972..00000000 --- a/includes/filerepo/backend/lockmanager/LockManagerGroup.php +++ /dev/null @@ -1,89 +0,0 @@ -<?php -/** - * Class to handle file lock manager registration - * - * @ingroup LockManager - * @author Aaron Schulz - * @since 1.19 - */ -class LockManagerGroup { - - /** - * @var LockManagerGroup - */ - protected static $instance = null; - - /** @var Array of (name => ('class' =>, 'config' =>, 'instance' =>)) */ - protected $managers = array(); - - protected function __construct() {} - protected function __clone() {} - - /** - * @return LockManagerGroup - */ - public static function singleton() { - if ( self::$instance == null ) { - self::$instance = new self(); - self::$instance->initFromGlobals(); - } - return self::$instance; - } - - /** - * Register lock managers from the global variables - * - * @return void - */ - protected function initFromGlobals() { - global $wgLockManagers; - - $this->register( $wgLockManagers ); - } - - /** - * Register an array of file lock manager configurations - * - * @param $configs Array - * @return void - * @throws MWException - */ - protected function register( array $configs ) { - foreach ( $configs as $config ) { - if ( !isset( $config['name'] ) ) { - throw new MWException( "Cannot register a lock manager with no name." ); - } - $name = $config['name']; - if ( !isset( $config['class'] ) ) { - throw new MWException( "Cannot register lock manager `{$name}` with no class." ); - } - $class = $config['class']; - unset( $config['class'] ); // lock manager won't need this - $this->managers[$name] = array( - 'class' => $class, - 'config' => $config, - 'instance' => null - ); - } - } - - /** - * Get the lock manager object with a given name - * - * @param $name string - * @return LockManager - * @throws MWException - */ - public function get( $name ) { - if ( !isset( $this->managers[$name] ) ) { - throw new MWException( "No lock manager defined with the name `$name`." ); - } - // Lazy-load the actual lock manager instance - if ( !isset( $this->managers[$name]['instance'] ) ) { - $class = $this->managers[$name]['class']; - $config = $this->managers[$name]['config']; - $this->managers[$name]['instance'] = new $class( $config ); - } - return $this->managers[$name]['instance']; - } -} |