From 08aa4418c30cfc18ccc69a0f0f9cb9e17be6c196 Mon Sep 17 00:00:00 2001 From: Pierre Schmitz Date: Mon, 12 Aug 2013 09:28:15 +0200 Subject: Update to MediaWiki 1.21.1 --- includes/dao/DBAccessBase.php | 92 ++++++++++++++++++++++++++++++++++++++++ includes/dao/IDBAccessObject.php | 4 +- 2 files changed, 95 insertions(+), 1 deletion(-) create mode 100644 includes/dao/DBAccessBase.php (limited to 'includes/dao') diff --git a/includes/dao/DBAccessBase.php b/includes/dao/DBAccessBase.php new file mode 100644 index 00000000..6c009dee --- /dev/null +++ b/includes/dao/DBAccessBase.php @@ -0,0 +1,92 @@ +wiki = $wiki; + } + + /** + * Returns a database connection. + * + * @see wfGetDB() + * @see LoadBalancer::getConnection() + * + * @since 1.21 + * + * @param int $id Which connection to use + * @param array $groups Query groups + * + * @return DatabaseBase + */ + protected function getConnection( $id, $groups = array() ) { + $loadBalancer = wfGetLB( $this->wiki ); + return $loadBalancer->getConnection( $id, $groups, $this->wiki ); + } + + /** + * Releases a database connection and makes it available for recycling. + * + * @see LoadBalancer::reuseConnection() + * + * @since 1.21 + * + * @param DatabaseBase $db the database connection to release. + */ + protected function releaseConnection( DatabaseBase $db ) { + if ( $this->wiki !== false ) { + $loadBalancer = $this->getLoadBalancer(); + $loadBalancer->reuseConnection( $db ); + } + } + + /** + * Get the database type used for read operations. + * + * @see wfGetLB + * + * @since 1.21 + * + * @return LoadBalancer The database load balancer object + */ + public function getLoadBalancer() { + return wfGetLB( $this->wiki ); + } +} diff --git a/includes/dao/IDBAccessObject.php b/includes/dao/IDBAccessObject.php index e30522a5..4eb6ff3e 100644 --- a/includes/dao/IDBAccessObject.php +++ b/includes/dao/IDBAccessObject.php @@ -41,10 +41,12 @@ * - b) Determine the new row (expensive, so we don't want to hold locks now) * - c) Re-read the current row with READ_LOCKING; if it changed then bail out * - d) otherwise, do the updates + * + * @since 1.20 */ interface IDBAccessObject { // Constants for object loading bitfield flags (higher => higher QoS) - const READ_LATEST = 1; // read from the master + const READ_LATEST = 1; // read from the master const READ_LOCKING = 3; // READ_LATEST and "FOR UPDATE" // Convenience constant for callers to explicitly request slave data -- cgit v1.2.2