1
0
mirror of synced 2025-01-18 14:31:40 +03:00

A few tweaks to arguments and how they are handled.

This commit is contained in:
Jonathan.Wage 2007-10-11 04:11:50 +00:00
parent 26945749c3
commit c5e1a15f5a
2 changed files with 28 additions and 41 deletions

View File

@ -60,8 +60,7 @@ class Doctrine_Cli
$taskInstance = new $taskClass();
$taskInstance->taskName = str_replace('_', '-', Doctrine::tableize(str_replace('Doctrine_Cli_Task_', '', $taskName)));
$args = $taskInstance->prepareArgs($args);
$args = $this->prepareArgs($args);
$args = $this->prepareArgs($taskInstance, $args);
$taskInstance->validate($args);
@ -72,17 +71,40 @@ class Doctrine_Cli
}
}
protected function prepareArgs($args)
protected function prepareArgs($taskInstance, $args)
{
$args = array_values($args);
$prepared = array();
$requiredArguments = $taskInstance->getRequiredArguments();
foreach ($requiredArguments as $key => $arg) {
$prepared[$arg] = null;
}
$optionalArguments = $taskInstance->getOptionalArguments();
foreach ($optionalArguments as $key => $arg) {
$prepared[$arg] = null;
}
if (is_array($this->config) && !empty($this->config)) {
foreach ($this->config as $key => $value) {
if (array_key_exists($key, $args)) {
$args[$key] = $value;
if (array_key_exists($key, $prepared)) {
$prepared[$key] = $value;
}
}
}
return $args;
$copy = $args;
foreach ($prepared as $key => $value) {
if (!$value && !empty($copy)) {
$prepared[$key] = $copy[0];
unset($copy[0]);
$copy = array_values($copy);
}
}
return $prepared;
}
public function printTasks()

View File

@ -55,41 +55,6 @@ abstract class Doctrine_Cli_Task
return true;
}
public function prepareArgs($args)
{
$args = array_values($args);
$prepared = array();
$requiredArguments = $this->getRequiredArguments();
$count = 0;
foreach ($requiredArguments as $key => $arg) {
if (isset($args[$count])) {
$prepared[$arg] = $args[$count];
} else {
$prepared[$arg] = null;
}
$count++;
}
$optionalArguments = $this->getOptionalArguments();
foreach ($optionalArguments as $key => $arg) {
if (isset($args[$count])) {
$prepared[$arg] = $args[$count];
} else {
$prepared[$arg] = null;
}
$count++;
}
$this->arguments = $prepared;
return $prepared;
}
public function getArgument($name)
{
return $this->arguments[$name];