mirror of
				https://github.com/diocloid/LinkTitles.git
				synced 2025-10-22 05:42:32 +02:00 
			
		
		
		
	Upgrade to use of new MediaWiki\Title for use in MW 1.44
This commit is contained in:
		| @@ -64,7 +64,7 @@ class Extension { | ||||
| 		// MW 1.36+ | ||||
| 		if ( method_exists( MediaWikiServices::class, 'getWikiPageFactory' ) ) { | ||||
| 			$wikiPageFactory = MediaWikiServices::getInstance()->getWikiPageFactory(); | ||||
| 			$wikiPage = $wikiPageFactory->newFromTitle( $title ); | ||||
| 			$wikiPage = $wikiPageFactory->newFromLinkTarget( $title ); | ||||
| 		} else { | ||||
| 			$wikiPage = WikiPage::factory( $title ); | ||||
| 		} | ||||
| @@ -102,11 +102,11 @@ class Extension { | ||||
| 	 * | ||||
| 	 * Entry point for the SpecialLinkTitles class and the LinkTitlesJob class. | ||||
| 	 * | ||||
| 	 * @param  \Title $title Title object. | ||||
| 	 * @param  MediaWiki\Title\Title $title Title object. | ||||
| 	 * @param  \RequestContext $context Current request context. If in doubt, call MediaWiki's `RequestContext::getMain()` to obtain such an object. | ||||
| 	 * @return bool True if the page exists, false if the page does not exist | ||||
| 	 */ | ||||
| 	public static function processPage( \Title $title, \RequestContext $context ) { | ||||
| 	public static function processPage( MediaWiki\Title\Title $title, \RequestContext $context ) { | ||||
| 		$config = new Config(); | ||||
| 		$source = Source::createFromTitle( $title, $config ); | ||||
| 		if ( $source->hasContent() ) { | ||||
|   | ||||
| @@ -66,7 +66,7 @@ class Linker { | ||||
| 	 * callbacks in the Extension class do not always get a WikiPage object in the | ||||
| 	 * first place. | ||||
| 	 * | ||||
| 	 * @param \Title &$title Title object for the current page. | ||||
| 	 * @param MediaWiki\Title\Title &$title Title object for the current page. | ||||
| 	 * @param String $text String that holds the article content | ||||
| 	 * @return String|null Source page text with links to target pages, or null if no links were added | ||||
| 	 */ | ||||
|   | ||||
| @@ -46,11 +46,11 @@ class Source { | ||||
| 	private $content; | ||||
|  | ||||
| 	/** | ||||
| 	 * Creates a Source object from a \Title. | ||||
| 	 * @param  \Title  $title  Title object from which to create the Source. | ||||
| 	 * Creates a Source object from a MediaWiki\Title\Title. | ||||
| 	 * @param  MediaWiki\Title\Title  $title  Title object from which to create the Source. | ||||
| 	 * @return Source          Source object created from the title. | ||||
| 	 */ | ||||
| 	public static function createFromTitle( \Title $title, Config $config ) { | ||||
| 	public static function createFromTitle( MediaWiki\Title\Title $title, Config $config ) { | ||||
| 		$source = new Source( $config ); | ||||
| 		$source->title = $title; | ||||
| 		return $source; | ||||
| @@ -62,12 +62,12 @@ class Source { | ||||
| 	 * This factory can be called e.g. from a onPageContentSave event handler | ||||
| 	 * which knows both these parameters. | ||||
| 	 * | ||||
| 	 * @param  \Title $title Title of the source page | ||||
| 	 * @param  \MediaWiki\Title\Title $title Title of the source page | ||||
| 	 * @param  String $text  String representation of the page content | ||||
| 	 * @param  Config    $config   LinkTitles configuration | ||||
| 	 * @return Source        Source object created from the title and the text | ||||
| 	 */ | ||||
| 	public static function createFromTitleAndText( \Title $title, $text, Config $config ) { | ||||
| 	public static function createFromTitleAndText( \MediaWiki\Title\Title $title, $text, Config $config ) { | ||||
| 		$source = Source::createFromTitle( $title, $config); | ||||
| 		$source->text = $text; | ||||
| 		return $source; | ||||
| @@ -158,7 +158,7 @@ class Source { | ||||
| 	/** | ||||
| 	 * Gets the title. | ||||
| 	 * | ||||
| 	 * @return \Title Title of the source page. | ||||
| 	 * @return MediaWiki\Title\Title Title of the source page. | ||||
| 	 */ | ||||
| 	public function getTitle() { | ||||
| 		if ( $this->title === null ) { | ||||
| @@ -249,7 +249,7 @@ class Source { | ||||
| 	/** | ||||
|  	 * Obtain a WikiPage object. | ||||
| 	 * Workaround for MediaWiki 1.36+ which deprecated Wikipage::factory. | ||||
| 	 * @param \Title $title | ||||
| 	 * @param MediaWiki\Title\Title $title | ||||
| 	 * @return WikiPage object | ||||
| 	 */ | ||||
| 	private static function getPageObject( $title ) { | ||||
|   | ||||
| @@ -25,6 +25,7 @@ | ||||
| namespace LinkTitles; | ||||
|  | ||||
| use MediaWiki\MediaWikiServices; | ||||
| use MediaWiki\Title\Title as MWTitle; | ||||
|  | ||||
| /** | ||||
|  * Represents a page that is a potential link target. | ||||
| @@ -32,7 +33,7 @@ use MediaWiki\MediaWikiServices; | ||||
| class Target { | ||||
| 	/** | ||||
| 	 * A Title object for the target page currently being examined. | ||||
| 	 * @var \Title $title | ||||
| 	 * @var MediaWiki\Title\Title $title | ||||
| 	 */ | ||||
| 	private $title; | ||||
|  | ||||
| @@ -76,7 +77,7 @@ class Target { | ||||
| 	 * @param String &$title Title of the target page | ||||
| 	 */ | ||||
| 	public function __construct( $namespace, $title, Config &$config ) { | ||||
| 		$this->title = \Title::makeTitleSafe( $namespace, $title ); | ||||
| 		$this->title = MWTitle::makeTitleSafe( $namespace, $title ); | ||||
| 		$this->titleValue = $this->title->getTitleValue(); | ||||
| 		$this->config = $config; | ||||
|  | ||||
| @@ -252,7 +253,7 @@ class Target { | ||||
| 	/** | ||||
|  	 * Obtain a page's content. | ||||
| 	 * Workaround for MediaWiki 1.36+ which deprecated Wikipage::factory. | ||||
| 	 * @param  \Title $title | ||||
| 	 * @param  MediaWiki\Title\Title $title | ||||
| 	 * @return Content content object of the page | ||||
| 	 */ | ||||
| 	private static function getPageContents( $title ) { | ||||
|   | ||||
| @@ -24,6 +24,8 @@ | ||||
|  */ | ||||
| namespace LinkTitles; | ||||
|  | ||||
| use MediaWiki\Title\Title; | ||||
|  | ||||
| /** | ||||
|  * Fetches potential target page titles from the database. | ||||
|  */ | ||||
| @@ -41,7 +43,7 @@ class Targets { | ||||
| 	 * @param  String $sourceNamespace The namespace of the current page. | ||||
| 	 * @param  Config $config    LinkTitles configuration. | ||||
| 	 */ | ||||
| 	public static function singleton( \Title $title, Config $config ) { | ||||
| 	public static function singleton( \MediaWiki\Title\Title $title, Config $config ) { | ||||
| 		if ( ( self::$instance === null ) || ( self::$instance->sourceNamespace != $title->getNamespace() ) ) { | ||||
| 			self::$instance = new Targets( $title, $config ); | ||||
| 		} | ||||
| @@ -83,9 +85,9 @@ class Targets { | ||||
|  | ||||
| 	/** | ||||
| 	 * The constructor is private to enforce using the singleton pattern. | ||||
| 	 * @param  \Title $title | ||||
| 	 * @param MediaWiki\Title\Title $title | ||||
| 	 */ | ||||
| 	private function __construct( \Title $title, Config $config) { | ||||
| 	private function __construct( MediaWiki\Title\Title $title, Config $config) { | ||||
| 		$this->config = $config; | ||||
| 		$this->sourceNamespace = $title->getNamespace(); | ||||
| 		$this->fetch(); | ||||
| @@ -135,7 +137,7 @@ class Targets { | ||||
| 		// shortest to longest. Only titles from 'normal' pages (namespace uid | ||||
| 		// = 0) are returned. Since the db may be sqlite, we need a try..catch | ||||
| 		// structure because sqlite does not support the CHAR_LENGTH function. | ||||
| 		$dbr = wfGetDB( DB_REPLICA ); | ||||
| 		$dbr = MediaWikiServices::getInstance()->getDBLoadBalancer()->getConnection( DB_REPLICA ); | ||||
| 		$this->queryResult = $dbr->select( | ||||
| 			'page', | ||||
| 			array( 'page_title', 'page_namespace' , "weight" => $weightSelect), | ||||
|   | ||||
		Reference in New Issue
	
	Block a user