Passed
Pull Request — dev (#52)
by Wilmer
09:10
created

LikeConditionBuilder   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 33
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
eloc 10
dl 0
loc 33
ccs 6
cts 6
cp 1
rs 10
c 0
b 0
f 0
wmc 3
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Db\Oracle\Builder;
6
7
use Exception;
8
use Yiisoft\Db\Query\Conditions\Builder\LikeConditionBuilder as AbstractLikeConditionBuilder;
9
use Yiisoft\Db\Query\Conditions\Interface\LikeConditionInterface;
0 ignored issues
show
Bug introduced by
A parse error occurred: Syntax error, unexpected T_INTERFACE, expecting T_STRING or '{' on line 9 at column 32
Loading history...
10
use Yiisoft\Db\Query\QueryBuilderInterface;
11
use Yiisoft\Db\Schema\Quoter;
12
13
final class LikeConditionBuilder extends AbstractLikeConditionBuilder
14
{
15
    protected ?string $escapeCharacter = '!';
16
17
    /**
18
     * `\` is initialized in {@see buildLikeCondition()} method since we need to choose replacement value based on
19
     * {@see Quoter::quoteValue()}.
20
     */
21
    protected array $escapingReplacements = [
22
        '%' => '!%',
23
        '_' => '!_',
24
        '!' => '!!',
25
    ];
26
27 31
    public function __construct(private QueryBuilderInterface $queryBuilder)
28
    {
29 31
        parent::__construct($queryBuilder);
30
    }
31
32
    /**
33
     * @throws Exception
34
     */
35 31
    public function build(LikeConditionInterface $expression, array &$params = []): string
36
    {
37 31
        if (!isset($this->escapingReplacements['\\'])) {
38
            /*
39
             * Different pdo_oci8 versions may or may not implement PDO::quote(), so {@see Quoter::quoteValue()} may or
40
             * may not quote \.
41
             */
42 31
            $this->escapingReplacements['\\'] = substr((string) $this->queryBuilder->quoter()->quoteValue('\\'), 1, -1);
43
        }
44
45 31
        return parent::build($expression, $params);
46
    }
47
}
48