Completed
Pull Request — master (#6)
by Jefersson
09:35
created

Regex::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 3
CRAP Score 1

Importance

Changes 0
Metric Value
c 0
b 0
f 0
dl 0
loc 4
ccs 3
cts 3
cp 1
rs 10
cc 1
eloc 2
nc 1
nop 1
crap 1
1
<?php
2
/*
3
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
4
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
5
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
6
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
7
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
8
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
9
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
10
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
11
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
12
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
13
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
14
 *
15
 * This software consists of voluntary contributions made by many individuals
16
 * and is licensed under the MIT license.
17
 */
18
19
namespace DocHeader\Validator;
20
21
/**
22
 * @author  Jefersson Nathan <[email protected]>
23
 * @license MIT
24
 */
25
final class Regex
26
{
27
    const TAG_BEGIN = '%re:';
28
    const TAG_END   = '%';
29
30
    /**
31
     * @var string
32
     */
33
    private $pattern;
34
35
    /**
36
     * @param string $pattern
37
     */
38 10
    public function __construct($pattern)
39
    {
40 10
        $this->pattern = $pattern;
41 10
    }
42
43
    /**
44
     * {@inheritDoc}
45
     */
46 10
    public function __invoke($docheader)
47
    {
48 10
        $didMatch = preg_match_all(
49 10
            '{' . preg_quote(self::TAG_BEGIN) . '(.+?)' . preg_quote(self::TAG_END) . '}',
50 10
            $this->pattern,
51
            $matches
52
        );
53
54 10
        if (! $didMatch) {
55
            return true;
56
        }
57
58 10
        $matchable = $this->pattern;
59
60
        /* @var $matches array[] */
61 10
        foreach ($matches[1] as $k => $match) {
62 10
            $sentence = $matches[0][$k];
63
64 10
            $matchable = str_replace($sentence, $match, $matchable);
65
        }
66
67 10
        if (! preg_match('{' . $matchable . '}', $docheader, $m)) {
0 ignored issues
show
Comprehensibility introduced by
Avoid variables with short names like $m. Configured minimum length is 3.

Short variable names may make your code harder to understand. Variable names should be self-descriptive. This check looks for variable names who are shorter than a configured minimum.

Loading history...
68 2
            return false;
69
        }
70
71 8
        return true;
72
    }
73
}
74