You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							75 lines
						
					
					
						
							2.0 KiB
						
					
					
				
			
		
		
	
	
							75 lines
						
					
					
						
							2.0 KiB
						
					
					
				| <?php | |
| /** | |
|  * @link http://www.yiiframework.com/ | |
|  * @copyright Copyright (c) 2008 Yii Software LLC | |
|  * @license http://www.yiiframework.com/license/ | |
|  */ | |
|  | |
| namespace yii\apidoc\models; | |
|  | |
| use phpDocumentor\Reflection\DocBlock\Tag\ParamTag; | |
| use phpDocumentor\Reflection\DocBlock\Tag\PropertyTag; | |
| use phpDocumentor\Reflection\DocBlock\Tag\ReturnTag; | |
| use phpDocumentor\Reflection\DocBlock\Tag\ThrowsTag; | |
| use yii\base\Exception; | |
|  | |
| /** | |
|  * | |
|  * @author Carsten Brandt <mail@cebe.cc> | |
|  * @since 2.0 | |
|  */ | |
| class FunctionDoc extends BaseDoc | |
| { | |
| 	/** | |
| 	 * @var ParamDoc[] | |
| 	 */ | |
| 	public $params = []; | |
| 	public $exceptions = []; | |
| 	public $return; | |
| 	public $returnType; | |
| 	public $returnTypes; | |
| 	public $isReturnByReference; | |
|  | |
| 	/** | |
| 	 * @param \phpDocumentor\Reflection\FunctionReflector $reflector | |
| 	 * @param array $config | |
| 	 */ | |
| 	public function __construct($reflector = null, $config = []) | |
| 	{ | |
| 		parent::__construct($reflector, $config); | |
|  | |
| 		if ($reflector === null) { | |
| 			return; | |
| 		} | |
|  | |
| 		$this->isReturnByReference = $reflector->isByRef(); | |
|  | |
| 		foreach($reflector->getArguments() as $arg) { | |
| 			$arg = new ParamDoc($arg); | |
| 			$this->params[$arg->name] = $arg; | |
| 		} | |
|  | |
| 		foreach($this->tags as $i => $tag) { | |
| 			if ($tag instanceof ThrowsTag) { | |
| 				$this->exceptions[$tag->getType()] = $tag->getDescription(); | |
| 				unset($this->tags[$i]); | |
| 			} elseif ($tag instanceof PropertyTag) { | |
| 				 // TODO handle property tag | |
| 			} elseif ($tag instanceof ParamTag) { | |
| 				$paramName = $tag->getVariableName(); | |
| 				if (!isset($this->params[$paramName])) { | |
| 					echo 'undefined parameter documented: ' . $paramName . ' in ' . $this->name . "\n"; // todo add this to a log file | |
| 				} | |
| 				$this->params[$paramName]->description = $tag->getDescription(); | |
| 				$this->params[$paramName]->type = $tag->getType(); | |
| 				$this->params[$paramName]->types = $tag->getTypes(); | |
| 				unset($this->tags[$i]); | |
| 			} elseif ($tag instanceof ReturnTag) { | |
| 				$this->returnType = $tag->getType(); | |
| 				$this->returnTypes = $tag->getTypes(); | |
| 				$this->return = $tag->getDescription(); | |
| 				unset($this->tags[$i]); | |
| 			} | |
| 		} | |
| 	} | |
| }
 | |
| 
 |