File: FauxSearchResultSet.php

package info (click to toggle)
mediawiki 1%3A1.43.3%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 417,464 kB
  • sloc: php: 1,062,949; javascript: 664,290; sql: 9,714; python: 5,458; xml: 3,489; sh: 1,131; makefile: 64
file content (43 lines) | stat: -rw-r--r-- 1,120 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
<?php

use MediaWiki\Title\Title;

/**
 * A manually constructed search result set.
 * Mainly meant for supporting developer setups where the search operation might be
 * mocked or proxied.
 */
class FauxSearchResultSet extends SearchResultSet {

	/**
	 * @var int|null
	 * @see getTotalHits
	 */
	private $totalHits;

	/**
	 * @param array<Title|SearchResult> $results Search results
	 * @param int|null $totalHits See getTotalHits()
	 */
	public function __construct( array $results, $totalHits = null ) {
		$totalHits = max( count( $results ), $totalHits );
		$hasMoreResults = count( $results ) < $totalHits;
		parent::__construct( false, $hasMoreResults );
		$this->results = array_map( static function ( $result ) {
			if ( $result instanceof SearchResult ) {
				return $result;
			} elseif ( $result instanceof Title ) {
				return new FauxSearchResult( $result );
			} else {
				throw new InvalidArgumentException( '$results must contain Title or SearchResult' );
			}
		}, $results );
		$this->totalHits = $totalHits;
	}

	/** @inheritDoc */
	public function getTotalHits() {
		return $this->totalHits;
	}

}