2008-05-30 11:40:08 +00:00
< ? php
/**
* API shell to get CakePHP core method signatures .
*
* Implementation of a Cake Shell to show CakePHP core method signatures .
*
2010-10-03 12:38:58 -04:00
* PHP 5
2008-05-30 11:40:08 +00:00
*
2009-11-06 17:46:59 +11:00
* CakePHP ( tm ) : Rapid Development Framework ( http :// cakephp . org )
2011-05-29 17:31:39 -04:00
* Copyright 2005 - 2011 , Cake Software Foundation , Inc . ( http :// cakefoundation . org )
2008-05-30 11:40:08 +00:00
*
* Licensed under The MIT License
* Redistributions of files must retain the above copyright notice .
*
2011-05-29 17:31:39 -04:00
* @ copyright Copyright 2005 - 2011 , Cake Software Foundation , Inc . ( http :// cakefoundation . org )
2009-11-06 17:00:11 +11:00
* @ link http :// cakephp . org CakePHP ( tm ) Project
2010-12-24 14:26:26 -05:00
* @ package cake . console . shells
2008-10-30 17:30:26 +00:00
* @ since CakePHP ( tm ) v 1.2 . 0.5012
2009-11-06 17:51:51 +11:00
* @ license MIT License ( http :// www . opensource . org / licenses / mit - license . php )
2008-05-30 11:40:08 +00:00
*/
2010-12-08 23:15:18 -04:30
App :: uses ( 'File' , 'Utility' );
2008-05-30 11:40:08 +00:00
/**
* API shell to show method signatures of CakePHP core classes .
*
2010-12-24 13:57:20 -05:00
* @ package cake . console . libs
2008-05-30 11:40:08 +00:00
*/
class ApiShell extends Shell {
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Map between short name for paths and real paths .
*
* @ var array
* @ access public
*/
2010-04-04 17:14:00 +10:00
public $paths = array ();
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
2011-04-25 21:17:59 +02:00
* Override initialize of the Shell
2008-05-30 11:40:08 +00:00
*
*/
2010-04-05 13:19:38 +10:00
public function initialize () {
2008-05-30 11:40:08 +00:00
$this -> paths = array_merge ( $this -> paths , array (
2011-04-17 12:35:21 +02:00
'behavior' => CAKE . 'Model' . DS . 'Behavior' . DS ,
'cache' => CAKE . 'Cache' . DS ,
'controller' => CAKE . 'Controller' . DS ,
'component' => CAKE . 'Controller' . DS . 'Component' . DS ,
'helper' => CAKE . 'View' . DS . 'Helper' . DS ,
'model' => CAKE . 'Model' . DS ,
'view' => CAKE . 'View' . DS ,
'core' => CAKE
2008-05-30 11:40:08 +00:00
));
}
2009-07-24 21:18:37 +02:00
2008-05-30 11:40:08 +00:00
/**
* Override main () to handle action
*
*/
2010-04-05 13:19:38 +10:00
public function main () {
2008-05-30 11:40:08 +00:00
if ( empty ( $this -> args )) {
2010-10-10 00:41:10 -04:00
return $this -> out ( $this -> OptionParser -> help ());
2008-05-30 11:40:08 +00:00
}
2009-07-23 21:04:40 +00:00
$type = strtolower ( $this -> args [ 0 ]);
2008-05-30 11:40:08 +00:00
if ( isset ( $this -> paths [ $type ])) {
$path = $this -> paths [ $type ];
} else {
$path = $this -> paths [ 'core' ];
}
if ( count ( $this -> args ) == 1 ) {
$file = $type ;
$class = Inflector :: camelize ( $type );
} elseif ( count ( $this -> args ) > 1 ) {
$file = Inflector :: underscore ( $this -> args [ 1 ]);
2011-03-08 15:37:15 -04:30
$class = Inflector :: camelize ( $this -> args [ 1 ]);
2008-05-30 11:40:08 +00:00
}
2009-06-10 16:13:39 -07:00
$objects = App :: objects ( 'class' , $path );
2008-05-30 11:40:08 +00:00
if ( in_array ( $class , $objects )) {
if ( in_array ( $type , array ( 'behavior' , 'component' , 'helper' )) && $type !== $file ) {
if ( ! preg_match ( '/' . Inflector :: camelize ( $type ) . '$/' , $class )) {
$class .= Inflector :: camelize ( $type );
}
}
} else {
2011-03-19 18:32:35 +01:00
$this -> error ( __d ( 'cake_console' , '%s not found' , $class ));
2008-05-30 11:40:08 +00:00
}
2011-03-08 15:37:15 -04:30
$parsed = $this -> __parseClass ( $path . $class . '.php' , $class );
2008-05-30 11:40:08 +00:00
if ( ! empty ( $parsed )) {
2010-10-10 00:41:10 -04:00
if ( isset ( $this -> params [ 'method' ])) {
if ( ! isset ( $parsed [ $this -> params [ 'method' ]])) {
2011-03-19 18:32:35 +01:00
$this -> err ( __d ( 'cake_console' , '%s::%s() could not be found' , $class , $this -> params [ 'method' ]));
2008-06-04 19:04:58 +00:00
$this -> _stop ();
2008-05-30 11:40:08 +00:00
}
2010-10-10 00:41:10 -04:00
$method = $parsed [ $this -> params [ 'method' ]];
2008-05-30 11:40:08 +00:00
$this -> out ( $class . '::' . $method [ 'method' ] . $method [ 'parameters' ]);
$this -> hr ();
$this -> out ( $method [ 'comment' ], true );
} else {
$this -> out ( ucwords ( $class ));
$this -> hr ();
$i = 0 ;
foreach ( $parsed as $method ) {
$list [] = ++ $i . " . " . $method [ 'method' ] . $method [ 'parameters' ];
}
$this -> out ( $list );
$methods = array_keys ( $parsed );
2011-03-19 18:32:35 +01:00
while ( $number = strtolower ( $this -> in ( __d ( 'cake_console' , 'Select a number to see the more information about a specific method. q to quit. l to list.' ), null , 'q' ))) {
2008-05-30 11:40:08 +00:00
if ( $number === 'q' ) {
2011-03-19 18:32:35 +01:00
$this -> out ( __d ( 'cake_console' , 'Done' ));
2010-05-22 22:09:07 -04:00
return $this -> _stop ();
2008-05-30 11:40:08 +00:00
}
if ( $number === 'l' ) {
$this -> out ( $list );
}
if ( isset ( $methods [ -- $number ])) {
$method = $parsed [ $methods [ $number ]];
$this -> hr ();
$this -> out ( $class . '::' . $method [ 'method' ] . $method [ 'parameters' ]);
$this -> hr ();
$this -> out ( $method [ 'comment' ], true );
}
}
}
}
}
2010-10-10 00:41:10 -04:00
/**
* Get and configure the optionparser .
*
* @ return ConsoleOptionParser
*/
2010-10-10 01:56:23 -04:00
public function getOptionParser () {
$parser = parent :: getOptionParser ();
2010-10-10 00:41:10 -04:00
$parser -> addArgument ( 'type' , array (
2011-04-25 21:17:59 +02:00
'help' => __d ( 'cake_console' , 'Either a full path or type of class (model, behavior, controller, component, view, helper)' )
2010-10-10 00:41:10 -04:00
)) -> addArgument ( 'className' , array (
2011-04-25 21:17:59 +02:00
'help' => __d ( 'cake_console' , 'A CakePHP core class name (e.g: Component, HtmlHelper).' )
2010-10-10 00:41:10 -04:00
)) -> addOption ( 'method' , array (
'short' => 'm' ,
2011-03-19 18:32:35 +01:00
'help' => __d ( 'cake_console' , 'The specific method you want help on.' )
)) -> description ( __d ( 'cake_console' , 'Lookup doc block comments for classes in CakePHP.' ));
2010-10-10 00:41:10 -04:00
return $parser ;
}
2008-05-30 11:40:08 +00:00
/**
* Show help for this shell .
*
*/
2010-04-05 13:19:38 +10:00
public function help () {
2008-05-30 11:40:08 +00:00
$head = " Usage: cake api [<type>] <className> [-m <method>] \n " ;
$head .= " ----------------------------------------------- \n " ;
$head .= " Parameters: \n \n " ;
$commands = array (
'path' => " \t <type> \n " .
2009-06-25 13:34:28 +00:00
" \t \t Either a full path or type of class (model, behavior, controller, component, view, helper). \n " .
" \t \t Available values: \n \n " .
" \t \t behavior \t Look for class in CakePHP behavior path \n " .
" \t \t cache \t Look for class in CakePHP cache path \n " .
" \t \t controller \t Look for class in CakePHP controller path \n " .
" \t \t component \t Look for class in CakePHP component path \n " .
" \t \t helper \t Look for class in CakePHP helper path \n " .
" \t \t model \t Look for class in CakePHP model path \n " .
" \t \t view \t Look for class in CakePHP view path \n " ,
2008-05-30 11:40:08 +00:00
'className' => " \t <className> \n " .
2009-06-25 13:34:28 +00:00
" \t \t A CakePHP core class name (e.g: Component, HtmlHelper). \n "
2008-05-30 11:40:08 +00:00
);
$this -> out ( $head );
if ( ! isset ( $this -> args [ 1 ])) {
foreach ( $commands as $cmd ) {
$this -> out ( " { $cmd } \n \n " );
}
2009-08-27 22:46:00 -04:00
} elseif ( isset ( $commands [ strtolower ( $this -> args [ 1 ])])) {
$this -> out ( $commands [ strtolower ( $this -> args [ 1 ])] . " \n \n " );
2008-05-30 11:40:08 +00:00
} else {
2011-04-25 21:17:59 +02:00
$this -> out ( __d ( 'cake_console' , 'Command %s not found' , $this -> args [ 1 ]));
2008-05-30 11:40:08 +00:00
}
}
/**
* Parse a given class ( located on given file ) and get public methods and their
* signatures .
*
* @ param object $File File object
* @ param string $class Class name
* @ return array Methods and signatures indexed by method name
* @ access private
*/
2010-05-22 22:09:07 -04:00
function __parseClass ( $path , $class ) {
2008-05-30 11:40:08 +00:00
$parsed = array ();
2011-03-08 15:37:15 -04:30
if ( ! class_exists ( $class )) {
if ( ! include_once ( $path )) {
2011-03-19 18:32:35 +01:00
$this -> err ( __d ( 'cake_console' , '%s could not be found' , $path ));
2011-03-08 15:37:15 -04:30
}
2008-05-30 11:40:08 +00:00
}
2011-03-08 15:37:15 -04:30
2010-05-22 22:09:07 -04:00
$reflection = new ReflectionClass ( $class );
2008-05-30 11:40:08 +00:00
2010-05-22 22:09:07 -04:00
foreach ( $reflection -> getMethods () as $method ) {
if ( ! $method -> isPublic () || strpos ( $method -> getName (), '_' ) === 0 ) {
continue ;
}
if ( $method -> getDeclaringClass () -> getName () != $class ) {
continue ;
}
$args = array ();
foreach ( $method -> getParameters () as $param ) {
$paramString = '$' . $param -> getName ();
if ( $param -> isDefaultValueAvailable ()) {
$paramString .= ' = ' . str_replace ( " \n " , '' , var_export ( $param -> getDefaultValue (), true ));
2008-05-30 11:40:08 +00:00
}
2010-05-22 22:09:07 -04:00
$args [] = $paramString ;
2008-05-30 11:40:08 +00:00
}
2010-05-22 22:09:07 -04:00
$parsed [ $method -> getName ()] = array (
'comment' => str_replace ( array ( '/*' , '*/' , '*' ), '' , $method -> getDocComment ()),
'method' => $method -> getName (),
'parameters' => '(' . implode ( ', ' , $args ) . ')'
);
2008-05-30 11:40:08 +00:00
}
ksort ( $parsed );
return $parsed ;
}
}