2013-04-22 14:09:50 +10:00
|
|
|
<?php defined('SYSPATH') or die('No direct script access.');
|
|
|
|
/**
|
|
|
|
* Class property documentation generator.
|
|
|
|
*
|
|
|
|
* @package Kohana/Userguide
|
|
|
|
* @category Base
|
|
|
|
* @author Kohana Team
|
2016-05-01 20:50:24 +10:00
|
|
|
* @copyright (c) 2008-2013 Kohana Team
|
|
|
|
* @license http://kohanaframework.org/license
|
2013-04-22 14:09:50 +10:00
|
|
|
*/
|
|
|
|
class Kohana_Kodoc_Property extends Kodoc {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var object ReflectionProperty
|
|
|
|
*/
|
|
|
|
public $property;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var string modifiers: public, private, static, etc
|
|
|
|
*/
|
|
|
|
public $modifiers = 'public';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var string variable type, retrieved from the comment
|
|
|
|
*/
|
|
|
|
public $type;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var string value of the property
|
|
|
|
*/
|
|
|
|
public $value;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var string default value of the property
|
|
|
|
*/
|
|
|
|
public $default;
|
|
|
|
|
|
|
|
public function __construct($class, $property, $default = NULL)
|
|
|
|
{
|
|
|
|
$property = new ReflectionProperty($class, $property);
|
|
|
|
|
|
|
|
list($description, $tags) = Kodoc::parse($property->getDocComment());
|
|
|
|
|
|
|
|
$this->description = $description;
|
|
|
|
|
|
|
|
if ($modifiers = $property->getModifiers())
|
|
|
|
{
|
|
|
|
$this->modifiers = '<small>'.implode(' ', Reflection::getModifierNames($modifiers)).'</small> ';
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($tags['var']))
|
|
|
|
{
|
|
|
|
if (preg_match('/^(\S*)(?:\s*(.+?))?$/s', $tags['var'][0], $matches))
|
|
|
|
{
|
|
|
|
$this->type = $matches[1];
|
|
|
|
|
|
|
|
if (isset($matches[2]))
|
|
|
|
{
|
|
|
|
$this->description = Kodoc_Markdown::markdown($matches[2]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->property = $property;
|
|
|
|
|
|
|
|
// Show the value of static properties, but only if they are public or we are php 5.3 or higher and can force them to be accessible
|
|
|
|
if ($property->isStatic() AND ($property->isPublic() OR version_compare(PHP_VERSION, '5.3', '>=')))
|
|
|
|
{
|
|
|
|
// Force the property to be accessible
|
|
|
|
if (version_compare(PHP_VERSION, '5.3', '>='))
|
|
|
|
{
|
|
|
|
$property->setAccessible(TRUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Don't debug the entire object, just say what kind of object it is
|
|
|
|
if (is_object($property->getValue($class)))
|
|
|
|
{
|
|
|
|
$this->value = '<pre>object '.get_class($property->getValue($class)).'()</pre>';
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$this->value = Debug::vars($property->getValue($class));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Store the defult property
|
|
|
|
$this->default = Debug::vars($default);;
|
|
|
|
}
|
|
|
|
|
|
|
|
} // End Kodoc_Property
|