mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Linter
synced 2024-12-18 19:01:11 +00:00
e6a510fbed
This avoids a duplicate parse with DiscussionTools (T376325) and also reduces some redundancy by using the metrics-gathering code from ParserOutput instead of having to clone it here. Finally, it allows the parse to use the output of a previous parse for selective update. Bug: T376325 Follows-Up: I64a4556a74da4f735a5b562070c21310ecda36d1 Change-Id: I11386e307caaa9fce34870b08bd4dce4c5e6eb25
92 lines
2.9 KiB
PHP
92 lines
2.9 KiB
PHP
<?php
|
|
/**
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
* http://www.gnu.org/copyleft/gpl.html
|
|
*
|
|
* @file
|
|
*/
|
|
|
|
namespace MediaWiki\Linter;
|
|
|
|
use MediaWiki\Content\TextContent;
|
|
use MediaWiki\Deferred\DataUpdate;
|
|
use MediaWiki\Logger\LoggerFactory;
|
|
use MediaWiki\Page\ParserOutputAccess;
|
|
use MediaWiki\Page\WikiPageFactory;
|
|
use MediaWiki\Revision\RenderedRevision;
|
|
use MediaWiki\Revision\RevisionRecord;
|
|
use MediaWiki\Revision\SlotRecord;
|
|
|
|
class LintUpdate extends DataUpdate {
|
|
|
|
private WikiPageFactory $wikiPageFactory;
|
|
private ParserOutputAccess $parserOutputAccess;
|
|
private RenderedRevision $renderedRevision;
|
|
|
|
public function __construct(
|
|
WikiPageFactory $wikiPageFactory,
|
|
ParserOutputAccess $parserOutputAccess,
|
|
RenderedRevision $renderedRevision
|
|
) {
|
|
parent::__construct();
|
|
$this->wikiPageFactory = $wikiPageFactory;
|
|
$this->parserOutputAccess = $parserOutputAccess;
|
|
$this->renderedRevision = $renderedRevision;
|
|
}
|
|
|
|
public function doUpdate() {
|
|
$rev = $this->renderedRevision->getRevision();
|
|
$mainSlot = $rev->getSlot( SlotRecord::MAIN, RevisionRecord::RAW );
|
|
|
|
$page = $this->wikiPageFactory->newFromTitle( $rev->getPage() );
|
|
|
|
if ( $page->getLatest() !== $rev->getId() ) {
|
|
// The given revision is no longer the latest revision.
|
|
return;
|
|
}
|
|
|
|
$content = $mainSlot->getContent();
|
|
if ( !$content instanceof TextContent ) {
|
|
// Linting is only defined for text
|
|
return;
|
|
}
|
|
|
|
$pOptions = $page->makeParserOptions( 'canonical' );
|
|
$pOptions->setUseParsoid();
|
|
$pOptions->setRenderReason( 'LintUpdate' );
|
|
|
|
LoggerFactory::getInstance( 'Linter' )->debug(
|
|
'{method}: Parsing {page}',
|
|
[
|
|
'method' => __METHOD__,
|
|
'page' => $page->getTitle()->getPrefixedDBkey(),
|
|
'touched' => $page->getTouched()
|
|
]
|
|
);
|
|
|
|
// Don't update the parser cache, to avoid flooding it.
|
|
// This matches the behavior of RefreshLinksJob.
|
|
// However, unlike RefreshLinksJob, we don't parse if we already
|
|
// have the output in the cache. This avoids duplicating the effort
|
|
// of ParsoidCachePrewarmJob / DiscussionTools
|
|
// (note that even with OPT_NO_UPDATE_CACHE we still update the
|
|
// *local* cache, which prevents wasting effort on duplicate parses)
|
|
$this->parserOutputAccess->getParserOutput(
|
|
$page, $pOptions, $rev,
|
|
ParserOutputAccess::OPT_NO_UPDATE_CACHE
|
|
);
|
|
}
|
|
}
|