Passed
Push — 2.0 ( 0701c6 )
by Luis
47s queued 12s
created

GeneratorInput::directory()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 1
c 1
b 0
f 0
nc 1
nop 0
dl 0
loc 3
rs 10
1
<?php
2
/**
3
 * PHP version 7.1
4
 *
5
 * This source file is subject to the license that is bundled with this package in the file LICENSE.
6
 */
7
8
namespace PhUml\Console\Commands;
9
10
use Webmozart\Assert\Assert;
0 ignored issues
show
Bug introduced by
The type Webmozart\Assert\Assert was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
11
12
class GeneratorInput
13
{
14
    /** @var string */
15
    private $directory;
16
17
    /** @var string */
18
    private $outputFile;
19
20
    /** @var mixed[] $options */
21
    private $options;
22
23
    /**
24
     * @param string[] $arguments
25
     * @param mixed[] $options
26
     */
27
    public function __construct(array $arguments, array $options)
28
    {
29
        $this->setDirectory($arguments);
30
        $this->setOutputFile($arguments);
31
        $this->options = $options;
32
    }
33
34
    public function directory(): string
35
    {
36
        return $this->directory;
37
    }
38
39
    public function outputFile(): string
40
    {
41
        return $this->outputFile;
42
    }
43
44
    /** @return mixed[] $options */
45
    public function options(): array
46
    {
47
        return $this->options;
48
    }
49
50
    /** @param string[] $arguments */
51
    private function setDirectory(array $arguments): void
52
    {
53
        Assert::stringNotEmpty(
54
            $arguments['directory'] ?? '',
55
            'The directory with the code to be scanned cannot be empty'
56
        );
57
        $this->directory = $arguments['directory'];
58
    }
59
60
    /** @param string[] $arguments */
61
    private function setOutputFile(array $arguments): void
62
    {
63
        Assert::stringNotEmpty(
64
            $arguments['output'] ?? '',
65
            'The output file cannot be empty'
66
        );
67
        $this->outputFile = $arguments['output'];
68
    }
69
}
70