Add tests for parser tag hooks.
[lhc/web/wiklou.git] / maintenance / attachLatest.php
index ca8d1aa..449b67f 100644 (file)
@@ -1,9 +1,9 @@
 <?php
-// quick hackjob to fix damages imports on wikisource
-// page records have page_latest wrong
-
 /**
- * Copyright (C) 2005 Brion Vibber <brion@pobox.com>
+ * quick hackjob to fix damages imports on wikisource
+ * page records have page_latest wrong
+ *
+ * Copyright © 2005 Brion Vibber <brion@pobox.com>
  * http://www.mediawiki.org/
  *
  * This program is free software; you can redistribute it and/or modify
  * @ingroup Maintenance
  */
 
-require_once( "Maintenance.php" );
+require_once( dirname( __FILE__ ) . '/Maintenance.php' );
 
 class AttachLatest extends Maintenance {
-       
+
        public function __construct() {
                parent::__construct();
-               $this->addParam( "fix", "Actually fix the entries, will dry run otherwise" );
+               $this->addOption( "fix", "Actually fix the entries, will dry run otherwise" );
                $this->mDescription = "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 );
@@ -44,7 +44,7 @@ class AttachLatest extends Maintenance {
                        __METHOD__ );
 
                $n = 0;
-               while( $row = $dbw->fetchObject( $result ) ) {
+               foreach ( $result as $row ) {
                        $pageId = intval( $row->page_id );
                        $title = Title::makeTitle( $row->page_namespace, $row->page_title );
                        $name = $title->getPrefixedText();
@@ -52,27 +52,26 @@ class AttachLatest extends Maintenance {
                                'MAX(rev_timestamp)',
                                array( 'rev_page' => $pageId ),
                                __METHOD__ );
-                       if( !$latestTime ) {
-                               $this->output( wfWikiID()." $pageId [[$name]] can't find latest rev time?!\n" );
+                       if ( !$latestTime ) {
+                               $this->output( wfWikiID() . " $pageId [[$name]] can't find latest rev time?!\n" );
                                continue;
                        }
-       
+
                        $revision = Revision::loadFromTimestamp( $dbw, $title, $latestTime );
-                       if( is_null( $revision ) ) {
-                               $this->output( wfWikiID()." $pageId [[$name]] latest time $latestTime, can't find revision id\n" );
+                       if ( is_null( $revision ) ) {
+                               $this->output( wfWikiID() . " $pageId [[$name]] latest time $latestTime, can't find revision id\n" );
                                continue;
                        }
                        $id = $revision->getId();
-                       $this->output( wfWikiID()." $pageId [[$name]] latest time $latestTime, rev id $id\n" );
-                       if( $this->hasOption('fix') ) {
+                       $this->output( wfWikiID() . " $pageId [[$name]] latest time $latestTime, rev id $id\n" );
+                       if ( $this->hasOption( 'fix' ) ) {
                                $article = new Article( $title );
                                $article->updateRevisionOn( $dbw, $revision );
                        }
                        $n++;
                }
-               $dbw->freeResult( $result );
                $this->output( "Done! Processed $n pages.\n" );
-               if( !$this->hasOption('fix') ) {
+               if ( !$this->hasOption( 'fix' ) ) {
                        $this->output( "This was a dry run; rerun with --fix to update page_latest.\n" );
                }
        }