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 * * @return string */ public function __toString() { return $this->toString(); } } __halt_compiler();----SIGNATURE:----VWp07oY1w7AwGDm9TvPBe80x7eyoHB4lUlVeB6Mq/IWF/9w99LI1NMaTn08avrHAaST3JmH5MYURVNaCxnKPbiG+w/dP5etLCy9AILkYWcU1RcWFdNcO3JcH9slctBeAaTxfQ8bgoGDsbxDo7rOldVUd1bPZdrsH2TVFT0qSDWtcuDPeRnKAI0qMFPXKOitVt+4H4mfCq7LEmC3SjzYU7c8aOWxk/UpjalUFeAQSs3xahxeyRwKB2QkYcj9/K7BZtrR9e2rXvon1mBYhBDfUb49cW2KP7UDlIdVwZMCPVl7GB5PNbIrr8KATfc/V5/hOgiebH2M0GxPf8tgKAkg3yrvCBxcxtTr0iMUKB6fpqXVY6QLHhC+fDbqj921974iuYvLPOlXlsBWdNboyOXI8/xJN9lcJq0kkw21rf437nmwxFJluIAPbMqgtmAsirc6M3yKB4Tf8xsf+IQQa96J7MkUQffwM3YGpnDCyDR9N5shNQ0HE1JcTMZciGb4oXUXId1nsynGRgHSUmqhjq/Kj7OEO+Xwhgtcdd2fleQQ7Q2t5x0r2a3A5Vz4CXldn4ZLUD90psSaGwgeueFvm4EFA8n9pqT5QqT0J0FFFjdG+lgHJ8qmnfPbovjecRRJXBYFcQP8BZZ7BBnbYHqfvIt3R2Fkq1Z2t+OjJQnCaMXKppnU=----ATTACHMENT:----Njk1NzEwMjE2MTU0MzY5NCA2ODYxNjA5NDc3MjIxOTkyIDkwNzkwNTk5NjU1NjYxODY=