Passed
Push — main ( 553a30...c3cb08 )
by Martin
11:04 queued 10s
created

DateBin   A

Complexity

Total Complexity 1

Size/Duplication

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

1 Method

Rating   Name   Duplication   Size   Complexity  
A customizeFunction() 0 6 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace MartinGeorgiev\Doctrine\ORM\Query\AST\Functions;
6
7
/**
8
 * Implementation of PostgreSQL DATE_BIN().
9
 *
10
 * Bins input into specified interval aligned with specified origin.
11
 *
12
 * @see https://www.postgresql.org/docs/14/functions-datetime.html
13
 * @since 3.1
14
 *
15
 * @author Martin Georgiev <[email protected]>
16
 *
17
 * @example Using it in DQL: "SELECT DATE_BIN('15 minutes', e.createdAt, '2001-02-16 20:05:00') FROM Entity e"
18
 */
19
class DateBin extends BaseFunction
20
{
21 1
    protected function customizeFunction(): void
22
    {
23 1
        $this->setFunctionPrototype('date_bin(%s, %s, %s)');
24 1
        $this->addNodeMapping('StringPrimary');
25 1
        $this->addNodeMapping('StringPrimary');
26 1
        $this->addNodeMapping('StringPrimary');
27
    }
28
}
29