use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface;
-use Symfony\Component\Console\Command\Command;
-use Drupal\Console\Core\Command\Shared\CommandTrait;
+use Drupal\Console\Core\Command\Command;
use Drupal\Console\Generator\ModuleFileGenerator;
use Drupal\Console\Command\Shared\ConfirmationTrait;
use Drupal\Console\Command\Shared\ModuleTrait;
use Drupal\Console\Extension\Manager;
-use Drupal\Console\Core\Style\DrupalStyle;
+use Drupal\Console\Utils\Validator;
/**
* Class ModuleFileCommand
*/
class ModuleFileCommand extends Command
{
- use CommandTrait;
use ConfirmationTrait;
use ModuleTrait;
/**
- * @var Manager
-*/
+ * @var Manager
+ */
protected $extensionManager;
/**
- * @var ModuleFileGenerator
-*/
+ * @var ModuleFileGenerator
+ */
protected $generator;
+ /**
+ * @var Validator
+ */
+ protected $validator;
+
/**
* ModuleFileCommand constructor.
*/
public function __construct(
Manager $extensionManager,
- ModuleFileGenerator $generator
+ ModuleFileGenerator $generator,
+ Validator $validator
) {
$this->extensionManager = $extensionManager;
$this->generator = $generator;
+ $this->validator = $validator;
parent::__construct();
}
->setName('generate:module:file')
->setDescription($this->trans('commands.generate.module.file.description'))
->setHelp($this->trans('commands.generate.module.file.help'))
- ->addOption('module', null, InputOption::VALUE_REQUIRED, $this->trans('commands.common.options.module'));
+ ->addOption(
+ 'module',
+ null,
+ InputOption::VALUE_REQUIRED,
+ $this->trans('commands.common.options.module')
+ )->setAliases(['gmf']);
}
/**
*/
protected function execute(InputInterface $input, OutputInterface $output)
{
- $io = new DrupalStyle($input, $output);
-
- // @see use Drupal\Console\Command\Shared\ConfirmationTrait::confirmGeneration
- if (!$this->confirmGeneration($io, $yes)) {
+ // @see use Drupal\Console\Command\Shared\ConfirmationTrait::confirmOperation
+ if (!$this->confirmOperation()) {
return 1;
}
$machine_name = $input->getOption('module');
$file_path = $this->extensionManager->getModule($machine_name)->getPath();
- $generator = $this->generator;
- $generator->generate(
- $machine_name,
- $file_path
- );
+ $this->generator->generate([
+ 'machine_name' => $machine_name,
+ 'file_path' => $file_path,
+ ]);
}
*/
protected function interact(InputInterface $input, OutputInterface $output)
{
- $io = new DrupalStyle($input, $output);
-
// --module option
- $module = $input->getOption('module');
-
- if (!$module) {
- // @see Drupal\Console\Command\Shared\ModuleTrait::moduleQuestion
- $module = $this->moduleQuestion($io);
- }
-
- $input->setOption('module', $module);
+ $this->getModuleOption();
}
}