mirror of
				https://github.com/diocloid/LinkTitles.git
				synced 2025-10-22 05:42:32 +02:00 
			
		
		
		
	Suppress second pass if $wgLinkTitlesFirstOnly is true.
- Fix: Do not link titles twice if $wgLinkTitlesFirstOnly and $wgLinkTitlesSmartMode are both true. Closes #12.
This commit is contained in:
		| @@ -123,6 +123,8 @@ class Extension { | |||||||
|  |  | ||||||
| 		( $wgLinkTitlesPreferShortTitles ) ? $sort_order = 'ASC' : $sort_order = 'DESC'; | 		( $wgLinkTitlesPreferShortTitles ) ? $sort_order = 'ASC' : $sort_order = 'DESC'; | ||||||
| 		( $wgLinkTitlesFirstOnly ) ? $limit = 1 : $limit = -1; | 		( $wgLinkTitlesFirstOnly ) ? $limit = 1 : $limit = -1; | ||||||
|  | 		$limitReached = false; | ||||||
|  | 		error_log($wgLinkTitlesFirstOnly); | ||||||
|  |  | ||||||
| 		self::$currentTitle = $title; | 		self::$currentTitle = $title; | ||||||
| 		$newText = $text; | 		$newText = $text; | ||||||
| @@ -214,7 +216,8 @@ class Extension { | |||||||
| 				// even indexes will point to text that is not enclosed by brackets | 				// even indexes will point to text that is not enclosed by brackets | ||||||
| 				$arr[$i] = preg_replace_callback( $regex, | 				$arr[$i] = preg_replace_callback( $regex, | ||||||
| 					'LinkTitles\Extension::simpleModeCallback', $arr[$i], $limit, $count ); | 					'LinkTitles\Extension::simpleModeCallback', $arr[$i], $limit, $count ); | ||||||
| 				if (( $limit >= 0 ) && ( $count > 0  )) { | 				if ( $wgLinkTitlesFirstOnly && ( $count > 0 ) ) { | ||||||
|  | 					$limitReached = true; | ||||||
| 					break;  | 					break;  | ||||||
| 				}; | 				}; | ||||||
| 			}; | 			}; | ||||||
| @@ -223,7 +226,7 @@ class Extension { | |||||||
| 			// If smart mode is turned on, the extension will perform a second | 			// If smart mode is turned on, the extension will perform a second | ||||||
| 			// pass on the page and add links with aliases where the case does | 			// pass on the page and add links with aliases where the case does | ||||||
| 			// not match. | 			// not match. | ||||||
| 			if ($wgLinkTitlesSmartMode) { | 			if ( $wgLinkTitlesSmartMode && !$limitReached ) { | ||||||
| 				$arr = preg_split( self::$delimiter, $newText, -1, PREG_SPLIT_DELIM_CAPTURE ); | 				$arr = preg_split( self::$delimiter, $newText, -1, PREG_SPLIT_DELIM_CAPTURE ); | ||||||
|  |  | ||||||
| 				for ( $i = 0; $i < count( $arr ); $i+=2 ) { | 				for ( $i = 0; $i < count( $arr ); $i+=2 ) { | ||||||
| @@ -232,7 +235,7 @@ class Extension { | |||||||
| 						self::$wordStartDelim . '(' . $quotedTitle . ')' .  | 						self::$wordStartDelim . '(' . $quotedTitle . ')' .  | ||||||
| 						self::$wordEndDelim . '/iS', 'LinkTitles\Extension::smartModeCallback', | 						self::$wordEndDelim . '/iS', 'LinkTitles\Extension::smartModeCallback', | ||||||
| 						$arr[$i], $limit, $count ); | 						$arr[$i], $limit, $count ); | ||||||
| 					if (( $limit >= 0 ) && ( $count > 0  )) { | 					if ( $wgLinkTitlesFirstOnly && ( $count > 0  )) { | ||||||
| 						break;  | 						break;  | ||||||
| 					}; | 					}; | ||||||
| 				}; | 				}; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user