MyCustomEnumType::getSQLDeclaration()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 8
Code Lines 5

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 5
c 1
b 0
f 0
nc 1
nop 2
dl 0
loc 8
rs 10
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Acelaya\Test\Doctrine\Type;
6
7
use Acelaya\Doctrine\Type\PhpEnumType;
8
use Doctrine\DBAL\Platforms\AbstractPlatform;
9
10
use function call_user_func;
11
use function implode;
12
use function sprintf;
13
14
class MyCustomEnumType extends PhpEnumType
15
{
16
    /**
17
     * {@inheritdoc}
18
     */
19
    public function getSQLDeclaration(array $fieldDeclaration, AbstractPlatform $platform)
20
    {
21
        $values = call_user_func([$this->enumClass, 'toArray']);
22
23
        return sprintf(
24
            'ENUM("%s") COMMENT "%s"',
25
            implode('", "', $values),
26
            $this->getName()
27
        );
28
    }
29
}
30