]> scripts.mit.edu Git - autoinstalls/mediawiki.git/blobdiff - includes/specials/SpecialWantedfiles.php
MediaWiki 1.17.0
[autoinstalls/mediawiki.git] / includes / specials / SpecialWantedfiles.php
index 189b9d8bd91b5b521e5af2797ec09cdc7619162e..d6c1157b0020b678ac066aa0ef7df55660ebed67 100644 (file)
@@ -1,17 +1,33 @@
 <?php
-/*
+/**
+ * Implements Special:Wantedfiles
+ *
+ * Copyright © 2008 Soxred93
+ *
+ * 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
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ * http://www.gnu.org/copyleft/gpl.html
+ *
  * @file
  * @ingroup SpecialPage
+ * @author Soxred93 <soxred93@gmail.com>
  */
 
 /**
- * Querypage that lists the most wanted files - implements Special:Wantedfiles
+ * Querypage that lists the most wanted files
  *
  * @ingroup SpecialPage
- *
- * @author Soxred93 <soxred93@gmail.com>
- * @copyright Copyright © 2008, Soxred93
- * @license http://www.gnu.org/copyleft/gpl.html GNU General Public License 2.0 or later
  */
 class WantedFilesPage extends WantedQueryPage {
 
@@ -19,9 +35,19 @@ class WantedFilesPage extends WantedQueryPage {
                return 'Wantedfiles';
        }
 
+       /**
+        * KLUGE: The results may contain false positives for files
+        * that exist e.g. in a shared repo.  Setting this at least
+        * keeps them from showing up as redlinks in the output, even
+        * if it doesn't fix the real problem (bug 6220).
+        */
+       function forceExistenceCheck() {
+               return true;
+       }
+
        function getSQL() {
                $dbr = wfGetDB( DB_SLAVE );
-               list( $imagelinks, $page ) = $dbr->tableNamesN( 'imagelinks', 'page' );
+               list( $imagelinks, $image ) = $dbr->tableNamesN( 'imagelinks', 'image' );
                $name = $dbr->addQuotes( $this->getName() );
                return
                        "
@@ -31,8 +57,8 @@ class WantedFilesPage extends WantedQueryPage {
                                il_to as title,
                                COUNT(*) as value
                        FROM $imagelinks
-                       LEFT JOIN $page ON il_to = page_title AND page_namespace = ". NS_FILE ."
-                       WHERE page_title IS NULL
+                       LEFT JOIN $image ON il_to = img_name
+                       WHERE img_name IS NULL
                        GROUP BY il_to
                        ";
        }