X-Git-Url: https://git.cyclocoop.org/%28%28?a=blobdiff_plain;f=maintenance%2FattachLatest.php;h=36060d8371c473202d4026098dbd0db2776f1f06;hb=fc6d8a9cdb90e753ea05f2da9b32148456ecccc1;hp=2cf277fe24f281e42bfeedefc5db02a5c09de662;hpb=f10c9815e69b59844c178d218640bd1ac0435896;p=lhc%2Fweb%2Fwiklou.git diff --git a/maintenance/attachLatest.php b/maintenance/attachLatest.php index 2cf277fe24..36060d8371 100644 --- a/maintenance/attachLatest.php +++ b/maintenance/attachLatest.php @@ -3,7 +3,7 @@ * Corrects wrong values in the `page_latest` field in the database. * * Copyright © 2005 Brion Vibber - * http://www.mediawiki.org/ + * https://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 @@ -33,19 +33,24 @@ require_once __DIR__ . '/Maintenance.php'; * @ingroup Maintenance */ class AttachLatest extends Maintenance { - public function __construct() { parent::__construct(); $this->addOption( "fix", "Actually fix the entries, will dry run otherwise" ); - $this->mDescription = "Fix page_latest entries in the page table"; + $this->addOption( "regenerate-all", + "Regenerate the page_latest field for all records in table page" ); + $this->addDescription( 'Fix page_latest entries in the page table' ); } public function execute() { $this->output( "Looking for pages with page_latest set to 0...\n" ); - $dbw = wfGetDB( DB_MASTER ); + $dbw = $this->getDB( DB_MASTER ); + $conds = [ 'page_latest' => 0 ]; + if ( $this->hasOption( 'regenerate-all' ) ) { + $conds = ''; + } $result = $dbw->select( 'page', - array( 'page_id', 'page_namespace', 'page_title' ), - array( 'page_latest' => 0 ), + [ 'page_id', 'page_namespace', 'page_title' ], + $conds, __METHOD__ ); $n = 0; @@ -55,7 +60,7 @@ class AttachLatest extends Maintenance { $name = $title->getPrefixedText(); $latestTime = $dbw->selectField( 'revision', 'MAX(rev_timestamp)', - array( 'rev_page' => $pageId ), + [ 'rev_page' => $pageId ], __METHOD__ ); if ( !$latestTime ) { $this->output( wfWikiID() . " $pageId [[$name]] can't find latest rev time?!\n" ); @@ -64,7 +69,8 @@ class AttachLatest extends Maintenance { $revision = Revision::loadFromTimestamp( $dbw, $title, $latestTime ); if ( is_null( $revision ) ) { - $this->output( wfWikiID() . " $pageId [[$name]] latest time $latestTime, can't find revision id\n" ); + $this->output( wfWikiID() + . " $pageId [[$name]] latest time $latestTime, can't find revision id\n" ); continue; } $id = $revision->getId();