Passed
Push — main ( 05a0af...c5f732 )
by Martin
13:23
created

WidthBucket   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 15
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

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

3 Methods

Rating   Name   Duplication   Size   Complexity  
A getMinArgumentCount() 0 3 1
A getFunctionName() 0 3 1
A getMaxArgumentCount() 0 3 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace MartinGeorgiev\Doctrine\ORM\Query\AST\Functions;
6
7
/**
8
 * Implementation of PostgreSQL WIDTH_BUCKET() - assigns values to buckets (equi-width histogram).
9
 *
10
 * @see https://www.postgresql.org/docs/17/functions-math.html
11
 * @since 3.2
12
 *
13
 * @author Martin Georgiev <[email protected]>
14
 *
15
 * @example Using it in DQL: "SELECT WIDTH_BUCKET(operand, b1, b2, count) FROM Entity e"
16
 */
17
class WidthBucket extends BaseArithmeticFunction
18
{
19 1
    protected function getFunctionName(): string
20
    {
21 1
        return 'WIDTH_BUCKET';
22
    }
23
24 1
    protected function getMinArgumentCount(): int
25
    {
26 1
        return 4;
27
    }
28
29 1
    protected function getMaxArgumentCount(): int
30
    {
31 1
        return 4;
32
    }
33
}
34