2020-05-29 04:14:41 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Psalm\Internal\Scanner;
|
|
|
|
|
|
|
|
use function explode;
|
2021-06-08 04:55:21 +02:00
|
|
|
use function trim;
|
2020-05-29 04:14:41 +02:00
|
|
|
|
|
|
|
class ParsedDocblock
|
|
|
|
{
|
|
|
|
/** @var string */
|
|
|
|
public $description;
|
|
|
|
|
2020-08-14 22:26:55 +02:00
|
|
|
/** @var string */
|
|
|
|
public $first_line_padding;
|
|
|
|
|
2020-05-29 04:14:41 +02:00
|
|
|
/** @var array<string, array<int, string>> */
|
|
|
|
public $tags = [];
|
|
|
|
|
|
|
|
/** @var array<string, array<int, string>> */
|
|
|
|
public $combined_tags = [];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
private static $shouldAddNewLineBetweenAnnotations = true;
|
|
|
|
|
|
|
|
/** @param array<string, array<int, string>> $tags */
|
2020-08-14 22:26:55 +02:00
|
|
|
public function __construct(string $description, array $tags, string $first_line_padding = '')
|
2020-05-29 04:14:41 +02:00
|
|
|
{
|
|
|
|
$this->description = $description;
|
|
|
|
$this->tags = $tags;
|
2020-08-14 22:26:55 +02:00
|
|
|
$this->first_line_padding = $first_line_padding;
|
2020-05-29 04:14:41 +02:00
|
|
|
}
|
|
|
|
|
2021-12-05 18:51:26 +01:00
|
|
|
public function render(string $left_padding): string
|
2020-05-29 04:14:41 +02:00
|
|
|
{
|
|
|
|
$doc_comment_text = '/**' . "\n";
|
|
|
|
|
|
|
|
$trimmed_description = trim($this->description);
|
|
|
|
|
2020-09-20 00:26:51 +02:00
|
|
|
if ($trimmed_description !== '') {
|
2020-05-29 04:14:41 +02:00
|
|
|
$description_lines = explode("\n", $this->description);
|
|
|
|
|
|
|
|
foreach ($description_lines as $line) {
|
2020-07-02 23:55:57 +02:00
|
|
|
$doc_comment_text .= $left_padding . ' *' . (trim($line) ? ' ' . $line : '') . "\n";
|
2020-05-29 04:14:41 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->tags) {
|
2020-09-20 00:26:51 +02:00
|
|
|
if ($trimmed_description !== '') {
|
2020-07-02 23:55:57 +02:00
|
|
|
$doc_comment_text .= $left_padding . ' *' . "\n";
|
|
|
|
}
|
|
|
|
|
2020-05-29 04:14:41 +02:00
|
|
|
$last_type = null;
|
|
|
|
|
|
|
|
foreach ($this->tags as $type => $lines) {
|
|
|
|
if ($last_type !== null
|
|
|
|
&& $last_type !== 'psalm-return'
|
|
|
|
&& static::shouldAddNewLineBetweenAnnotations()
|
|
|
|
) {
|
|
|
|
$doc_comment_text .= $left_padding . ' *' . "\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach ($lines as $line) {
|
2020-08-23 16:28:26 +02:00
|
|
|
$doc_comment_text .= $left_padding . ' * @' . $type . ($line !== '' ? ' ' . $line : '') . "\n";
|
2020-05-29 04:14:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$last_type = $type;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$doc_comment_text .= $left_padding . ' */' . "\n" . $left_padding;
|
|
|
|
|
|
|
|
return $doc_comment_text;
|
|
|
|
}
|
|
|
|
|
|
|
|
private static function shouldAddNewLineBetweenAnnotations(): bool
|
|
|
|
{
|
|
|
|
return static::$shouldAddNewLineBetweenAnnotations;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets whether a new line should be added between the annotations or not.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function addNewLineBetweenAnnotations(bool $should = true): void
|
|
|
|
{
|
|
|
|
static::$shouldAddNewLineBetweenAnnotations = $should;
|
|
|
|
}
|
2020-08-23 16:32:07 +02:00
|
|
|
|
|
|
|
public static function resetNewlineBetweenAnnotations(): void
|
|
|
|
{
|
|
|
|
static::$shouldAddNewLineBetweenAnnotations = true;
|
|
|
|
}
|
2020-05-29 04:14:41 +02:00
|
|
|
}
|