| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 | <?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;/** * Represents API documentation information for a `function`. * * @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 Context $context     * @param array $config     */    public function __construct($reflector = null, $context = null, $config = [])    {        parent::__construct($reflector, $context, $config);        if ($reflector === null) {            return;        }        $this->isReturnByReference = $reflector->isByRef();        foreach ($reflector->getArguments() as $arg) {            $arg = new ParamDoc($arg, $context, ['sourceFile' => $this->sourceFile]);            $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) {                // ignore property tag            } elseif ($tag instanceof ParamTag) {                $paramName = $tag->getVariableName();                if (!isset($this->params[$paramName]) && $context !== null) {                    $context->errors[] = [                        'line' => $this->startLine,                        'file' => $this->sourceFile,                        'message' => "Undefined parameter documented: $paramName in {$this->name}().",                    ];                    continue;                }                $this->params[$paramName]->description = static::mbUcFirst($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 = static::mbUcFirst($tag->getDescription());                unset($this->tags[$i]);            }        }    }}
 |