<?php
/**
- * @file
+ * @file
* @ingroup Maintenance
* @author Simetrical
*/
$this->addOption( 'throttle', 'Wait this many milliseconds after each category. Default: 0', false, true );
$this->addOption( 'force', 'Run regardless of whether the database says it\'s been run already' );
}
-
+
public function execute() {
$begin = $this->getOption( 'begin', '' );
$maxSlaveLag = $this->getOption( 'max-slave-lag', 10 );
private function doPopulateCategory( $begin, $maxlag, $throttle, $force ) {
$dbw = wfGetDB( DB_MASTER );
-
+
if ( !$force ) {
$row = $dbw->selectRow(
'updatelog',
'1',
array( 'ul_key' => 'populate category' ),
- __FUNCTION__
+ __METHOD__
);
if ( $row ) {
$this->output( "Category table already populated. Use php " .
return true;
}
}
-
+
$maxlag = intval( $maxlag );
$throttle = intval( $throttle );
- $force = (bool)$force;
if ( $begin !== '' ) {
$where = 'cl_to > ' . $dbw->addQuotes( $begin );
} else {
$where = null;
}
$i = 0;
-
+
while ( true ) {
# Find which category to update
$row = $dbw->selectRow(
'categorylinks',
'cl_to',
$where,
- __FUNCTION__,
+ __METHOD__,
array(
'ORDER BY' => 'cl_to'
)
}
$name = $row->cl_to;
$where = 'cl_to > ' . $dbw->addQuotes( $name );
-
+
# Use the row to update the category count
$cat = Category::newFromName( $name );
if ( !is_object( $cat ) ) {
} else {
$cat->refreshCounts();
}
-
+
++$i;
if ( !( $i % self::REPORTING_INTERVAL ) ) {
$this->output( "$name\n" );
}
usleep( $throttle * 1000 );
}
-
+
if ( $dbw->insert(
'updatelog',
array( 'ul_key' => 'populate category' ),
- __FUNCTION__,
+ __METHOD__,
'IGNORE'
)
) {
- wfOut( "Category population complete.\n" );
+ $this->output( "Category population complete.\n" );
return true;
} else {
- wfOut( "Could not insert category population row.\n" );
+ $this->output( "Could not insert category population row.\n" );
return false;
}
}