25require __DIR__ .
'/../Maintenance.php';
52 parent::__construct();
54 $this->
addArg(
'title',
'The name of the page to parse' );
55 $this->
addOption(
'warmup',
'Repeat the parse operation this number of times to warm the cache',
57 $this->
addOption(
'loops',
'Number of times to repeat parse operation post-warmup',
60 'Use the version of the page which was current at the given time',
63 'Use templates which were current at the given time (except that moves and ' .
64 'deletes are not handled properly)',
66 $this->
addOption(
'reset-linkcache',
'Reset the LinkCache after every parse.',
73 Hooks::register(
'BeforeParserFetchTemplateAndtitle', [ $this,
'onFetchTemplate' ] );
76 $this->clearLinkCache = $this->
hasOption(
'reset-linkcache' );
78 $this->linkCache = MediaWikiServices::getInstance()->getLinkCache();
82 $this->
error(
"Invalid title" );
86 $revLookup = MediaWikiServices::getInstance()->getRevisionLookup();
91 $this->
error(
"The page did not exist at that time" );
95 $revision = $revLookup->getRevisionById( $id );
97 $revision = $revLookup->getRevisionByTitle(
$title );
101 $this->
error(
"Unable to load revision, incorrect title?" );
105 $warmup = $this->
getOption(
'warmup', 1 );
106 for ( $i = 0; $i < $warmup; $i++ ) {
112 $this->
fatalError(
'Invalid number of loops specified' );
114 $startUsage = getrusage();
115 $startTime = microtime(
true );
116 for ( $i = 0; $i < $loops; $i++ ) {
119 $endUsage = getrusage();
120 $endTime = microtime(
true );
122 printf(
"CPU time = %.3f s, wall clock time = %.3f s\n",
124 ( $endUsage[
'ru_utime.tv_sec'] + $endUsage[
'ru_utime.tv_usec'] * 1e-6
125 - $startUsage[
'ru_utime.tv_sec'] - $startUsage[
'ru_utime.tv_usec'] * 1e-6 ) / $loops,
127 ( $endTime - $startTime ) / $loops
141 $id =
$dbr->selectField(
142 [
'revision',
'page' ],
145 'page_namespace' =>
$title->getNamespace(),
146 'page_title' =>
$title->getDBkey(),
147 'rev_timestamp <= ' .
$dbr->addQuotes( $timestamp )
150 [
'ORDER BY' =>
'rev_timestamp DESC',
'LIMIT' => 1 ],
151 [
'revision' => [
'JOIN',
'rev_page=page_id' ] ]
167 if ( $this->clearLinkCache ) {
168 $this->linkCache->clear();
183 $pdbk =
$title->getPrefixedDBkey();
184 if ( !isset( $this->idCache[$pdbk] ) ) {
185 $proposedId = $this->
getRevIdForTime( $title, $this->templateTimestamp );
186 $this->idCache[$pdbk] = $proposedId;
188 if ( $this->idCache[$pdbk] !==
false ) {
189 $id = $this->idCache[$pdbk];
wfTimestamp( $outputtype=TS_UNIX, $ts=0)
Get a timestamp string in one of various formats.
const RUN_MAINTENANCE_IF_MAIN
Maintenance script to benchmark how long it takes to parse a given title at an optionally specified t...
getRevIdForTime(Title $title, $timestamp)
Fetch the ID of the revision of a Title that occurred.
onFetchTemplate(Parser $parser, Title $title, &$skip, &$id)
Hook into the parser's revision ID fetcher.
__construct()
Default constructor.
runParser(RevisionRecord $revision)
Parse the text from a given Revision.
execute()
Do the actual work.
array $idCache
Cache that maps a Title DB key to revision ID for the requested timestamp.
string $templateTimestamp
MediaWiki concatenated string timestamp (YYYYMMDDHHMMSS)
Cache for article titles (prefixed DB keys) and ids linked from one source.
Abstract maintenance class for quickly writing and churning out maintenance scripts with minimal effo...
error( $err, $die=0)
Throw an error to the user.
addArg( $arg, $description, $required=true)
Add some args that are needed.
hasOption( $name)
Checks to see if a particular option was set.
getArg( $argId=0, $default=null)
Get an argument.
addDescription( $text)
Set the description text.
addOption( $name, $description, $required=false, $withArg=false, $shortName=false, $multiOccurrence=false)
Add a parameter to the script.
getOption( $name, $default=null)
Get an option, or return the default.
fatalError( $msg, $exitCode=1)
Output a message and terminate the current script.
PHP Parser - Processes wiki markup (which uses a more user-friendly syntax, such as "[[link]]" for ma...
Represents a title within MediaWiki.