Application::addInitRoboFileCommand()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 22

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 22
rs 9.568
c 0
b 0
f 0
cc 1
nc 1
nop 2
1
<?php
2
3
namespace Robo;
4
5
use SelfUpdate\SelfUpdateCommand;
6
use Symfony\Component\Console\Application as SymfonyApplication;
7
use Symfony\Component\Console\Command\Command;
8
use Symfony\Component\Console\Input\InputOption;
9
10
class Application extends SymfonyApplication
11
{
12
    /**
13
     * @param string $name
14
     * @param string $version
15
     */
16
    public function __construct($name, $version)
17
    {
18
        parent::__construct($name, $version);
19
20
        $this->getDefinition()
21
            ->addOption(
22
                new InputOption('--simulate', null, InputOption::VALUE_NONE, 'Run in simulated mode (show what would have happened).')
23
            );
24
        $this->getDefinition()
25
            ->addOption(
26
                new InputOption('--progress-delay', null, InputOption::VALUE_REQUIRED, 'Number of seconds before progress bar is displayed in long-running task collections. Default: 2s.', Config::DEFAULT_PROGRESS_DELAY)
27
            );
28
29
        $this->getDefinition()
30
            ->addOption(
31
                new InputOption('--define', '-D', InputOption::VALUE_REQUIRED | InputOption::VALUE_IS_ARRAY, 'Define a configuration item value.', [])
32
            );
33
    }
34
35
    /**
36
     * @param string $roboFile
37
     * @param string $roboClass
38
     */
39
    public function addInitRoboFileCommand($roboFile, $roboClass)
40
    {
41
        $createRoboFile = new Command('init');
42
        $createRoboFile->setDescription("Intitalizes basic RoboFile in current dir");
43
        $createRoboFile->setCode(function () use ($roboClass, $roboFile) {
44
            $output = Robo::output();
45
            $output->writeln("<comment>  ~~~ Welcome to Robo! ~~~~ </comment>");
46
            $output->writeln("<comment>  " . basename($roboFile) . " will be created in the current directory </comment>");
47
            file_put_contents(
48
                $roboFile,
49
                '<?php'
50
                . "\n/**"
51
                . "\n * This is project's console commands configuration for Robo task runner."
52
                . "\n *"
53
                . "\n * @see http://robo.li/"
54
                . "\n */"
55
                . "\nclass " . $roboClass . " extends \\Robo\\Tasks\n{\n    // define public methods as commands\n}"
56
            );
57
            $output->writeln("<comment>  Edit this file to add your commands! </comment>");
58
        });
59
        $this->add($createRoboFile);
60
    }
61
62
    /**
63
     * Add self update command, do nothing if null is provided
64
     *
65
     * @param string $repository
66
     *   GitHub Repository for self update.
67
     */
68
    public function addSelfUpdateCommand($repository = null)
69
    {
70
        if (!$repository || empty(\Phar::running())) {
0 ignored issues
show
Bug Best Practice introduced by
The expression $repository of type string|null is loosely compared to false; this is ambiguous if the string can be empty. You might want to explicitly use === null instead.

In PHP, under loose comparison (like ==, or !=, or switch conditions), values of different types might be equal.

For string values, the empty string '' is a special case, in particular the following results might be unexpected:

''   == false // true
''   == null  // true
'ab' == false // false
'ab' == null  // false

// It is often better to use strict comparison
'' === false // false
'' === null  // false
Loading history...
71
            return;
72
        }
73
        $selfUpdateCommand = new SelfUpdateCommand($this->getName(), $this->getVersion(), $repository);
74
        $this->add($selfUpdateCommand);
75
    }
76
}
77