DDC-1179 - Make it possible to specify a namespace when mapping with --from-database
This commit is contained in:
parent
cec62db2d8
commit
7ee8dc4e44
@ -66,6 +66,13 @@ class DatabaseDriver implements Driver
|
|||||||
*/
|
*/
|
||||||
private $fieldNamesForColumns = array();
|
private $fieldNamesForColumns = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The namespace for the generated entities.
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
private $namespace;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initializes a new AnnotationDriver that uses the given AnnotationReader for reading
|
* Initializes a new AnnotationDriver that uses the given AnnotationReader for reading
|
||||||
* docblock annotations.
|
* docblock annotations.
|
||||||
@ -348,10 +355,10 @@ class DatabaseDriver implements Driver
|
|||||||
private function getClassNameForTable($tableName)
|
private function getClassNameForTable($tableName)
|
||||||
{
|
{
|
||||||
if (isset($this->classNamesForTables[$tableName])) {
|
if (isset($this->classNamesForTables[$tableName])) {
|
||||||
return $this->classNamesForTables[$tableName];
|
return $this->namespace . $this->classNamesForTables[$tableName];
|
||||||
}
|
}
|
||||||
|
|
||||||
return Inflector::classify(strtolower($tableName));
|
return $this->namespace . Inflector::classify(strtolower($tableName));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -376,4 +383,15 @@ class DatabaseDriver implements Driver
|
|||||||
}
|
}
|
||||||
return Inflector::camelize($columnName);
|
return Inflector::camelize($columnName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the namespace for the generated entities.
|
||||||
|
*
|
||||||
|
* @param string $namespace
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function setNamespace($namespace)
|
||||||
|
{
|
||||||
|
$this->namespace = $namespace;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -78,6 +78,10 @@ class ConvertMappingCommand extends Console\Command\Command
|
|||||||
'num-spaces', null, InputOption::VALUE_OPTIONAL,
|
'num-spaces', null, InputOption::VALUE_OPTIONAL,
|
||||||
'Defines the number of indentation spaces', 4
|
'Defines the number of indentation spaces', 4
|
||||||
),
|
),
|
||||||
|
new InputOption(
|
||||||
|
'namespace', null, InputOption::VALUE_OPTIONAL,
|
||||||
|
'Defines a namespace for the generated entity classes, if converted from database.'
|
||||||
|
),
|
||||||
))
|
))
|
||||||
->setHelp(<<<EOT
|
->setHelp(<<<EOT
|
||||||
Convert mapping information between supported formats.
|
Convert mapping information between supported formats.
|
||||||
@ -107,11 +111,17 @@ EOT
|
|||||||
$em = $this->getHelper('em')->getEntityManager();
|
$em = $this->getHelper('em')->getEntityManager();
|
||||||
|
|
||||||
if ($input->getOption('from-database') === true) {
|
if ($input->getOption('from-database') === true) {
|
||||||
$em->getConfiguration()->setMetadataDriverImpl(
|
$databaseDriver = new \Doctrine\ORM\Mapping\Driver\DatabaseDriver(
|
||||||
new \Doctrine\ORM\Mapping\Driver\DatabaseDriver(
|
$em->getConnection()->getSchemaManager()
|
||||||
$em->getConnection()->getSchemaManager()
|
|
||||||
)
|
|
||||||
);
|
);
|
||||||
|
|
||||||
|
$em->getConfiguration()->setMetadataDriverImpl(
|
||||||
|
$databaseDriver
|
||||||
|
);
|
||||||
|
|
||||||
|
if (($namespace = $input->getOption('namespace')) !== null) {
|
||||||
|
$databaseDriver->setNamespace($namespace);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$cmf = new DisconnectedClassMetadataFactory();
|
$cmf = new DisconnectedClassMetadataFactory();
|
||||||
|
Loading…
Reference in New Issue
Block a user