CommentParser: * Move comment formatting backend from Linker to a CommentParser service. Allow link existence and file existence to be batched. * Rename $local to $samePage since I think that is clearer. * Rename $title to $selfLinkTarget since it was unclear what the title was used for. * Rename the "autocomment" concept to "section link" in public interfaces, although the old term remains in CSS classes. * Keep unsafe HTML pass-through in separate "unsafe" methods, for easier static analysis and code review. CommentFormatter: * Add CommentFormatter and RowCommentFormatter services as a usable frontend for comment batches, and to replace the Linker static methods. * Provide fluent and parametric interfaces. Linker: * Remove Linker::makeCommentLink() without deprecation -- nothing calls it and it is obviously an internal helper. * Soft-deprecate Linker methods formatComment(), formatLinksInComment(), commentBlock() and revComment(). Caller migration: * CommentFormatter single: Linker, RollbackAction, ApiComparePages, ApiParse * CommentFormatter parametric batch: ImageHistoryPseudoPager * CommentFormatter fluent batch: ApiQueryFilearchive * RowCommentFormatter sequential: History feed, BlocklistPager, ProtectedPagesPager, ApiQueryProtectedTitles * RowCommentFormatter with index: ChangesFeed, ChangesList, ApiQueryDeletedrevs, ApiQueryLogEvents, ApiQueryRecentChanges * RevisionCommentBatch: HistoryPager, ContribsPager Bug: T285917 Change-Id: Ia3fd50a4a13138ba5003d884962da24746d562d0
194 lines
5.1 KiB
PHP
194 lines
5.1 KiB
PHP
<?php
|
|
|
|
namespace MediaWiki\CommentFormatter;
|
|
|
|
use MediaWiki\Linker\LinkTarget;
|
|
use Traversable;
|
|
|
|
/**
|
|
* This class provides a fluent interface for formatting a batch of comments.
|
|
*
|
|
* @since 1.38
|
|
*/
|
|
class CommentBatch {
|
|
/** @var CommentFormatter */
|
|
private $formatter;
|
|
/** @var iterable<CommentItem>|Traversable */
|
|
private $comments;
|
|
/** @var bool|null */
|
|
private $useBlock;
|
|
/** @var bool|null */
|
|
private $useParentheses;
|
|
/** @var LinkTarget|null */
|
|
private $selfLinkTarget;
|
|
/** @var bool|null */
|
|
private $samePage;
|
|
/** @var string|false|null */
|
|
private $wikiId;
|
|
/** @var bool|null */
|
|
private $enableSectionLinks;
|
|
|
|
/**
|
|
* @internal Use CommentFormatter::createBatch()
|
|
*
|
|
* @param CommentFormatter $formatter
|
|
*/
|
|
public function __construct( CommentFormatter $formatter ) {
|
|
$this->formatter = $formatter;
|
|
}
|
|
|
|
/**
|
|
* Set the comments to be formatted. This can be an array of CommentItem
|
|
* objects, or it can be an iterator which generates CommentItem objects.
|
|
*
|
|
* Theoretically iterable should imply Traversable, but PHPStorm gives an
|
|
* error when RowCommentIterator is passed as iterable<CommentItem>.
|
|
*
|
|
* @param iterable<CommentItem>|Traversable $comments
|
|
* @return $this
|
|
*/
|
|
public function comments( $comments ) {
|
|
$this->comments = $comments;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Specify the comments to be formatted as an array of strings. This is a
|
|
* simplified wrapper for comments() which does not allow you to set options
|
|
* on a per-comment basis.
|
|
*
|
|
* $strings must be an array -- use comments() if you want to use an iterator.
|
|
*
|
|
* @param string[] $strings
|
|
* @return $this
|
|
*/
|
|
public function strings( array $strings ) {
|
|
$this->comments = new StringCommentIterator( $strings );
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Wrap each comment in standard punctuation and formatting if it's
|
|
* non-empty. Empty comments remain empty. This causes the batch to work
|
|
* like the old Linker::commentBlock().
|
|
*
|
|
* If this function is not called, the option is false.
|
|
*
|
|
* @param bool $useBlock
|
|
* @return $this
|
|
*/
|
|
public function useBlock( $useBlock = true ) {
|
|
$this->useBlock = $useBlock;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Wrap each comment with parentheses. This has no effect if the useBlock
|
|
* option is not enabled.
|
|
*
|
|
* Unlike the legacy Linker::commentBlock(), this option defaults to false
|
|
* if this method is not called, since that better preserves the fluent
|
|
* style.
|
|
*
|
|
* @param bool $useParentheses
|
|
* @return $this
|
|
*/
|
|
public function useParentheses( $useParentheses = true ) {
|
|
$this->useParentheses = $useParentheses;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Set the title to be used for self links in the comments. If there is no
|
|
* title specified either here or in the item, fragment links are not
|
|
* expanded.
|
|
*
|
|
* @param LinkTarget $selfLinkTarget
|
|
* @return $this
|
|
*/
|
|
public function selfLinkTarget( LinkTarget $selfLinkTarget ) {
|
|
$this->selfLinkTarget = $selfLinkTarget;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Set the option to enable/disable section links formatted as C-style
|
|
* comments, as used in revision comments to indicate the section which
|
|
* was edited.
|
|
*
|
|
* If the method is not called, the option is true. Setting this to false
|
|
* approximately emulates Linker::formatLinksInComment() except that HTML
|
|
* in the input is escaped.
|
|
*
|
|
* @param bool $enable
|
|
* @return $this
|
|
*/
|
|
public function enableSectionLinks( $enable ) {
|
|
$this->enableSectionLinks = $enable;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Disable section links formatted as C-style comments, as used in revision
|
|
* comments to indicate the section which was edited. Calling this
|
|
* approximately emulates Linker::formatLinksInComment() except that HTML
|
|
* in the input is escaped.
|
|
*
|
|
* @return $this
|
|
*/
|
|
public function disableSectionLinks() {
|
|
$this->enableSectionLinks = false;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Set the same-page option. If this is true, section links and fragment-
|
|
* only wikilinks are rendered with an href that is a fragment-only URL.
|
|
* If it is false (the default), such links go to the self link title.
|
|
*
|
|
* This can also be set per-item using CommentItem::samePage().
|
|
*
|
|
* This is equivalent to $local in the old Linker methods.
|
|
*
|
|
* @param bool $samePage
|
|
* @return $this
|
|
*/
|
|
public function samePage( $samePage = true ) {
|
|
$this->samePage = $samePage;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* ID of the wiki to link to (if not the local wiki), as used by WikiMap.
|
|
* This is used to render comments which are loaded from a foreign wiki.
|
|
* This only affects links which are syntactically internal -- it has no
|
|
* effect on interwiki links.
|
|
*
|
|
* This can also be set per-item using CommentItem::wikiId().
|
|
*
|
|
* @param string|false|null $wikiId
|
|
* @return $this
|
|
*/
|
|
public function wikiId( $wikiId ) {
|
|
$this->wikiId = $wikiId;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Format the comments and produce an array of HTML fragments.
|
|
*
|
|
* @return string[]
|
|
*/
|
|
public function execute() {
|
|
return $this->formatter->formatItemsInternal(
|
|
$this->comments,
|
|
$this->selfLinkTarget,
|
|
$this->samePage,
|
|
$this->wikiId,
|
|
$this->enableSectionLinks,
|
|
$this->useBlock,
|
|
$this->useParentheses
|
|
);
|
|
}
|
|
|
|
}
|