1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-05 20:48:45 +01:00
psalm/src/Psalm/Internal/Scanner/ParsedDocblock.php

92 lines
2.4 KiB
PHP
Raw Normal View History

2020-05-29 04:14:41 +02:00
<?php
namespace Psalm\Internal\Scanner;
use function trim;
use function explode;
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
}
public function render(string $left_padding) : string
{
$doc_comment_text = '/**' . "\n";
$trimmed_description = trim($this->description);
if (!empty($trimmed_description)) {
$description_lines = explode("\n", $this->description);
foreach ($description_lines as $line) {
$doc_comment_text .= $left_padding . ' *' . (trim($line) ? ' ' . $line : '') . "\n";
2020-05-29 04:14:41 +02:00
}
}
if ($this->tags) {
if (!empty($trimmed_description)) {
$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) {
$doc_comment_text .= $left_padding . ' * @' . $type . ' ' . $line . "\n";
}
$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.
*
* @param bool $should
*/
public static function addNewLineBetweenAnnotations(bool $should = true): void
{
static::$shouldAddNewLineBetweenAnnotations = $should;
}
}