Passed
Pull Request — main (#430)
by
unknown
26:07 queued 11:08
created

TrajectoryDistance   A

Complexity

Total Complexity 1

Size/Duplication

Total Lines 7
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

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

1 Method

Rating   Name   Duplication   Size   Complexity  
A customizeFunction() 0 5 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace MartinGeorgiev\Doctrine\ORM\Query\AST\Functions;
6
7
/**
8
 * Implementation of PostGIS trajectory distance operator (using |=|).
9
 *
10
 * Returns the distance between A and B trajectories at their closest point of approach.
11
 * Trajectories are linear geometries with increasing measures (M value) on each coordinate.
12
 *
13
 * @see https://postgis.net/docs/reference.html#Operators_Distance
14
 * @since 3.5
15
 *
16
 * @author Martin Georgiev <[email protected]>
17
 *
18
 * @example Using it in DQL: "SELECT TRAJECTORY_DISTANCE(t1.trajectory, t2.trajectory) FROM Entity t1, Entity t2"
19
 * Returns numeric distance value.
20
 */
21
class TrajectoryDistance extends BaseFunction
22
{
23 1
    protected function customizeFunction(): void
24
    {
25 1
        $this->setFunctionPrototype('(%s |=| %s)');
26 1
        $this->addNodeMapping('StringPrimary');
27 1
        $this->addNodeMapping('StringPrimary');
28
    }
29
}
30