1
0
Fork 0
mirror of synced 2025-04-03 13:23:37 +03:00

Moved tools to Advanced topic, included simple setting up tools in Installation. Reworked CLI tool to print a template when no cli-config.php is defined.

This commit is contained in:
Benjamin Eberlei 2013-03-17 12:16:42 +01:00
parent bdfe6098a4
commit a7d764f6c0
5 changed files with 107 additions and 24 deletions

View file

@ -13,32 +13,47 @@
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
* *
* This software consists of voluntary contributions made by many individuals * This software consists of voluntary contributions made by many individuals
* and is licensed under the LGPL. For more information, see * and is licensed under the MIT license. For more information, see
* <http://www.doctrine-project.org>. * <http://www.doctrine-project.org>.
*/ */
use Symfony\Component\Console\Helper\HelperSet;
use Doctrine\ORM\Tools\Console\ConsoleRunner;
(@include_once __DIR__ . '/../vendor/autoload.php') || @include_once __DIR__ . '/../../../autoload.php'; (@include_once __DIR__ . '/../vendor/autoload.php') || @include_once __DIR__ . '/../../../autoload.php';
$configFile = getcwd() . DIRECTORY_SEPARATOR . 'cli-config.php';
$helperSet = null; $directories = array(getcwd(), getcwd() . DIRECTORY_SEPARATOR . 'config');
$commands = array();
if (file_exists($configFile)) { $configFile = null;
if ( ! is_readable($configFile)) { foreach ($directories as $directory) {
trigger_error( $configFile = $directory . DIRECTORY_SEPARATOR . 'cli-config.php';
'Configuration file [' . $configFile . '] does not have read permission.', E_ERROR
); if (file_exists($configFile)) {
break;
} }
}
require $configFile; if ( ! file_exists($configFile)) {
ConsoleRunner::printCliConfigTemplate();
exit(1);
}
if ( ! is_readable($configFile)) {
echo 'Configuration file [' . $configFile . '] does not have read permission.' . "\n";
exit(1);
}
$commands = array();
$helperSet = require $configFile;
if ( ! ($helperSet instanceof HelperSet)) {
foreach ($GLOBALS as $helperSetCandidate) { foreach ($GLOBALS as $helperSetCandidate) {
if ($helperSetCandidate instanceof \Symfony\Component\Console\Helper\HelperSet) { if ($helperSetCandidate instanceof HelperSet) {
$helperSet = $helperSetCandidate; $helperSet = $helperSetCandidate;
break; break;
} }
} }
} }
$helperSet = ($helperSet) ?: new \Symfony\Component\Console\Helper\HelperSet();
\Doctrine\ORM\Tools\Console\ConsoleRunner::run($helperSet, $commands); \Doctrine\ORM\Tools\Console\ConsoleRunner::run($helperSet, $commands);

View file

@ -27,7 +27,6 @@ Getting Started
* **Setup**: * **Setup**:
:doc:`Installation & Configuration <reference/configuration>` | :doc:`Installation & Configuration <reference/configuration>` |
:doc:`Commandline Tools <reference/tools>`
* **Tutorial**: * **Tutorial**:
:doc:`Code First <tutorials/getting-started>` | :doc:`Code First <tutorials/getting-started>` |
@ -71,6 +70,7 @@ Advanced Topics
* :doc:`Architecture <reference/architecture>` * :doc:`Architecture <reference/architecture>`
* :doc:`Advanced Configuration <reference/advanced-configuration>` * :doc:`Advanced Configuration <reference/advanced-configuration>`
* :doc:`Limitations and knowns issues <reference/limitations-and-known-issues>` * :doc:`Limitations and knowns issues <reference/limitations-and-known-issues>`
* :doc:`Commandline Tools <reference/tools>`
* :doc:`Transactions and Concurrency <reference/transactions-and-concurrency>` * :doc:`Transactions and Concurrency <reference/transactions-and-concurrency>`
* :doc:`Filters <reference/filters>` * :doc:`Filters <reference/filters>`
* :doc:`NamingStrategy <reference/namingstrategy>` * :doc:`NamingStrategy <reference/namingstrategy>`

View file

