Passed
Push — ltree-functions ( d4a019 )
by Martin
13:48
created

Subltree   A

Complexity

Total Complexity 1

Size/Duplication

Total Lines 8
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 1
Metric Value
eloc 5
c 1
b 0
f 1
dl 0
loc 8
ccs 5
cts 5
cp 1
rs 10
wmc 1

1 Method

Rating   Name   Duplication   Size   Complexity  
A customizeFunction() 0 6 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace MartinGeorgiev\Doctrine\ORM\Query\AST\Functions\Ltree;
6
7
use MartinGeorgiev\Doctrine\ORM\Query\AST\Functions\BaseFunction;
8
9
/**
10
 * Implementation of PostgreSQL subltree function.
11
 *
12
 * Returns subpath of ltree from position start to position end-1 (counting from 0).
13
 *
14
 * @see https://www.postgresql.org/docs/current/ltree.html#LTREE-FUNCTIONS
15
 * @since 3.5
16
 *
17
 * @author Martin Georgiev <[email protected]>
18
 *
19
 * @example Using it in DQL: "SELECT SUBLTREE(e.path, 1, 2) FROM Entity e"
20
 * Returns ltree, subpath from position start to position end-1.
21
 */
22
class Subltree extends BaseFunction
23
{
24 1
    protected function customizeFunction(): void
25
    {
26 1
        $this->setFunctionPrototype('subltree(%s, %s, %s)');
27 1
        $this->addNodeMapping('StringPrimary');
28 1
        $this->addNodeMapping('SimpleArithmeticExpression');
29 1
        $this->addNodeMapping('SimpleArithmeticExpression');
30
    }
31
}
32