Completed
Push — master ( 8e394d...79f3c8 )
by Beniamin
02:56
created

AbstractBuilder::getReferences()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 0
Metric Value
dl 0
loc 4
ccs 2
cts 2
cp 1
rs 10
c 0
b 0
f 0
cc 1
eloc 2
nc 1
nop 0
crap 1
1
<?php
2
3
/**
4
 * This file is part of UnderQuery 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\UnderQuery\QueryBuilder;
13
14
use Phuria\UnderQuery\Parameter\ParameterCollection;
15
use Phuria\UnderQuery\Parameter\ParameterCollectionInterface;
16
use Phuria\UnderQuery\Query\Query;
17
use Phuria\UnderQuery\Reference\ReferenceCollection;
18
use Phuria\UnderQuery\Reference\ReferenceCollectionInterface;
19
use Phuria\UnderQuery\Table\AbstractTable;
20
21
/**
22
 * @author Beniamin Jonatan Šimko <[email protected]>
23
 */
24
abstract class AbstractBuilder implements BuilderInterface
25
{
26
    /**
27
     * @var QueryBuilderFacade
28
     */
29
    private $facade;
30
31
    /**
32
     * @var ReferenceCollectionInterface
33
     */
34
    private $referenceCollection;
35
36
    /**
37
     * @var ParameterCollectionInterface
38
     */
39
    private $parameterCollection;
40
41
    /**
42
     * @var AbstractTable[] $tables
43
     */
44
    private $rootTables = [];
45
46
    /**
47
     * @param QueryBuilderFacade $facade
48
     */
49 8
    public function __construct(QueryBuilderFacade $facade)
50
    {
51 8
        $this->facade = $facade;
52 8
        $this->parameterCollection = new ParameterCollection();
53 8
        $this->referenceCollection = new ReferenceCollection();
54 8
    }
55
56
    /**
57
     * @return BuilderInterface
58
     */
59 1
    public function getQueryBuilder()
60
    {
61 1
        return $this;
62
    }
63
64
    /**
65
     * @return ParameterCollectionInterface
66
     */
67 2
    public function getParameters()
68
    {
69 2
        return $this->parameterCollection;
70
    }
71
72
    /**
73
     * @return ReferenceCollectionInterface
74
     */
75 4
    public function getReferences()
76
    {
77 4
        return $this->referenceCollection;
78
    }
79
80
    /**
81
     * @param mixed  $table
82
     * @param string $alias
0 ignored issues
show
Documentation introduced by
Should the type for parameter $alias not be string|null?

This check looks for @param annotations where the type inferred by our type inference engine differs from the declared type.

It makes a suggestion as to what type it considers more descriptive.

Most often this is a case of a parameter that can be null in addition to its declared types.

Loading history...
83
     *
84
     * @return AbstractTable
85
     */
86 2
    public function addRootTable($table, $alias = null)
87
    {
88 2
        $this->rootTables[] = $table = $this->createTable($table, $alias);
89
90 1
        return $table;
91
    }
92
93
    /**
94
     * @return AbstractTable[]
95
     */
96 3
    public function getRootTables()
97
    {
98 3
        return $this->rootTables;
99
    }
100
101
    /**
102
     * @param mixed       $table
103
     * @param string|null $alias
104
     *
105
     * @return AbstractTable
106
     */
107 2
    public function createTable($table, $alias = null)
108
    {
109 2
        $tableObject = $this->facade->createTable($this, $table);
110
111 2
        if ($alias) {
0 ignored issues
show
Bug Best Practice introduced by
The expression $alias of type string|null is loosely compared to true; this is ambiguous if the string can be empty. You might want to explicitly use !== null instead.

In PHP, under loose comparison (like ==, or !=, or switch conditions), values of different types might be equal.

For string values, the empty string '' is a special case, in particular the following results might be unexpected:

''   == false // true
''   == null  // true
'ab' == false // false
'ab' == null  // false

// It is often better to use strict comparison
'' === false // false
'' === null  // false
Loading history...
112 1
            $tableObject->setAlias($alias);
113 1
        }
114
115 2
        if (is_callable($table)) {
116 1
            $table($tableObject);
117
        }
118
119 1
        return $tableObject;
120
    }
121
122
    /**
123
     * @inheritdoc
124
     */
125 1
    public function objectToString($object)
126
    {
127 1
        return $this->getReferences()->createReference($object);
128
    }
129
130
    /**
131
     * @inheritdoc
132
     */
133 1
    public function setParameter($name, $value)
134
    {
135 1
        $parameter = $this->getParameters()->getParameter($name);
136 1
        $parameter->setValue($value);
137
138 1
        return $this;
139
    }
140
141
    /**
142
     * @return Query
143
     */
144 1
    public function buildQuery()
145
    {
146 1
        return new Query(
147 1
            $this->buildSQL(),
148 1
            $this->parameterCollection->toArray(),
149 1
            $this->facade->getConnection()
150 1
        );
151
    }
152
153
    /**
154
     * @inheritdoc
155
     */
156 2
    public function buildSQL()
157
    {
158 2
        return $this->facade->buildSQL($this);
159
    }
160
}