Passed
Push — master ( 229462...d74785 )
by Andreas
02:20 queued 14s
created

InlineParameterFormatter   A

Complexity

Total Complexity 14

Size/Duplication

Total Lines 73
Duplicated Lines 0 %

Test Coverage

Coverage 93.1%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 26
dl 0
loc 73
ccs 27
cts 29
cp 0.931
rs 10
c 1
b 0
f 0
wmc 14

4 Methods

Rating   Name   Duplication   Size   Complexity  
A formatParameters() 0 19 4
A __construct() 0 3 1
A parameterToString() 0 17 6
A formatParameter() 0 10 3
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Doctrine\Migrations;
6
7
use Doctrine\DBAL\Connection;
8
use Doctrine\DBAL\Types\Type;
9
use function array_map;
10
use function implode;
11
use function is_array;
12
use function is_bool;
13
use function is_int;
14
use function is_string;
15
use function sprintf;
16
17
/**
18
 * The InlineParameterFormatter class is responsible for formatting SQL query parameters to a string
19
 * for display output.
20
 *
21
 * @internal
22
 */
23
final class InlineParameterFormatter implements ParameterFormatter
24
{
25
    /** @var Connection */
26
    private $connection;
27
28 1
    public function __construct(Connection $connection)
29
    {
30 1
        $this->connection = $connection;
31 1
    }
32
33
    /**
34
     * @param mixed[] $params
35
     * @param mixed[] $types
36
     */
37 1
    public function formatParameters(array $params, array $types) : string
38
    {
39 1
        if ($params === []) {
40
            return '';
41
        }
42
43 1
        $formattedParameters = [];
44
45 1
        foreach ($params as $key => $value) {
46 1
            $type = $types[$key] ?? 'string';
47
48 1
            $formattedParameter = '[' . $this->formatParameter($value, $type) . ']';
49
50 1
            $formattedParameters[] = is_string($key)
51 1
                ? sprintf(':%s => %s', $key, $formattedParameter)
52 1
                : $formattedParameter;
53
        }
54
55 1
        return sprintf('with parameters (%s)', implode(', ', $formattedParameters));
56
    }
57
58
    /**
59
     * @param string|int $value
60
     * @param string|int $type
61
     *
62
     * @return string|int
63
     */
64 1
    private function formatParameter($value, $type)
65
    {
66 1
        if (is_string($type) && Type::hasType($type)) {
67 1
            return Type::getType($type)->convertToDatabaseValue(
68 1
                $value,
69 1
                $this->connection->getDatabasePlatform()
70
            );
71
        }
72
73 1
        return $this->parameterToString($value);
74
    }
75
76
    /**
77
     * @param int[]|bool[]|string[]|array|int|string|bool $value
78
     */
79 1
    private function parameterToString($value) : string
80
    {
81 1
        if (is_array($value)) {
82
            return implode(', ', array_map(function ($value) : string {
83 1
                return $this->parameterToString($value);
84 1
            }, $value));
85
        }
86
87 1
        if (is_int($value) || is_string($value)) {
88 1
            return (string) $value;
89
        }
90
91 1
        if (is_bool($value)) {
0 ignored issues
show
introduced by
The condition is_bool($value) is always true.
Loading history...
92 1
            return $value === true ? 'true' : 'false';
93
        }
94
95
        return '?';
96
    }
97
}
98