123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Bundle\FrameworkBundle\Command;
- use Symfony\Component\Console\Input\InputArgument;
- use Symfony\Component\Console\Input\InputOption;
- use Symfony\Component\Console\Input\InputInterface;
- use Symfony\Component\Console\Output\OutputInterface;
- use Symfony\Component\Console\Output\Output;
- use Symfony\Bundle\FrameworkBundle\Util\Mustache;
- /**
- * Initializes a new bundle.
- *
- * @author Fabien Potencier <fabien@symfony.com>
- */
- class InitBundleCommand extends Command
- {
- /**
- * @see Command
- */
- protected function configure()
- {
- $this
- ->setDefinition(array(
- new InputArgument('namespace', InputArgument::REQUIRED, 'The namespace of the bundle to create'),
- new InputArgument('dir', InputArgument::REQUIRED, 'The directory where to create the bundle'),
- new InputArgument('bundleName', InputArgument::OPTIONAL, 'The optional bundle name'),
- new InputOption('format', '', InputOption::VALUE_REQUIRED, 'Use the format for configuration files (php, xml, or yml)', 'yml')
- ))
- ->setHelp(<<<EOT
- The <info>init:bundle</info> command generates a new bundle with a basic skeleton.
- <info>./app/console init:bundle "Vendor\HelloBundle" src [bundleName]</info>
- The bundle namespace must end with "Bundle" (e.g. <comment>Vendor\HelloBundle</comment>)
- and can be placed in any directory (e.g. <comment>src</comment>).
- If you don't specify a bundle name (e.g. <comment>HelloBundle</comment>), the bundle name will
- be the concatenation of the namespace segments (e.g. <comment>VendorHelloBundle</comment>).
- EOT
- )
- ->setName('init:bundle')
- ;
- }
- /**
- * @see Command
- *
- * @throws \InvalidArgumentException When namespace doesn't end with Bundle
- * @throws \RuntimeException When bundle can't be executed
- */
- protected function execute(InputInterface $input, OutputInterface $output)
- {
- if (!preg_match('/Bundle$/', $namespace = $input->getArgument('namespace'))) {
- throw new \InvalidArgumentException('The namespace must end with Bundle.');
- }
- // validate namespace
- if (preg_match('/[^A-Za-z0-9_\\\-]/', $namespace)) {
- throw new \InvalidArgumentException('The namespace contains invalid characters.');
- }
- // user specified bundle name?
- $bundle = $input->getArgument('bundleName');
- if (!$bundle) {
- $bundle = strtr($namespace, array('\\' => ''));
- }
- if (!preg_match('/Bundle$/', $bundle)) {
- throw new \InvalidArgumentException('The bundle name must end with Bundle.');
- }
- // validate that the namespace is at least one level deep
- if (false === strpos($namespace, '\\')) {
- $msg = array();
- $msg[] = sprintf('The namespace must contain a vendor namespace (e.g. "VendorName\%s" instead of simply "%s").', $namespace, $namespace);
- $msg[] = 'If you\'ve specified a vendor namespace, did you forget to surround it with quotes (init:bundle "Acme\BlogBundle")?';
- throw new \InvalidArgumentException(implode("\n\n", $msg));
- }
- $dir = $input->getArgument('dir');
- // add trailing / if necessary
- $dir = '/' === substr($dir, -1, 1) ? $dir : $dir.'/';
- $targetDir = $dir.strtr($namespace, '\\', '/');
- if (file_exists($targetDir)) {
- throw new \RuntimeException(sprintf('Bundle "%s" already exists.', $bundle));
- }
- $filesystem = $this->container->get('filesystem');
- $filesystem->mirror(__DIR__.'/../Resources/skeleton/bundle/generic', $targetDir);
- $filesystem->mirror(__DIR__.'/../Resources/skeleton/bundle/'.$input->getOption('format'), $targetDir);
- Mustache::renderDir($targetDir, array(
- 'namespace' => $namespace,
- 'bundle' => $bundle,
- ));
- rename($targetDir.'/Bundle.php', $targetDir.'/'.$bundle.'.php');
- $output->writeln('<comment>Summary of actions</comment>');
- $output->writeln(sprintf('- The bundle "<info>%s</info>" was created at "<info>%s</info>" and is using the namespace "<info>%s</info>".', $bundle, $targetDir, $namespace));
- $output->writeln(sprintf('- The bundle contains a sample controller, a sample template and a sample routing file.'));
- $output->writeln('');
- $output->writeln('<comment>Follow-up actions</comment>');
- $output->writeln('- Enable the bundle inside the AppKernel::registerBundles() method.');
- $output->writeln(' Resource: <info>http://symfony.com/doc/2.0/book/page_creation.html#create-the-bundle</info>');
- $output->writeln('- Ensure that the namespace is registered with the autoloader.');
- $output->writeln(' Resource: <info>http://symfony.com/doc/2.0/book/page_creation.html#autoloading-introduction-sidebar</info>');
- $output->writeln('- If using routing, import the bundle\'s routing resource.');
- $output->writeln(' Resource: <info>http://symfony.com/doc/2.0/book/routing.html#including-external-routing-resources</info>');
- $output->writeln('- Starting building your bundle!');
- $output->writeln(' Resource: <info>http://symfony.com/doc/2.0/book/page_creation.html#the-hello-symfony-page</info>');
- }
- }
|