2010-09-17 14:48:06 +00:00
|
|
|
<?php
|
|
|
|
class Zend_View_Helper_DocParameter extends Zend_View_Helper_Abstract
|
|
|
|
{
|
|
|
|
protected $serviceTypes;
|
|
|
|
|
2010-12-06 14:41:23 +00:00
|
|
|
protected $types = array(
|
|
|
|
'string', 'str',
|
|
|
|
'boolean', 'bool',
|
|
|
|
'integer', 'int',
|
|
|
|
'float', 'double',
|
|
|
|
'array', 'object', 'mixed'
|
|
|
|
);
|
|
|
|
|
|
|
|
protected $_transcodeType = array(
|
|
|
|
'str' => 'string',
|
|
|
|
'bool' => 'boolean',
|
|
|
|
'int' => 'integer',
|
|
|
|
);
|
|
|
|
|
2010-09-17 14:48:06 +00:00
|
|
|
public function docParameter($params, $serviceTypes)
|
|
|
|
{
|
|
|
|
$this->serviceTypes = $serviceTypes;
|
|
|
|
$output = '';
|
|
|
|
if (count($params)>0) {
|
|
|
|
$output.= '<ul>';
|
|
|
|
foreach ($params as $param) {
|
|
|
|
$output.= $this->formatParam($param);
|
|
|
|
}
|
|
|
|
$output.= '</ul>';
|
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function parseType($type)
|
|
|
|
{
|
|
|
|
$output = '';
|
2010-09-20 08:04:31 +00:00
|
|
|
$type = str_replace('[]', '', $type);
|
2010-09-17 14:48:06 +00:00
|
|
|
if (array_key_exists($type, $this->serviceTypes)) {
|
|
|
|
$types = $this->serviceTypes[$type];
|
|
|
|
$output.= '<ul>';
|
|
|
|
foreach ($types as $param) {
|
|
|
|
$output.= $this->formatParam($param);
|
|
|
|
}
|
|
|
|
$output.= '</ul>';
|
2011-01-26 13:07:00 +00:00
|
|
|
} elseif (in_array($type, array(
|
|
|
|
'string', 'str',
|
|
|
|
'boolean', 'bool',
|
|
|
|
'integer', 'int',
|
|
|
|
'float', 'double',
|
|
|
|
'array', 'object', 'mixed'))) {
|
|
|
|
$output.= '';
|
|
|
|
} elseif ($type == 'void'){
|
|
|
|
$output.= 'Void';
|
2010-09-20 08:04:31 +00:00
|
|
|
} else {
|
2010-10-20 12:29:41 +00:00
|
|
|
$output.= ' => <b>Type '.$type.' Inconnu</b>';
|
2010-09-17 14:48:06 +00:00
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function formatParam($param)
|
|
|
|
{
|
|
|
|
$output = '';
|
|
|
|
$output.= '<li>';
|
2010-12-06 14:41:23 +00:00
|
|
|
$output.= '<i>' . $this->transcodeType($param['type']) . '</i>';
|
2010-09-20 15:08:45 +00:00
|
|
|
$output.= ' ';
|
|
|
|
$output.= $param['name'];
|
2010-09-17 14:48:06 +00:00
|
|
|
if (isset($param['description']) && !empty($param['description'])) {
|
|
|
|
$output.= ' : '.$param['description'];
|
|
|
|
}
|
2010-12-06 14:41:23 +00:00
|
|
|
if (!in_array($param['type'], $this->types)) {
|
2010-09-17 14:48:06 +00:00
|
|
|
$output.= $this->parseType($param['type']);
|
|
|
|
}
|
|
|
|
$output.= '</li>';
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
2010-12-06 14:41:23 +00:00
|
|
|
private function transcodeType($type)
|
|
|
|
{
|
|
|
|
if(array_key_exists($type, $this->_transcodeType)){
|
|
|
|
return $this->_transcodeType[$type];
|
|
|
|
} else {
|
|
|
|
return $type;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-09-17 14:48:06 +00:00
|
|
|
}
|