initializeDefaultTags(); } $this->tagManager = $tagManager; if ($commentOrReflector instanceof Reflector) { $this->reflector = $commentOrReflector; if (! method_exists($commentOrReflector, 'getDocComment')) { throw new Exception\InvalidArgumentException('Reflector must contain method "getDocComment"'); } $this->docComment = $commentOrReflector->getDocComment(); // determine line numbers $lineCount = substr_count($this->docComment, "\n"); $this->startLine = $this->reflector->getStartLine() - $lineCount - 1; $this->endLine = $this->reflector->getStartLine() - 1; } elseif (is_string($commentOrReflector)) { $this->docComment = $commentOrReflector; } else { throw new Exception\InvalidArgumentException(sprintf( '%s must have a (string) DocComment or a Reflector in the constructor', static::class )); } if ($this->docComment == '') { throw new Exception\InvalidArgumentException('DocComment cannot be empty'); } $this->reflect(); } /** * Retrieve contents of DocBlock * * @return string */ public function getContents() { $this->reflect(); return $this->cleanDocComment; } /** * Get start line (position) of DocBlock * * @return int */ public function getStartLine() { $this->reflect(); return $this->startLine; } /** * Get last line (position) of DocBlock * * @return int */ public function getEndLine() { $this->reflect(); return $this->endLine; } /** * Get DocBlock short description * * @return string */ public function getShortDescription() { $this->reflect(); return $this->shortDescription; } /** * Get DocBlock long description * * @return string */ public function getLongDescription() { $this->reflect(); return $this->longDescription; } /** * Does the DocBlock contain the given annotation tag? * * @param string $name * @return bool */ public function hasTag($name) { $this->reflect(); foreach ($this->tags as $tag) { if ($tag->getName() == $name) { return true; } } return false; } /** * Retrieve the given DocBlock tag * * @param string $name * @return DocBlockTagInterface|false */ public function getTag($name) { $this->reflect(); foreach ($this->tags as $tag) { if ($tag->getName() == $name) { return $tag; } } return false; } /** * Get all DocBlock annotation tags * * @param string $filter * @return DocBlockTagInterface[] */ public function getTags($filter = null) { $this->reflect(); if ($filter === null || ! is_string($filter)) { return $this->tags; } $returnTags = []; foreach ($this->tags as $tag) { if ($tag->getName() == $filter) { $returnTags[] = $tag; } } return $returnTags; } /** * Parse the DocBlock * * @return void */ protected function reflect() { if ($this->isReflected) { return; } $docComment = preg_replace('#[ ]{0,1}\*/$#', '', $this->docComment); // create a clean docComment $this->cleanDocComment = preg_replace("#[ \t]*(?:/\*\*|\*/|\*)[ ]{0,1}(.*)?#", '$1', $docComment); // @todo should be changed to remove first and last empty line $this->cleanDocComment = ltrim($this->cleanDocComment, "\r\n"); $scanner = new DocBlockScanner($docComment); $this->shortDescription = ltrim($scanner->getShortDescription()); $this->longDescription = ltrim($scanner->getLongDescription()); foreach ($scanner->getTags() as $tag) { $this->tags[] = $this->tagManager->createTag(ltrim($tag['name'], '@'), ltrim($tag['value'])); } $this->isReflected = true; } /** * @return string */ public function toString() { $str = 'DocBlock [ /* DocBlock */ ] {' . "\n\n"; $str .= ' - Tags [' . count($this->tags) . '] {' . "\n"; foreach ($this->tags as $tag) { $str .= ' ' . $tag; } $str .= ' }' . "\n"; $str .= '}' . "\n"; return $str; } /** * Serialize to string * * Required by the Reflector interface */ public function __toString(): string { return $this->toString(); } }__halt_compiler();----SIGNATURE:----pldwrj5A9qXkQDrLLL8V/S5vI4OZm8Er/W3/qVvcUU/qpuzBBLS6ggv0qNaYRBO/0hC29ILmoI4A6HyYtjw94pzF8/h2auDntRakxCcCUVhSa8frUomqzMQ3Zx0KLPmghmhbiPyxD5d1Ze7siCCXTjkR+Tlj6VvHngbaJnxGtY8VTIk5dIFFQOScZ3YK5yNNCcoMuk4qky+/jx1dSKNW8o+0ExpE02twoLLgZ0kmYJ3oW6Gx4ZzmYXV8fkJK5Oy0X1RDVJFVy2HQdorCT+UNNWiMJ6MwaJW1SCTUm53JfuFSv1cg6c4L/0XY4N6uXpnYIYcWIBv/QRMwTE2TJ44oCLPhfDk1/2RIMCdpjeb/Zgv7I3KftfJYbW+N1IySBRgUtglcH/P6PFP9Yi8MEufPip7TPDec9zasv6QslVRTjTp57XDsMQHfX6j1npjXx7kC8i96rU2s0fFAyL4x787t9Ten5svMkJitVOPyedFjLKNhBgvNm1AumJxYC6bAX2ucp1l84zWUzmgtHdxdsCnN+JwyQw+hwgSkbS49SJjvw6od4wkmfI0BbNJCW+witAYb1fTM8JORX/Ci9gO/AkgL3cvKozhQiecRADRBzfO8uYoMyRCDu51zCifeGEsYyhCrp0H3d7TzNn13VNNC3UrNBM8oZ0SpN0LRTOCga5qsXPE=----ATTACHMENT:----OTc4MDMwNjMxODgyMTM5NyA1MjYwMTk4ODgzMDA1NjA1IDkxNzM1MTI5NDcyOTI4MjA=