Redo r53641, reverted in r55457, now using indexed queries:
authorAlexandre Emsenhuber <ialex@users.mediawiki.org>
Sun, 23 Aug 2009 09:39:13 +0000 (09:39 +0000)
committerAlexandre Emsenhuber <ialex@users.mediawiki.org>
Sun, 23 Aug 2009 09:39:13 +0000 (09:39 +0000)
* (bug 19857) maintenance/deleteRevision.php on last revision no longer breaks target page

RELEASE-NOTES
maintenance/deleteRevision.php

index 3d7cddd..020931f 100644 (file)
@@ -423,6 +423,9 @@ this. Was used when mwEmbed was going to be an extension.
 * (bug 20317) Cleaned up default main page link accesskey settings
 * (bug 20362) Special:Statistics now produces valid HTML when view counters are
   enabled
+* (bug 19857) maintenance/deleteRevision.php on last revision no longer breaks
+  target page
+
 
 == API changes in 1.16 ==
 
index 980b0c3..5dc0b59 100644 (file)
@@ -63,7 +63,14 @@ class DeleteRevision extends Maintenance {
                                $this->output( "Revision $revID not found\n" );
                        } else {
                                $affected += $dbw->affectedRows();
+                               $pageID = $dbw->selectField( 'revision', 'rev_page', array( 'rev_id' => $revID ), __METHOD__ );
+                               $pageLatest = $dbw->selectField( 'page', 'page_latest', array( 'page_id' => $pageID ), __METHOD__ );
                                $dbw->delete( 'revision', array( 'rev_id' => $revID ) );
+                               if ( $pageLatest == $revID ) {
+                                       // Database integrity
+                                       $newLatest = $dbw->selectField( 'revision', 'rev_id', array( 'rev_page' => $pageID ), __METHOD__, array( 'ORDER BY' => 'rev_timestamp DESC' ) );
+                                       $dbw->update( 'page', array( 'page_latest' => $newLatest ), array( 'page_id' => $pageID ), __METHOD__ );
+                               }
                        }
                }
                $this->output( "Deleted $affected revisions\n" );