Fixing console scripts.

Correcting errors when using bake shell to create views.
Corrected errors when interactively creating controllers and views
Corrected issue in ProjectTask::cakeAdmin() with admin route not writing the admin define in core.php
Moved ControllerTask::getAdmin() to Shell::getAdmin()
Removed define setting CAKE_ADMIN to null which would cause issues with admin methods and views
Corrected missing ?>

git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@5322 3807eeeb-6ff5-0310-8944-8be069107fe0
This commit is contained in:
phpnut 2007-06-21 14:38:46 +00:00
parent 9d56c4616e
commit 172f9817cb
8 changed files with 92 additions and 103 deletions

View file

@ -473,5 +473,4 @@ class AclShell extends Shell {
return $vars;
}
}
?>

View file

@ -231,5 +231,4 @@ class ApiShell extends Shell {
}
}
}
?>

View file

@ -34,9 +34,6 @@
* @package cake
* @subpackage cake.cake.console.libs
*/
if (!defined('CAKE_ADMIN')) {
define('CAKE_ADMIN', null);
}
class BakeShell extends Shell {
var $tasks = array('Project', 'DbConfig', 'Model', 'Controller', 'View');

View file

@ -239,6 +239,4 @@ class ConsoleShell extends Shell {
}
}
}
?>

View file

