2010-12-05 00:48:38 -05:00
< ? php
/**
* A shell class to help developers upgrade applications to CakePHP 2.0
*
* @ package cake . console / shells
*/
class UpgradeShell extends Shell {
protected $_files = array ();
protected $_paths = array ();
2010-12-11 18:13:21 +03:00
/**
* Update helpers .
*
* - Converts helpers usage to new format .
*
* @ return void
*/
function helpers () {
2010-12-11 18:13:59 +03:00
$this -> _paths = array (
VIEWS
);
2010-12-11 23:13:21 -05:00
if ( ! empty ( $this -> params [ 'plugin' ])) {
$this -> _paths = array ( App :: pluginPath ( $this -> params [ 'plugin' ]) . 'views' . DS );
}
2010-12-11 18:13:21 +03:00
$patterns = array ();
2010-12-11 23:19:07 -05:00
$helpers = App :: objects ( 'helper' );
$plugins = App :: objects ( 'plugin' );
$pluginHelpers = array ();
foreach ( $plugins as $plugin ) {
$pluginHelpers = array_merge (
$pluginHelpers ,
App :: objects ( 'helper' , App :: pluginPath ( $plugin ) . DS . 'views' . DS . 'helpers' . DS , false )
);
}
$helpers = array_merge ( $pluginHelpers , $helpers );
foreach ( $helpers as $helper ) {
2010-12-11 18:13:21 +03:00
$oldHelper = strtolower ( substr ( $helper , 0 , 1 )) . substr ( $helper , 1 );
$patterns [] = array (
" \$ { $oldHelper } to \$ this-> { $helper } " ,
" / \\ \$ { $oldHelper } ->/ " ,
" \\ \$ this-> { $helper } -> "
);
}
2010-12-11 18:13:59 +03:00
$this -> _filesRegexpUpdate ( $patterns );
2010-12-11 18:13:21 +03:00
}
2010-12-05 00:48:38 -05:00
/**
* Update i18n .
*
* - Removes extra true param .
2010-12-11 23:13:21 -05:00
* - Add the echo to __ * () calls that didn ' t need them before .
2010-12-05 00:48:38 -05:00
*
* @ return void
*/
function i18n () {
2010-12-11 18:13:59 +03:00
$this -> _paths = array (
2010-12-11 23:13:21 -05:00
APP
2010-12-11 18:13:59 +03:00
);
2010-12-11 23:13:21 -05:00
if ( ! empty ( $this -> params [ 'plugin' ])) {
$this -> _paths = array ( App :: pluginPath ( $this -> params [ 'plugin' ]));
}
2010-12-11 18:13:21 +03:00
$patterns = array (
array (
'<?php __*(*) to <?php echo __*(*)' ,
'/<\?php\s*(__[a-z]*\(.*?\))/' ,
'<?php echo \1'
),
array (
'<?php __*(*, true) to <?php echo __*()' ,
'/<\?php\s*(__[a-z]*\(.*?)(,\s*true)(\))/' ,
'<?php echo \1\3'
),
array ( '__*(*, true) to __*(*)' , '/(__[a-z]*\(.*?)(,\s*true)(\))/' , '\1\3' )
);
2010-12-11 18:13:59 +03:00
$this -> _filesRegexpUpdate ( $patterns );
}
2010-12-11 23:13:21 -05:00
/**
* Updates files based on regular expressions .
*
* @ param array $patterns Array of search and replacement patterns .
* @ return void
*/
2010-12-11 18:13:59 +03:00
protected function _filesRegexpUpdate ( $patterns ) {
2010-12-11 23:13:21 -05:00
$this -> _findFiles ( $this -> params [ 'ext' ]);
2010-12-05 00:48:38 -05:00
foreach ( $this -> _files as $file ) {
$this -> out ( 'Updating ' . $file . '...' , 1 , Shell :: VERBOSE );
2010-12-11 18:13:21 +03:00
$this -> _updateFile ( $file , $patterns );
2010-12-05 00:48:38 -05:00
}
}
2010-12-11 23:13:21 -05:00
/**
* Searches the paths and finds files based on extension .
*
* @ param string $extensions
* @ return void
*/
protected function _findFiles ( $extensions = '' ) {
2010-12-05 00:48:38 -05:00
foreach ( $this -> _paths as $path ) {
2010-12-11 23:13:21 -05:00
$files = array ();
$Iterator = new RegexIterator (
new RecursiveIteratorIterator ( new RecursiveDirectoryIterator ( $path )),
'/^.+\.(' . $extensions . ')$/i' ,
RegexIterator :: MATCH
);
foreach ( $Iterator as $file ) {
if ( $file -> isFile ()) {
$files [] = $file -> getPathname ();
2010-12-05 00:48:38 -05:00
}
}
$this -> _files = array_merge ( $this -> _files , $files );
}
}
/**
* Update a single file .
*
2010-12-11 23:13:21 -05:00
* @ param string $file The file to update
* @ param array $patterns The replacement patterns to run .
2010-12-05 00:48:38 -05:00
* @ return void
*/
2010-12-11 18:13:21 +03:00
protected function _updateFile ( $file , $patterns ) {
2010-12-05 00:48:38 -05:00
$contents = file_get_contents ( $file );
2010-12-11 18:13:21 +03:00
2010-12-05 00:48:38 -05:00
foreach ( $patterns as $pattern ) {
$this -> out ( ' * Updating ' . $pattern [ 0 ], 1 , Shell :: VERBOSE );
$contents = preg_replace ( $pattern [ 1 ], $pattern [ 2 ], $contents );
}
$this -> out ( 'Done updating ' . $file , 1 );
file_put_contents ( $file , $contents );
}
/**
* get the option parser
*
2010-12-11 23:13:21 -05:00
* @ return ConsoleOptionParser
2010-12-05 00:48:38 -05:00
*/
function getOptionParser () {
2010-12-11 18:14:54 +03:00
$subcommandParser = array (
'options' => array (
2010-12-11 23:13:21 -05:00
'plugin' => array (
'short' => 'p' ,
'help' => __ ( 'The plugin to update. Only the specified plugin will be updated.'
)),
'ext' => array (
'short' => 'e' ,
'help' => __ ( 'The extension(s) to search. A pipe delimited list, or a preg_match compatible subpattern' ),
'default' => 'php|ctp|thtml|inc|tpl'
),
2010-12-11 18:14:54 +03:00
)
);
2010-12-05 00:48:38 -05:00
return parent :: getOptionParser ()
2010-12-11 11:00:09 -05:00
-> description ( " A shell to help automate upgrading from CakePHP 1.3 to 2.0. \n Be sure to have a backup of your application before running these commands. " )
2010-12-05 00:48:38 -05:00
-> addSubcommand ( 'i18n' , array (
'help' => 'Update the i18n translation method calls.' ,
2010-12-11 18:14:54 +03:00
'parser' => $subcommandParser
2010-12-11 18:13:21 +03:00
))
-> addSubcommand ( 'helpers' , array (
'help' => 'Update calls to helpers.' ,
2010-12-11 18:14:54 +03:00
'parser' => $subcommandParser
2010-12-05 00:48:38 -05:00
));
}
}