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.
		
		
		
		
		
			
		
			
				
					
					
						
							78 lines
						
					
					
						
							1.8 KiB
						
					
					
				
			
		
		
	
	
							78 lines
						
					
					
						
							1.8 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\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; | |
| 				} | |
| 			} | |
| 		} | |
| 	} | |
| } |