Passed
Push — text-bug ( 3bd0aa )
by Martin
11:49
created

Lca   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 20
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 20
ccs 8
cts 8
cp 1
rs 10
wmc 4

4 Methods

Rating   Name   Duplication   Size   Complexity  
A getNodeMappingPattern() 0 3 1
A getMaxArgumentCount() 0 3 1
A getMinArgumentCount() 0 3 1
A getFunctionName() 0 3 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\BaseVariadicFunction;
8
9
/**
10
 * Implementation of PostgreSQL lca function.
11
 *
12
 * Computes longest common ancestor of paths (up to 8 arguments are supported).
13
 *
14
 * @see https://www.postgresql.org/docs/17/ltree.html#LTREE-FUNCTIONS
15
 * @since 3.5
16
 *
17
 * @author Martin Georgiev <[email protected]>
18
 *
19
 * @example Using it in DQL: "SELECT LCA(e.path1, e.path2) FROM Entity e"
20
 * Returns ltree, longest common ancestor of paths.
21
 */
22
class Lca extends BaseVariadicFunction
23
{
24 3
    protected function getNodeMappingPattern(): array
25
    {
26 3
        return ['StringPrimary'];
27
    }
28
29 3
    protected function getFunctionName(): string
30
    {
31 3
        return 'lca';
32
    }
33
34 3
    protected function getMinArgumentCount(): int
35
    {
36 3
        return 2;
37
    }
38
39 3
    protected function getMaxArgumentCount(): int
40
    {
41 3
        return 8;
42
    }
43
}
44