Completed
Push — master ( be00fa...152a7c )
by Beniamin
05:51 queued 02:08
created

ParameterManager   A

Complexity

Total Complexity 6

Size/Duplication

Total Lines 66
Duplicated Lines 0 %

Coupling/Cohesion

Components 2
Dependencies 1

Test Coverage

Coverage 53.33%

Importance

Changes 0
Metric Value
dl 0
loc 66
c 0
b 0
f 0
wmc 6
lcom 2
cbo 1
ccs 8
cts 15
cp 0.5333
rs 10

5 Methods

Rating   Name   Duplication   Size   Complexity  
A createOrGetParameter() 0 8 2
A toArray() 0 4 1
A createReference() 0 7 1
A getReferences() 0 4 1
A generateNextReference() 0 4 1
1
<?php
2
3
/**
4
 * This file is part of Phuria SQL Builder package.
5
 *
6
 * Copyright (c) 2016 Beniamin Jonatan Šimko
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
namespace Phuria\SQLBuilder\Parameter;
13
14
/**
15
 * @author Beniamin Jonatan Šimko <[email protected]>
16
 */
17
class ParameterManager implements ParameterManagerInterface
18
{
19
    /**
20
     * @var QueryParameter[]
21
     */
22
    private $parameters = [];
23
24
    /**
25
     * @var array
26
     */
27
    private $references = [];
28
29
    /**
30
     * @var int
31
     */
32
    private $referenceCounter = 0;
33
34
    /**
35
     * @inheritdoc
36
     */
37
    public function createOrGetParameter($name)
38
    {
39
        if (false === array_key_exists($name, $this->parameters)) {
40
            $this->parameters[$name] = new QueryParameter($name);
41
        }
42
43
        return $this->parameters[$name];
44
    }
45
46
    /**
47
     * @return QueryParameter[]
48
     */
49
    public function toArray()
50
    {
51
        return $this->parameters;
52
    }
53
54
    /**
55
     * @param mixed $value
56
     *
57
     * @return string
58
     */
59 3
    public function createReference($value)
60
    {
61 3
        $ref = $this->generateNextReference();
62 3
        $this->references[$ref] = $value;
63
64 3
        return $ref;
65
    }
66
67
    /**
68
     * @return array
69
     */
70 4
    public function getReferences()
71
    {
72 4
        return $this->references;
73
    }
74
75
    /**
76
     * @return string
77
     */
78 3
    private function generateNextReference()
79
    {
80 3
        return sprintf('@[%d]', $this->referenceCounter++);
81
    }
82
}