<?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\VarTag; use yii\apidoc\helpers\PrettyPrinter; /** * Represents API documentation information for a `property`. * * @author Carsten Brandt <mail@cebe.cc> * @since 2.0 */ class PropertyDoc extends BaseDoc { public $visibility; public $isStatic; public $type; public $types; public $defaultValue; // will be set by creating class public $getter; public $setter; // will be set by creating class public $definedBy; public function getIsReadOnly() { return $this->getter !== null && $this->setter === null; } public function getIsWriteOnly() { return $this->getter === null && $this->setter !== null; } /** * @param \phpDocumentor\Reflection\ClassReflector\PropertyReflector $reflector * @param array $config */ public function __construct($reflector = null, $config = []) { parent::__construct($reflector, $config); if ($reflector === null) { return; } $this->visibility = $reflector->getVisibility(); $this->isStatic = $reflector->isStatic(); // bypass $reflector->getDefault() for short array syntax if ($reflector->getNode()->default) { $this->defaultValue = PrettyPrinter::getRepresentationOfValue($reflector->getNode()->default); } foreach($this->tags as $i => $tag) { if ($tag instanceof VarTag) { $this->type = $tag->getType(); $this->types = $tag->getTypes(); $this->description = ucfirst($tag->getDescription()); if (($pos = strpos($this->description, '.')) !== false) { $this->shortDescription = substr($this->description, 0, $pos); } else { $this->shortDescription = $this->description; } } } } }