Passed
Pull Request — 2.x (#135)
by Maxim
18:50
created

CompileJsonContains   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 18
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 7
c 1
b 0
f 0
dl 0
loc 18
rs 10
wmc 2

1 Method

Rating   Name   Duplication   Size   Complexity  
A compile() 0 11 2
1
<?php
2
3
/**
4
 * This file is part of Cycle ORM package.
5
 *
6
 * For the full copyright and license information, please view the LICENSE
7
 * file that was distributed with this source code.
8
 */
9
10
declare(strict_types=1);
11
12
namespace Cycle\Database\Driver\Postgres\Injection;
13
14
class CompileJsonContains extends PostgresJsonExpression
15
{
16
    /**
17
     * @param non-empty-string $statement
0 ignored issues
show
Documentation Bug introduced by
The doc comment non-empty-string at position 0 could not be parsed: Unknown type name 'non-empty-string' at position 0 in non-empty-string.
Loading history...
18
     *
19
     * @return non-empty-string
0 ignored issues
show
Documentation Bug introduced by
The doc comment non-empty-string at position 0 could not be parsed: Unknown type name 'non-empty-string' at position 0 in non-empty-string.
Loading history...
20
     */
21
    protected function compile(string $statement): string
22
    {
23
        $wrappedPath = $this->getWrappedPath($statement);
24
        $attribute = \array_pop($wrappedPath);
25
        $field = $this->getField($statement);
26
27
        if (!empty($wrappedPath)) {
28
            return '(' . $field . '->' . \implode('->', $wrappedPath) . '->' . $attribute . ')::jsonb @> ?';
29
        }
30
31
        return '(' . $field . '->' . $attribute . ')::jsonb @> ?';
32
    }
33
}
34