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:----JhAZj8aagCGQJRfi2985oqd3eM7gjD9PJyhTGRTpu/lA1gWo6cyAmrm5K6CcJ2BcekTkoII9mZcQ58iXVTs03CIOd3pTFfLfZagdtCpsvXRukVmXIq9vn9F54HT9V47D2tQrQmkdr3iSFy4UcKTRSfB3I+1tyUJB0qTzWWbwtmgMBZo2Yy+EsrQOSC0xR9JOiEVejYhv8pXWXcIgJ1VeTODvJ6jh96XI9YUaY/7T7gtCpz7AcmBr1ntu3FZu14z3L3N3S86azuKlMOsaNlQLGIKu7/Q0IclTjrHrV6+ABwd3vNiRHUuUhtKen0kF7AC7DbnRqmT8b4uVGv4DHpokBSyeAJahawjPu5LlUr66cuhJMF0i23UNDDgP6fY9YF79yWNWS3lxiNG9CMpd25NbyEGDyGaIDrGYYpYlNvYU7UDXUklPwVr9TQzbLB+yT5w9QXTqqUmj4ExDqGfLt55JtDzCSJmD1upnyBTLUf9wC3CYX/p3bvIX7mOEL81vrtuCAYAAc9ouCxTDRU9h8TrYW/K0LdjG5KzY1Z3RP4weqrc5F//j9U3gEo0oeFLDM1Hg37cixlTHkFNGZUzAxtDcsAB8zCbxnTT2ZCbVirWCBuvgsosayPGvKl3aBaEC6N/8/QCwJSJuXFVcYUQd0h9DFAjit0HvtbODGROxxZsBQqo=----ATTACHMENT:----NzU5NzA4NTQzOTc1NDE0NiAyMzI2OTMzMjAwMjkzMzc5IDgzNTk4NTU4NzY1NTM2MTY=