[DDC-481] Fixed.
This commit is contained in:
parent
dc3844e167
commit
59d4e0c8e7
@ -279,7 +279,7 @@ class ClassMetadataFactory
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ($parent && $parent->isInheritanceTypeSingleTable()) {
|
if ($parent && $parent->isInheritanceTypeSingleTable()) {
|
||||||
$class->setTableName($parent->getTableName());
|
$class->setPrimaryTable($parent->table);
|
||||||
}
|
}
|
||||||
|
|
||||||
$class->setParentClasses($visited);
|
$class->setParentClasses($visited);
|
||||||
|
@ -903,8 +903,8 @@ class ClassMetadataInfo
|
|||||||
/**
|
/**
|
||||||
* Sets the name of the primary table the class is mapped to.
|
* Sets the name of the primary table the class is mapped to.
|
||||||
*
|
*
|
||||||
* @param string $tableName The table name.
|
* @param string $tableName The table name.
|
||||||
* @deprecated
|
* @deprecated Use {@link setPrimaryTable}.
|
||||||
*/
|
*/
|
||||||
public function setTableName($tableName)
|
public function setTableName($tableName)
|
||||||
{
|
{
|
||||||
@ -912,18 +912,22 @@ class ClassMetadataInfo
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the primary table definition. The provided array must have the
|
* Sets the primary table definition. The provided array supports the
|
||||||
* following structure:
|
* following structure:
|
||||||
*
|
*
|
||||||
* name => <tableName>
|
* name => <tableName> (optional, defaults to class name)
|
||||||
* schema => <schemaName>
|
* indexes => array of indexes (optional)
|
||||||
* catalog => <catalogName>
|
* uniqueConstraints => array of constraints (optional)
|
||||||
*
|
*
|
||||||
* @param array $primaryTableDefinition
|
* @param array $table
|
||||||
*/
|
*/
|
||||||
public function setPrimaryTable(array $primaryTableDefinition)
|
public function setPrimaryTable(array $table)
|
||||||
{
|
{
|
||||||
$this->table = $primaryTableDefinition;
|
if (isset($table['name']) && $table['name'][0] == '`') {
|
||||||
|
$table['name'] = trim($table['name'], '`');
|
||||||
|
$table['quoted'] = true;
|
||||||
|
}
|
||||||
|
$this->table = $table;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
/*
|
/*
|
||||||
* $Id$
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
@ -31,14 +29,11 @@ require __DIR__ . '/DoctrineAnnotations.php';
|
|||||||
/**
|
/**
|
||||||
* The AnnotationDriver reads the mapping metadata from docblock annotations.
|
* The AnnotationDriver reads the mapping metadata from docblock annotations.
|
||||||
*
|
*
|
||||||
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL
|
* @since 2.0
|
||||||
* @link www.doctrine-project.org
|
* @author Benjamin Eberlei <kontakt@beberlei.de>
|
||||||
* @since 2.0
|
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
|
||||||
* @version $Revision$
|
* @author Jonathan H. Wage <jonwage@gmail.com>
|
||||||
* @author Benjamin Eberlei <kontakt@beberlei.de>
|
* @author Roman Borschel <roman@code-factory.org>
|
||||||
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
|
|
||||||
* @author Jonathan H. Wage <jonwage@gmail.com>
|
|
||||||
* @author Roman Borschel <roman@code-factory.org>
|
|
||||||
*/
|
*/
|
||||||
class AnnotationDriver implements Driver
|
class AnnotationDriver implements Driver
|
||||||
{
|
{
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
/*
|
/*
|
||||||
* $Id$
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
@ -62,13 +62,16 @@ class XmlDriver extends AbstractFileDriver
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Evaluate <entity...> attributes
|
// Evaluate <entity...> attributes
|
||||||
|
$table = array();
|
||||||
if (isset($xmlRoot['table'])) {
|
if (isset($xmlRoot['table'])) {
|
||||||
$metadata->table['name'] = (string)$xmlRoot['table'];
|
$table['name'] = (string)$xmlRoot['table'];
|
||||||
}
|
}
|
||||||
|
$metadata->setPrimaryTable($table);
|
||||||
|
|
||||||
|
/* not implemented specially anyway. use table = schema.table
|
||||||
if (isset($xmlRoot['schema'])) {
|
if (isset($xmlRoot['schema'])) {
|
||||||
$metadata->table['schema'] = (string)$xmlRoot['schema'];
|
$metadata->table['schema'] = (string)$xmlRoot['schema'];
|
||||||
}
|
}*/
|
||||||
|
|
||||||
if (isset($xmlRoot['inheritance-type'])) {
|
if (isset($xmlRoot['inheritance-type'])) {
|
||||||
$inheritanceType = (string)$xmlRoot['inheritance-type'];
|
$inheritanceType = (string)$xmlRoot['inheritance-type'];
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
/*
|
/*
|
||||||
* $Id$
|
|
||||||
*
|
|
||||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
@ -27,14 +25,11 @@ use Doctrine\ORM\Mapping\ClassMetadataInfo,
|
|||||||
/**
|
/**
|
||||||
* The YamlDriver reads the mapping metadata from yaml schema files.
|
* The YamlDriver reads the mapping metadata from yaml schema files.
|
||||||
*
|
*
|
||||||
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL
|
* @since 2.0
|
||||||
* @link www.doctrine-project.org
|
* @author Benjamin Eberlei <kontakt@beberlei.de>
|
||||||
* @since 2.0
|
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
|
||||||
* @version $Revision$
|
* @author Jonathan H. Wage <jonwage@gmail.com>
|
||||||
* @author Benjamin Eberlei <kontakt@beberlei.de>
|
* @author Roman Borschel <roman@code-factory.org>
|
||||||
* @author Guilherme Blanco <guilhermeblanco@hotmail.com>
|
|
||||||
* @author Jonathan H. Wage <jonwage@gmail.com>
|
|
||||||
* @author Roman Borschel <roman@code-factory.org>
|
|
||||||
*/
|
*/
|
||||||
class YamlDriver extends AbstractFileDriver
|
class YamlDriver extends AbstractFileDriver
|
||||||
{
|
{
|
||||||
@ -61,13 +56,16 @@ class YamlDriver extends AbstractFileDriver
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Evaluate root level properties
|
// Evaluate root level properties
|
||||||
|
$table = array();
|
||||||
if (isset($element['table'])) {
|
if (isset($element['table'])) {
|
||||||
$metadata->table['name'] = $element['table'];
|
$table['name'] = $element['table'];
|
||||||
}
|
}
|
||||||
|
$metadata->setPrimaryTable($table);
|
||||||
|
|
||||||
|
/* not implemented specially anyway. use table = schema.table
|
||||||
if (isset($element['schema'])) {
|
if (isset($element['schema'])) {
|
||||||
$metadata->table['schema'] = $element['schema'];
|
$metadata->table['schema'] = $element['schema'];
|
||||||
}
|
}*/
|
||||||
|
|
||||||
if (isset($element['inheritanceType'])) {
|
if (isset($element['inheritanceType'])) {
|
||||||
$metadata->setInheritanceType(constant('Doctrine\ORM\Mapping\ClassMetadata::INHERITANCE_TYPE_' . strtoupper($element['inheritanceType'])));
|
$metadata->setInheritanceType(constant('Doctrine\ORM\Mapping\ClassMetadata::INHERITANCE_TYPE_' . strtoupper($element['inheritanceType'])));
|
||||||
|
@ -26,6 +26,7 @@ class ClassMetadataFactoryTest extends \Doctrine\Tests\OrmTestCase
|
|||||||
|
|
||||||
// Self-made metadata
|
// Self-made metadata
|
||||||
$cm1 = new ClassMetadata('Doctrine\Tests\ORM\Mapping\TestEntity1');
|
$cm1 = new ClassMetadata('Doctrine\Tests\ORM\Mapping\TestEntity1');
|
||||||
|
$cm1->setPrimaryTable(array('name' => '`group`'));
|
||||||
// Add a mapped field
|
// Add a mapped field
|
||||||
$cm1->mapField(array('fieldName' => 'name', 'type' => 'varchar'));
|
$cm1->mapField(array('fieldName' => 'name', 'type' => 'varchar'));
|
||||||
// Add a mapped field
|
// Add a mapped field
|
||||||
@ -54,6 +55,8 @@ class ClassMetadataFactoryTest extends \Doctrine\Tests\OrmTestCase
|
|||||||
// Go
|
// Go
|
||||||
$cm1 = $cmf->getMetadataFor('Doctrine\Tests\ORM\Mapping\TestEntity1');
|
$cm1 = $cmf->getMetadataFor('Doctrine\Tests\ORM\Mapping\TestEntity1');
|
||||||
|
|
||||||
|
$this->assertEquals('group', $cm1->table['name']);
|
||||||
|
$this->assertTrue($cm1->table['quoted']);
|
||||||
$this->assertEquals(array(), $cm1->parentClasses);
|
$this->assertEquals(array(), $cm1->parentClasses);
|
||||||
$this->assertTrue($cm1->hasField('name'));
|
$this->assertTrue($cm1->hasField('name'));
|
||||||
$this->assertEquals(ClassMetadata::GENERATOR_TYPE_SEQUENCE, $cm1->generatorType);
|
$this->assertEquals(ClassMetadata::GENERATOR_TYPE_SEQUENCE, $cm1->generatorType);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user