@ -92,3 +92,31 @@ Configuration <reference/advanced-configuration>` section.
You can learn more about the database connection configuration in the You can learn more about the database connection configuration in the
`Doctrine DBAL connection configuration reference <http://docs.doctrine-project.org/projects/doctrine-dbal/en/latest/reference/configuration.html>`_. `Doctrine DBAL connection configuration reference <http://docs.doctrine-project.org/projects/doctrine-dbal/en/latest/reference/configuration.html>`_.
Setting up the Commandline Tool
-------------------------------
Doctrine ships with a number of command line tools that are very helpful
during development. You can call this command from the Composer binary
directory:
.. code-block::
$ php vendor/bin/doctrine
You need to register your applications EntityManager to the console tool
to make use of the tasks by creating a ``cli-config.php`` file with the
following content:
.. code-block:: php
<?php
// cli-config.php
require_once 'my_bootstrap.php';
// Any way to access the EntityManager from your application
$em = GetMyEntityManager();
$helperSet = new \Symfony\Component\Console\Helper\HelperSet(array(
'db' => new \Doctrine\DBAL\Tools\Console\Helper\ConnectionHelper($em->getConnection()),
'em' => new \Doctrine\ORM\Tools\Console\Helper\EntityManagerHelper($em)
));

View file

@ -4,30 +4,29 @@ Tools
Doctrine Console Doctrine Console
---------------- ----------------
The Doctrine Console is a Command Line Interface tool for The Doctrine Console is a Command Line Interface tool for simplifying common
simplifying common tasks during the development of a project that administration tasks during the development of a project that uses Doctrine 2.
uses Doctrine 2.
Take a look at the :doc:`Configuration <configuration>` for more Take a look at the :doc:`Installation and Configuration <configuration>`
information how to setup the console command. chapter for more information how to setup the console command.
Getting Help Display Help Information
~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~
Type ``php vendor/bin/doctrine-orm`` on the command line and you should see an Type ``php vendor/bin/doctrine`` on the command line and you should see an
overview of the available commands or use the --help flag to get overview of the available commands or use the --help flag to get
information on the available commands. If you want to know more information on the available commands. If you want to know more
about the use of generate entities for example, you can call: about the use of generate entities for example, you can call:
.. code-block:: php .. code-block:: php
$> php vendor/bin/doctrine-orm orm:generate-entities --help $> php vendor/bin/doctrine orm:generate-entities --help
Configuration Configuration
~~~~~~~~~~~~~ ~~~~~~~~~~~~~
Whenever the ``doctrine-orm`` command line tool is invoked, it can Whenever the ``doctrine`` command line tool is invoked, it can
access all Commands that were registered by developer. There is no access all Commands that were registered by developer. There is no
auto-detection mechanism at work. The Doctrine binary auto-detection mechanism at work. The Doctrine binary
already registers all the commands that currently ship with already registers all the commands that currently ship with

View file

@ -23,8 +23,27 @@ use Symfony\Component\Console\Application;
use Symfony\Component\Console\Helper\HelperSet; use Symfony\Component\Console\Helper\HelperSet;
use Doctrine\ORM\Version; use Doctrine\ORM\Version;
use Doctrine\DBAL\Tools\Console\Helper\ConnectionHelper;
use Doctrine\ORM\Tools\Console\Helper\EntityManagerHelper;
/**
* Handles running the Console Tools inside Symfony Console context.
*/
class ConsoleRunner class ConsoleRunner
{ {
/**
* Create a Symfony Console HelperSet
*
* @return HelperSet
*/
public static function createHelperSet(EntityManager $entityManager)
{
return new HelperSet(array(
'db' => new ConnectionHelper($entityManager->getConnection()),
'em' => new EntityManagerHelper($entityManager)
));
}
/** /**
* Runs console with the given helperset. * Runs console with the given helperset.
* *
@ -73,4 +92,26 @@ class ConsoleRunner
new \Doctrine\ORM\Tools\Console\Command\InfoCommand() new \Doctrine\ORM\Tools\Console\Command\InfoCommand()
)); ));
} }
static public function printCliConfigTemplate()
{
echo <<<'HELP'
You are missing a "cli-config.php" or "config/cli-config.php" file in your
project, which is required to get the Doctrine Console working. You can use the
following sample as a template:
<?php
use Doctrine\ORM\Tools\Console\ConsoleRunner;
// replace with file to your own project bootstrap
require_once 'bootstrap.php';
// replace with mechanism to retrieve EntityManager in your app
$entityManager = GetEntityManager();
return ConsoleRunner::createHelperSet($entityManager);
HELP;
}
} }