fix belongsTo select for bake 1.2

git-svn-id: https://svn.cakephp.org/repo/branches/1.2.x.x@3639 3807eeeb-6ff5-0310-8944-8be069107fe0
This commit is contained in:
gwoo 2006-10-13 08:52:26 +00:00
parent 46b1451a8e
commit 89549ec129

View file

@ -85,8 +85,9 @@
$shortPath = str_replace('../', '', $shortPath); $shortPath = str_replace('../', '', $shortPath);
$shortPath = str_replace('//', '/', $shortPath); $shortPath = str_replace('//', '/', $shortPath);
$appDir = basename($shortPath); $pathArray = explode('/', $shortPath);
$rootDir = str_replace($appDir, '', $shortPath); $appDir = array_pop($pathArray);
$rootDir = implode('/', $pathArray);
$rootDir = str_replace('//', '', $rootDir); $rootDir = str_replace('//', '', $rootDir);
if(!$rootDir) { if(!$rootDir) {
@ -706,6 +707,7 @@ class Bake {
loadModels(); loadModels();
$controllerObj->constructClasses(); $controllerObj->constructClasses();
$currentModelName = $controllerObj->modelClass; $currentModelName = $controllerObj->modelClass;
$this->__modelClass = $currentModelName;
$modelKey = Inflector::underscore($currentModelName); $modelKey = Inflector::underscore($currentModelName);
$modelObj =& ClassRegistry::getObject($modelKey); $modelObj =& ClassRegistry::getObject($modelKey);
@ -1711,6 +1713,7 @@ class Bake {
function generateFields( $fields, $readOnly = false ) { function generateFields( $fields, $readOnly = false ) {
$strFormFields = ''; $strFormFields = '';
foreach( $fields as $field) { foreach( $fields as $field) {
if(isset( $field['type'])) { if(isset( $field['type'])) {
if(!isset($field['required'])) { if(!isset($field['required'])) {
$field['required'] = false; $field['required'] = false;
@ -1761,13 +1764,12 @@ class Bake {
} }
$this->__modelAlias = null; $this->__modelAlias = null;
if(isset($field['foreignKey'])) { if(isset($field['foreignKey'])) {
$modelKey = Inflector::underscore($field['model']); $modelKey = Inflector::underscore($this->__modelClass);
$modelObj =& ClassRegistry::getObject($modelKey); $modelObj =& ClassRegistry::getObject($modelKey);
foreach($modelObj->belongsTo as $associationName=>$value) { foreach($modelObj->belongsTo as $associationName =>$value) {
if($field['foreignKey'] == $value['foreignKey']) { if($field['model'] == $value['className']) {
$this->__modelAlias = $this->__modelName($associationName); $this->__modelAlias = $this->__modelName($associationName);
} else { break;
$this->__modelAlias = $this->__modelNameFromKey($field['foreignKey']);
} }
} }
} }
@ -1790,6 +1792,7 @@ class Bake {
$strFormFields = $strFormFields.$strFieldSet; $strFormFields = $strFormFields.$strFieldSet;
break; break;
case "hidden"; case "hidden";
$currentModelName = $field['model'];
//$strFormFields = $strFormFields . $this->Html->hiddenTag( $field['tagName']); //$strFormFields = $strFormFields . $this->Html->hiddenTag( $field['tagName']);
break; break;
case "date": case "date":