Passed
Push — main ( 1de5aa...972445 )
by Martin
33:59 queued 19:39
created

ST_Project::customizeFunction()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 6
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 5
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 1
eloc 4
c 1
b 0
f 1
nc 1
nop 0
dl 0
loc 6
ccs 5
cts 5
cp 1
crap 1
rs 10
1
<?php
2
3
declare(strict_types=1);
4
5
namespace MartinGeorgiev\Doctrine\ORM\Query\AST\Functions\PostGIS;
6
7
use MartinGeorgiev\Doctrine\ORM\Query\AST\Functions\BaseFunction;
8
9
/**
10
 * Implementation of PostGIS ST_Project() function.
11
 *
12
 * Projects a point along a geodesic.
13
 * Useful for calculating positions along great circle paths.
14
 *
15
 * @see https://postgis.net/docs/ST_Project.html
16
 * @since 3.5
17
 *
18
 * @author Martin Georgiev <[email protected]>
19
 *
20
 * @example Using it in DQL: "SELECT ST_PROJECT(g.geometry, :distance, :azimuth) FROM Entity g"
21
 * Returns projected point.
22
 */
23
class ST_Project extends BaseFunction
24
{
25 1
    protected function customizeFunction(): void
26
    {
27 1
        $this->setFunctionPrototype('ST_Project(%s, %s, %s)');
28 1
        $this->addNodeMapping('StringPrimary');
29 1
        $this->addNodeMapping('SimpleArithmeticExpression');
30 1
        $this->addNodeMapping('SimpleArithmeticExpression');
31
    }
32
}
33