-
Notifications
You must be signed in to change notification settings - Fork 15
Expand file tree
/
Copy pathDocBlock.php
More file actions
118 lines (98 loc) · 3.72 KB
/
DocBlock.php
File metadata and controls
118 lines (98 loc) · 3.72 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
<?php
declare(strict_types=1);
/**
* CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
* Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
*
* Licensed under The MIT License
* For full copyright and license information, please see the LICENSE.txt
* Redistributions of files must retain the above copyright notice
*
* @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
* @link https://cakephp.org CakePHP(tm) Project
* @since 2.0.0
* @license https://opensource.org/licenses/mit-license.php MIT License
*/
namespace Cake\ApiDocs\Reflection;
use Cake\ApiDocs\Util\DocUtil;
use PHPStan\PhpDocParser\Ast\PhpDoc\InvalidTagValueNode;
use PHPStan\PhpDocParser\Ast\PhpDoc\PhpDocTextNode;
class DocBlock
{
public string $summary = '';
public string $description = '';
public array $tags = [];
/**
* @param string|null $block Full docblock comment
*/
public function __construct(?string $block)
{
/** @var \PHPStan\PhpDocParser\Ast\PhpDoc\PhpDocNode $node */
$node = DocUtil::parseBlock($block);
foreach ($node->children as $childNode) {
if (!$childNode instanceof PhpDocTextNode) {
break;
}
if (!$this->summary) {
$this->summary = $childNode->text;
} else {
if ($this->description) {
$this->description .= "\n" . $childNode->text;
} else {
$this->description = $childNode->text;
}
}
}
$tags = $node->getTagsByName('@template');
array_walk($tags, fn($tag) => $this->tags['template'][] = $tag->value);
$tags = $node->getTagsByName('@var');
if ($tags) {
$this->tags['var'] = current($tags)->value;
}
$tags = $node->getTagsByName('@param');
foreach ($tags as $tag) {
if ($tag->value instanceof InvalidTagValueNode) {
continue;
}
$this->tags['param'][$tag->value->parameterName] = $tag->value;
}
$tags = $node->getTagsByName('@return');
if ($tags) {
$this->tags['return'] = current($tags)->value;
}
foreach (['@property', '@property-read', '@property-write'] as $tagName) {
$tags = $node->getTagsByName($tagName);
foreach ($tags as $tag) {
if ($tag->value instanceof InvalidTagValueNode) {
continue;
}
$this->tags[$tagName][$tag->value->propertyName] = $tag->value;
}
}
$tags = $node->getTagsByName('@method');
foreach ($tags as $tag) {
if ($tag->value instanceof InvalidTagValueNode) {
continue;
}
$this->tags['@method'][$tag->value->methodName] = $tag->value;
}
$tags = $node->getTagsByName('@throws');
array_walk($tags, fn($tag) => $this->tags['throws'][] = $tag->value);
$tags = $node->getTagsByName('@see');
array_walk($tags, fn($tag) => $this->tags['see'][] = $tag->value);
$tags = $node->getTagsByName('@link');
array_walk($tags, fn($tag) => $this->tags['link'][] = $tag->value);
$tags = $node->getTagsByName('@deprecated');
if ($tags) {
$this->tags['deprecated'] = current($tags)->value;
}
$tags = $node->getTagsByName('@experimental');
if ($tags) {
$this->tags['experimental'] = current($tags)->value;
}
$tags = $node->getTagsByName('@internal');
if ($tags) {
$this->tags['internal'] = current($tags)->value;
}
}
}