2012-07-01 09:52:20 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is part of the Doctrine Bundle
|
|
|
|
*
|
|
|
|
* The code was originally distributed inside the Symfony framework.
|
|
|
|
*
|
|
|
|
* (c) Fabien Potencier <fabien@symfony.com>
|
|
|
|
* (c) Doctrine Project, Benjamin Eberlei <kontakt@beberlei.de>
|
|
|
|
*
|
|
|
|
* For the full copyright and license information, please view the LICENSE
|
|
|
|
* file that was distributed with this source code.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Doctrine\Bundle\DoctrineBundle\Command;
|
|
|
|
|
|
|
|
use Symfony\Bundle\FrameworkBundle\Command\ContainerAwareCommand;
|
|
|
|
use Doctrine\ORM\Tools\EntityGenerator;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Base class for Doctrine console commands to extend from.
|
|
|
|
*
|
|
|
|
* @author Fabien Potencier <fabien@symfony.com>
|
|
|
|
*/
|
|
|
|
abstract class DoctrineCommand extends ContainerAwareCommand
|
|
|
|
{
|
2012-07-15 14:56:31 +02:00
|
|
|
/**
|
|
|
|
* get a doctrine entity generator
|
|
|
|
*
|
|
|
|
* @return EntityGenerator
|
|
|
|
*/
|
2012-07-01 09:52:20 +02:00
|
|
|
protected function getEntityGenerator()
|
|
|
|
{
|
|
|
|
$entityGenerator = new EntityGenerator();
|
|
|
|
$entityGenerator->setGenerateAnnotations(false);
|
|
|
|
$entityGenerator->setGenerateStubMethods(true);
|
|
|
|
$entityGenerator->setRegenerateEntityIfExists(false);
|
|
|
|
$entityGenerator->setUpdateEntityIfExists(true);
|
|
|
|
$entityGenerator->setNumSpaces(4);
|
|
|
|
$entityGenerator->setAnnotationPrefix('ORM\\');
|
|
|
|
|
|
|
|
return $entityGenerator;
|
|
|
|
}
|
|
|
|
|
2012-07-15 14:56:31 +02:00
|
|
|
/**
|
|
|
|
* Get a doctrine entity manager by symfony name.
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @return \Doctrine\ORM\EntityManager
|
|
|
|
*/
|
2012-07-01 09:52:20 +02:00
|
|
|
protected function getEntityManager($name)
|
|
|
|
{
|
|
|
|
return $this->getContainer()->get('doctrine')->getManager($name);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a doctrine dbal connection by symfony name.
|
|
|
|
*
|
|
|
|
* @param string $name
|
2012-07-15 14:56:31 +02:00
|
|
|
* @return \Doctrine\DBAL\Connection
|
2012-07-01 09:52:20 +02:00
|
|
|
*/
|
|
|
|
protected function getDoctrineConnection($name)
|
|
|
|
{
|
|
|
|
return $this->getContainer()->get('doctrine')->getConnection($name);
|
|
|
|
}
|
|
|
|
}
|