bugfix: if the upload path is absolute, don't prepend the server URL
[lhc/web/wiklou.git] / includes / SpecialWhatlinkshere.php
index 23922fd..81e8faa 100644 (file)
-<?
-
-function wfSpecialWhatlinkshere($par = NULL)
-{
-       global $wgUser, $wgOut, $target;
-       $fname = "wfSpecialWhatlinkshere";
-
-       if($par) {
-               $target = $par;
-       } else {
-               $target = wfCleanQueryVar( $_REQUEST['target'] );
-       }
-       if ( "" == $target ) {
-               $wgOut->errorpage( "notargettitle", "notargettext" );
+<?php
+/**
+ *
+ * @package MediaWiki
+ * @subpackage SpecialPage
+ */
+
+/**
+ * Entry point
+ * @param string $par An article name ??
+ */
+function wfSpecialWhatlinkshere($par = NULL) {
+       global $wgUser, $wgOut, $wgRequest;
+       $fname = 'wfSpecialWhatlinkshere';
+
+       $target = isset($par) ? $par : $wgRequest->getVal( 'target' );
+       list( $limit, $offset ) = $wgRequest->getLimitOffset(); 
+
+       if (is_null($target)) {
+               $wgOut->errorpage( 'notargettitle', 'notargettext' );
                return;
        }
+
        $nt = Title::newFromURL( $target );
+       if( !$nt ) {
+               $wgOut->errorpage( 'notargettitle', 'notargettext' );
+               return;
+       }
        $wgOut->setPagetitle( $nt->getPrefixedText() );
-       $wgOut->setSubtitle( wfMsg( "linklistsub" ) );
+       $wgOut->setSubtitle( wfMsg( 'linklistsub' ) );
 
-       $id = $nt->getArticleID();
        $sk = $wgUser->getSkin();
-       $isredir = " (" . wfMsg( "isredirect" ) . ")\n";
+       $isredir = ' (' . wfMsg( 'isredirect' ) . ")\n";
 
-       if ( 0 == $id ) {
-               $sql = "SELECT DISTINCT bl_from FROM brokenlinks WHERE bl_to='" .
-                 wfStrencode( $nt->getPrefixedDBkey() ) . "' LIMIT 500";
-               $res = wfQuery( $sql, DB_READ, $fname );
+       $wgOut->addHTML('&lt; '.$sk->makeKnownLinkObj($nt, '', 'redirect=no' )."<br />\n");
 
-               if ( 0 == wfNumRows( $res ) ) {
-                       $wgOut->addHTML( wfMsg( "nolinkshere" ) );
-               } else {
-                       $wgOut->addHTML( wfMsg( "linkshere" ) );
-                       $wgOut->addHTML( "\n<ul>" );
-
-                       while ( $row = wfFetchObject( $res ) ) {
-                               $lid = $row->bl_from;
-                               $sql = "SELECT cur_namespace,cur_title,cur_is_redirect " .
-                                 "FROM cur WHERE cur_id={$lid}";
-                               $res2 = wfQuery( $sql, DB_READ, $fname );
-                               $s = wfFetchObject( $res2 );
-
-                               $n = Title::makeName( $s->cur_namespace, $s->cur_title );
-                               $link = $sk->makeKnownLink( $n, "", "redirect=no" );
-                               $wgOut->addHTML( "<li>{$link}" );
-
-                               if ( 1 == $s->cur_is_redirect ) {
-                                       $wgOut->addHTML( $isredir );
-                                       wfShowIndirectLinks( 1, $lid );
-                               }
-                               $wgOut->addHTML( "</li>\n" );
-                       }
-                       $wgOut->addHTML( "</ul>\n" );
-                       wfFreeResult( $res );
-               }
-       } else {
-               wfShowIndirectLinks( 0, $id );
-       }
+       $specialTitle = Title::makeTitle( NS_SPECIAL, 'Whatlinkshere' );
+       $wgOut->addHTML( wfViewPrevNext( $offset, $limit, $specialTitle, 'target=' . urlencode( $target ) ) );
+
+       wfShowIndirectLinks( 0, $nt, $limit, $offset );
+       $wgOut->addHTML( wfViewPrevNext( $offset, $limit, $specialTitle, 'target=' . urlencode( $target ) ) );
 }
 
-function wfShowIndirectLinks( $level, $lid )
-{
+/**
+ * @param int   $level
+ * @param Title $target
+ * @param int   $limit
+ * @param int   $offset
+ * @access private
+ */
+function wfShowIndirectLinks( $level, $target, $limit, $offset = 0 ) {
        global $wgOut, $wgUser;
-       $fname = "wfShowIndirectLinks";
+       $fname = 'wfShowIndirectLinks';
 
-       $sql = "SELECT DISTINCT l_from FROM links WHERE l_to={$lid} LIMIT 500";
-       $res = wfQuery( $sql, DB_READ, $fname );
+       $dbr =& wfGetDB( DB_READ );
+       
+       if ( $level == 0 ) {
+               $limitSql = $dbr->limitResult( $limit, $offset );
+       } else {
+               $limitSql = "LIMIT $limit";
+       }
+
+       $res = $dbr->select( array( 'pagelinks', 'page' ),
+               array( 'page_id', 'page_namespace', 'page_title', 'page_is_redirect' ),
+               array(
+                       'pl_from=page_id',
+                       'pl_namespace' => $target->getNamespace(),
+                       'pl_title'     => $target->getDbKey() ),
+               $fname,
+               $limitSql );
 
-       if ( 0 == wfNumRows( $res ) ) {
+       if ( 0 == $dbr->numRows( $res ) ) {
                if ( 0 == $level ) {
-                       $wgOut->addHTML( wfMsg( "nolinkshere" ) );
+                       $wgOut->addHTML( wfMsg( 'nolinkshere' ) );
                }
                return;
        }
        if ( 0 == $level ) {
-               $wgOut->addHTML( wfMsg( "linkshere" ) );
+               $wgOut->addHTML( wfMsg( 'linkshere' ) );
        }
        $sk = $wgUser->getSkin();
-       $isredir = " (" . wfMsg( "isredirect" ) . ")\n";
+       $isredir = ' (' . wfMsg( 'isredirect' ) . ")\n";
 
-       $wgOut->addHTML( "<ul>" );
-       while ( $row = wfFetchObject( $res ) ) {
-               $nt = Title::newFromDBkey( $row->l_from );
-               $ns = $nt->getNamespace();
-               $t = wfStrencode( $nt->getDBkey() );
+       $wgOut->addHTML( '<ul>' );
+       while ( $row = $dbr->fetchObject( $res ) ) {
+               $nt = Title::makeTitle( $row->page_namespace, $row->page_title );
 
-               $link = $sk->makeKnownLink( $row->l_from, "", "redirect=no" );
-               $wgOut->addHTML( "<li>{$link}" );
+               if ( $row->page_is_redirect ) {
+                       $extra = 'redirect=no';
+               } else {
+                       $extra = '';
+               }
 
-               $sql = "SELECT cur_id,cur_is_redirect FROM cur " .
-                 "WHERE cur_namespace={$ns} AND cur_title='{$t}'";
-               $res2 = wfQuery( $sql, DB_READ, $fname );
-               $s = wfFetchObject( $res2 );
+               $link = $sk->makeKnownLinkObj( $nt, '', $extra );
+               $wgOut->addHTML( '<li>'.$link );
 
-               if ( 1 == $s->cur_is_redirect ) {
+               if ( $row->page_is_redirect ) {
                        $wgOut->addHTML( $isredir );
                        if ( $level < 2 ) {
-                               wfShowIndirectLinks( $level + 1, $s->cur_id );
+                               wfShowIndirectLinks( $level + 1, $nt, 500 );
                        }
                }
-               $wgOut->addHTML( "</il>\n" );
+               $wgOut->addHTML( "</li>\n" );
        }
        $wgOut->addHTML( "</ul>\n" );
 }