@@ 8-53 (lines=46) @@ | ||
5 | use Coduo\PHPMatcher\Parser; |
|
6 | use Coduo\ToString\StringConverter; |
|
7 | ||
8 | final class DoubleMatcher extends Matcher |
|
9 | { |
|
10 | /** |
|
11 | * @var Parser |
|
12 | */ |
|
13 | private $parser; |
|
14 | ||
15 | /** |
|
16 | * @param Parser $parser |
|
17 | */ |
|
18 | public function __construct(Parser $parser) |
|
19 | { |
|
20 | $this->parser = $parser; |
|
21 | } |
|
22 | ||
23 | /** |
|
24 | * {@inheritDoc} |
|
25 | */ |
|
26 | public function match($value, $pattern) |
|
27 | { |
|
28 | if (!is_double($value)) { |
|
29 | $this->error = sprintf("%s \"%s\" is not a valid double.", gettype($value), new StringConverter($value)); |
|
30 | return false; |
|
31 | } |
|
32 | ||
33 | $typePattern = $this->parser->parse($pattern); |
|
34 | if (!$typePattern->matchExpanders($value)) { |
|
35 | $this->error = $typePattern->getError(); |
|
36 | return false; |
|
37 | } |
|
38 | ||
39 | return true; |
|
40 | } |
|
41 | ||
42 | /** |
|
43 | * {@inheritDoc} |
|
44 | */ |
|
45 | public function canMatch($pattern) |
|
46 | { |
|
47 | if (!is_string($pattern)) { |
|
48 | return false; |
|
49 | } |
|
50 | ||
51 | return $this->parser->hasValidSyntax($pattern) && $this->parser->parse($pattern)->is('double'); |
|
52 | } |
|
53 | } |
|
54 |
@@ 8-53 (lines=46) @@ | ||
5 | use Coduo\PHPMatcher\Parser; |
|
6 | use Coduo\ToString\StringConverter; |
|
7 | ||
8 | final class IntegerMatcher extends Matcher |
|
9 | { |
|
10 | /** |
|
11 | * @var Parser |
|
12 | */ |
|
13 | private $parser; |
|
14 | ||
15 | /** |
|
16 | * @param Parser $parser |
|
17 | */ |
|
18 | public function __construct(Parser $parser) |
|
19 | { |
|
20 | $this->parser = $parser; |
|
21 | } |
|
22 | ||
23 | /** |
|
24 | * {@inheritDoc} |
|
25 | */ |
|
26 | public function match($value, $pattern) |
|
27 | { |
|
28 | if (!is_integer($value)) { |
|
29 | $this->error = sprintf("%s \"%s\" is not a valid integer.", gettype($value), new StringConverter($value)); |
|
30 | return false; |
|
31 | } |
|
32 | ||
33 | $typePattern = $this->parser->parse($pattern); |
|
34 | if (!$typePattern->matchExpanders($value)) { |
|
35 | $this->error = $typePattern->getError(); |
|
36 | return false; |
|
37 | } |
|
38 | ||
39 | return true; |
|
40 | } |
|
41 | ||
42 | /** |
|
43 | * {@inheritDoc} |
|
44 | */ |
|
45 | public function canMatch($pattern) |
|
46 | { |
|
47 | if (!is_string($pattern)) { |
|
48 | return false; |
|
49 | } |
|
50 | ||
51 | return $this->parser->hasValidSyntax($pattern) && $this->parser->parse($pattern)->is('integer'); |
|
52 | } |
|
53 | } |
|
54 |
@@ 8-53 (lines=46) @@ | ||
5 | use Coduo\PHPMatcher\Parser; |
|
6 | use Coduo\ToString\StringConverter; |
|
7 | ||
8 | final class StringMatcher extends Matcher |
|
9 | { |
|
10 | /** |
|
11 | * @var Parser |
|
12 | */ |
|
13 | private $parser; |
|
14 | ||
15 | /** |
|
16 | * @param Parser $parser |
|
17 | */ |
|
18 | public function __construct(Parser $parser) |
|
19 | { |
|
20 | $this->parser = $parser; |
|
21 | } |
|
22 | ||
23 | /** |
|
24 | * {@inheritDoc} |
|
25 | */ |
|
26 | public function match($value, $pattern) |
|
27 | { |
|
28 | if (!is_string($value)) { |
|
29 | $this->error = sprintf("%s \"%s\" is not a valid string.", gettype($value), new StringConverter($value)); |
|
30 | return false; |
|
31 | } |
|
32 | ||
33 | $typePattern = $this->parser->parse($pattern); |
|
34 | if (!$typePattern->matchExpanders($value)) { |
|
35 | $this->error = $typePattern->getError(); |
|
36 | return false; |
|
37 | } |
|
38 | ||
39 | return true; |
|
40 | } |
|
41 | ||
42 | /** |
|
43 | * {@inheritDoc} |
|
44 | */ |
|
45 | public function canMatch($pattern) |
|
46 | { |
|
47 | if (!is_string($pattern)) { |
|
48 | return false; |
|
49 | } |
|
50 | ||
51 | return $this->parser->hasValidSyntax($pattern) && $this->parser->parse($pattern)->is('string'); |
|
52 | } |
|
53 | } |
|
54 |