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

ST_Centroid   A

Complexity

Total Complexity 1

Size/Duplication

Total Lines 6
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

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

1 Method

Rating   Name   Duplication   Size   Complexity  
A customizeFunction() 0 4 1
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_Centroid() function.
11
 *
12
 * Returns the geometric center of a geometry.
13
 * For point geometries, the centroid is the point itself.
14
 * For line geometries, the centroid is the midpoint.
15
 * For polygon geometries, the centroid is the center of mass.
16
 *
17
 * @see https://postgis.net/docs/ST_Centroid.html
18
 * @since 3.5
19
 *
20
 * @author Martin Georgiev <[email protected]>
21
 *
22
 * @example Using it in DQL: "SELECT ST_CENTROID(g.geometry) FROM Entity g"
23
 * Returns point geometry representing the centroid.
24
 */
25
class ST_Centroid extends BaseFunction
26
{
27 1
    protected function customizeFunction(): void
28
    {
29 1
        $this->setFunctionPrototype('ST_Centroid(%s)');
30 1
        $this->addNodeMapping('StringPrimary');
31
    }
32
}
33