@ -447,7 +447,32 @@ class Shell extends Object {
$shortPath = str_replace('..'.DS, '', $shortPath);
return str_replace(DS.DS, DS, $shortPath);
}
/**
* Checks for CAKE_ADMIN and Forces user to input it if not enabled
*
* @return the controller name
*/
function getAdmin() {
$admin = null;
if (defined('CAKE_ADMIN')) {
$admin = CAKE_ADMIN.'_';
} else {
$this->out('You need to enable CAKE_ADMIN in /app/config/core.php to use admin routing.');
$this->out('What would you like the admin route to be?');
$this->out('Example: www.example.com/admin/controller');
while ($admin == '') {
$admin = $this->in("What would you like the admin route to be?", null, 'admin');
}
if ($this->Project->cakeAdmin($admin) !== true) {
$this->out('Unable to write to /app/config/core.php.');
$this->out('You need to enable CAKE_ADMIN in /app/config/core.php to use admin routing.');
exit();
} else {
$admin = $admin . '_';
}
}
return $admin;
}
/**
* creates the proper pluralize controller for the url
*

View file

@ -84,6 +84,7 @@ class ControllerTask extends Shell {
* @return void
*/
function __interactive() {
$this->interactive = false;
$this->hr();
$this->out('Controller Bake:');
$this->hr();
@ -148,6 +149,7 @@ class ControllerTask extends Shell {
$wannaDoAdmin = $this->in("Would you like to create the methods for admin routing?", array('y','n'), 'y');
}
}
$admin = false;
if ((low($wannaDoAdmin) == 'y' || low($wannaDoAdmin) == 'yes')) {
$admin = $this->getAdmin();
@ -222,7 +224,6 @@ class ControllerTask extends Shell {
if ($baked && $this->_checkUnitTest()) {
$this->__bakeTest($controllerName);
}
exit();
}
}
@ -529,32 +530,6 @@ class ControllerTask extends Shell {
return $controllerName;
}
/**
* Checks for CAKE_ADMIN and Forces user to input it if not enabled
*
* @return the controller name
*/
function getAdmin() {
$admin = null;
if (defined('CAKE_ADMIN')) {
$admin = CAKE_ADMIN.'_';
} else {
$this->out('You need to enable CAKE_ADMIN in /app/config/core.php to use admin routing.');
$this->out('What would you like the admin route to be?');
$this->out('Example: www.example.com/admin/controller');
while ($admin == '') {
$admin = $this->in("What would you like the admin route to be?", null, 'admin');
}
if ($this->Project->cakeAdmin($admin) !== true) {
$this->out('Unable to write to /app/config/core.php.');
$this->out('You need to enable CAKE_ADMIN in /app/config/core.php to use admin routing.');
exit();
} else {
$admin = $admin . '_';
}
}
return $admin;
}
/**
* Displays help contents
*
@ -573,3 +548,4 @@ class ControllerTask extends Shell {
exit();
}
}
?>

View file

@ -243,11 +243,12 @@ class ProjectTask extends Shell {
* @return bool
*/
function cakeAdmin($name) {
$File =& new File($path . 'webroot' . DS . 'index.php');
$File =& new File(CONFIGS . 'core.php');
$contents = $File->read();
if (preg_match('%([/\\t\\x20]*define\\(\'CAKE_ADMIN\',[\\t\\x20\'a-z]*\\);)%', $contents, $match)) {
$result = str_replace($match[0], 'define(\'CAKE_ADMIN\', \''.$name.'\');', $contents);
if ($File->write($result)) {
define('CAKE_ADMIN', $name);
return true;
} else {
return false;

View file

@ -79,11 +79,10 @@ class ViewTask extends Shell {
$this->__interactive();
}
$controller = $action = $alias = null;
if (isset($this->args[0])) {
$controller = $action = $alias = null;
$this->controllerName = Inflector::camelize($this->args[0]);
$this->controllerPath = Inflector::underscore($this->controllerName);
}
if (isset($this->args[1])) {
$this->template = $this->args[1];
@ -115,8 +114,13 @@ class ViewTask extends Shell {
} else {
$methods = get_class_methods($this->controllerName . 'Controller');
}
$adminDelete = null;
if (defined('CAKE_ADMIN')) {
$adminDelete = CAKE_ADMIN.'_delete';
}
foreach ($methods as $method) {
if ($method{0} != '_' && !in_array(low($method), am($protected, array('delete', CAKE_ADMIN.'_delete')))) {
if ($method{0} != '_' && !in_array(low($method), am($protected, array('delete', $adminDelete)))) {
$content = $this->getContent($method, $vars);
$this->bake($method, $content);
}
@ -124,6 +128,7 @@ class ViewTask extends Shell {
}
}
}
}
/**
* Handles interactive baking
*
@ -136,6 +141,7 @@ class ViewTask extends Shell {
$this->hr();
$wannaDoAdmin = 'n';
$wannaDoScaffold = 'y';
$this->interactive = false;
$this->controllerName = $this->Controller->getName();
@ -144,33 +150,19 @@ class ViewTask extends Shell {
$interactive = $this->in("Would you like bake to build your views interactively?\nWarning: Choosing no will overwrite {$this->controllerName} views if it exist.", array('y','n'), 'y');
if (low($interactive) == 'y' || low($interactive) == 'yes') {
$this->interactive = true;
$wannaDoScaffold = $this->in("Would you like to create some scaffolded views (index, add, view, edit) for this controller?\nNOTE: Before doing so, you'll need to create your controller and model classes (including associated models).", array('y','n'), 'n');
}
if (low($wannaDoScaffold) == 'y' || low($wannaDoScaffold) == 'yes') {
$wannaDoAdmin = $this->in("Would you like to create the views for admin routing?", array('y','n'), 'y');
}
$admin = false;
$admin = '';
if ((low($wannaDoAdmin) == 'y' || low($wannaDoAdmin) == 'yes')) {
if (defined('CAKE_ADMIN')) {
$admin = CAKE_ADMIN . '_';
} else {
$this->out('You need to enable CAKE_ADMIN in /app/config/core.php to use admin routing.');
$this->out('What would you like the admin route to be?');
$this->out('Example: www.example.com/admin/controller');
while ($admin == '') {
$admin = $this->in("What would you like the admin route to be?", null, 'admin');
}
if ($this->Project->cakeAdmin($admin) !== true) {
$this->err('Unable to write to /app/config/core.php.');
$this->err('You need to enable CAKE_ADMIN in /app/config/core.php to use admin routing.');
exit();
} else {
$admin = $admin . '_';
}
}
$admin = $this->getAdmin();
}
if (low($wannaDoScaffold) == 'y' || low($wannaDoScaffold) == 'yes') {
$file = CONTROLLERS . $this->controllerPath . '_controller.php';
@ -180,6 +172,7 @@ class ViewTask extends Shell {
}
}
$vars = $this->__loadController();
if ($vars) {
foreach ($this->scaffoldActions as $action) {
$content = $this->getContent($action, $vars);
@ -230,7 +223,7 @@ class ViewTask extends Shell {
$this->err('could not find the controller');
}
if (!loadController($this->controllerName)) {
if (!class_exists($this->controllerName . 'Controller') && !loadController($this->controllerName)) {
$file = CONTROLLERS . $this->controllerPath . '_controller.php';
$shortPath = $this->shortPath($file);
$this->err("The file '{$shortPath}' could not be found.\nIn order to bake a view, you'll need to first create the controller.");
@ -297,7 +290,7 @@ class ViewTask extends Shell {
}
$action = $template;
if (strpos($template, CAKE_ADMIN) !== false) {
if (defined('CAKE_ADMIN') && strpos($template, CAKE_ADMIN) !== false) {
$template = str_replace(CAKE_ADMIN.'_', '', $template);
}
@ -346,3 +339,4 @@ class ViewTask extends Shell {
exit();
}
}
?>