Completed
Push — master ( bf07e5...f61ec4 )
by Beniamin
02:20
created

ParameterManager::bindStatement()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 6
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 5
CRAP Score 2

Importance

Changes 0
Metric Value
dl 0
loc 6
c 0
b 0
f 0
ccs 5
cts 5
cp 1
rs 9.4285
cc 2
eloc 3
nc 2
nop 1
crap 2
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
use Phuria\SQLBuilder\Statement\StatementInterface;
15
16
/**
17
 * @author Beniamin Jonatan Šimko <[email protected]>
18
 */
19
class ParameterManager implements ParameterManagerInterface
20
{
21
    /**
22
     * @var QueryParameter[]
23
     */
24
    private $parameters = [];
25
26
    /**
27
     * @var array
28
     */
29
    private $references = [];
30
31
    /**
32
     * @var int
33
     */
34
    private $referenceCounter = 0;
35
36
    /**
37
     * @inheritdoc
38
     */
39 3
    public function createOrGetParameter($name)
40
    {
41 3
        if (false === array_key_exists($name, $this->parameters)) {
42 3
            $this->parameters[$name] = new QueryParameter($name);
43 3
        }
44
45 3
        return $this->parameters[$name];
46
    }
47
48
    /**
49
     * @inheritdoc
50
     */
51 4
    public function bindStatement(StatementInterface $stmt)
52
    {
53 4
        foreach ($this->parameters as $param) {
54 3
            $stmt->bindValue($param->getName(), $param->getValue());
55 4
        }
56 4
    }
57
58
    /**
59
     * @param mixed $value
60
     *
61
     * @return string
62
     */
63 24
    public function createReference($value)
64
    {
65 24
        $ref = $this->generateNextReference();
66 24
        $this->references[$ref] = $value;
67
68 24
        return $ref;
69
    }
70
71
    /**
72
     * @return array
73
     */
74 34
    public function getReferences()
75
    {
76 34
        return $this->references;
77
    }
78
79
    /**
80
     * @return string
81
     */
82 24
    private function generateNextReference()
83
    {
84 24
        return sprintf('@[%d]', $this->referenceCounter++);
85
    }
86
}