Passed
Pull Request — main (#430)
by Martin
27:00 queued 12:07
created

GeometryDistance   A

Complexity

Total Complexity 1

Size/Duplication

Total Lines 7
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 1
Metric Value
wmc 1
eloc 4
c 1
b 0
f 1
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 2D distance between geometries operator (using <->).
9
 *
10
 * Returns the 2D distance between A and B geometries.
11
 * This differs from BoundingBoxDistance (using <#>), which measures distance between
12
 * bounding boxes only. The <-> operator is commonly used for KNN nearest-neighbor
13
 * ordering, and on PostgreSQL 9.5+ with PostGIS 2.2+ it returns true geometry distance;
14
 * on older stacks it behaved as a centroid-of-bounding-box distance approximation.
15
 *
16
 * @see https://postgis.net/docs/reference.html#Operators
17
 * @see https://postgis.net/docs/geometry_distance_knn.html
18
 * @since 3.5
19
 *
20
 * @author Martin Georgiev <[email protected]>
21
 *
22
 * @example Using it in DQL: "SELECT GEOMETRY_DISTANCE(g1.geometry, g2.geometry) FROM Entity g1, Entity g2"
23
 * Returns numeric distance value.
24
 */
25
class GeometryDistance extends BaseFunction
26
{
27 1
    protected function customizeFunction(): void
28
    {
29 1
        $this->setFunctionPrototype('(%s <-> %s)');
30 1
        $this->addNodeMapping('StringPrimary');
31 1
        $this->addNodeMapping('StringPrimary');
32
    }
33
}
34