Completed
Push — master ( eeabde...efa6a6 )
by Beniamin
02:56
created

SelectQueryCompiler   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 39
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 4

Test Coverage

Coverage 100%

Importance

Changes 9
Bugs 0 Features 5
Metric Value
wmc 4
c 9
b 0
f 5
lcom 0
cbo 4
dl 0
loc 39
ccs 21
cts 21
cp 1
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A canHandleQuery() 0 4 1
B compile() 0 25 3
1
<?php
2
3
namespace Phuria\QueryBuilder\QueryCompiler;
4
5
use Phuria\QueryBuilder\QueryBuilder;
6
use Phuria\QueryBuilder\QueryClauses;
7
use Phuria\QueryBuilder\Table\AbstractTable;
8
9
/**
10
 * @author Beniamin Jonatan Šimko <[email protected]>
11
 */
12
class SelectQueryCompiler implements QueryCompilerInterface
13
{
14
    /**
15
     * @inheritdoc
16
     */
17 21
    public function canHandleQuery(QueryBuilder $qb)
18
    {
19 21
        return QueryClauses::QUERY_SELECT === $qb->getQueryClauses()->guessQueryType();
20
    }
21
22
    /**
23
     * @inheritdoc
24
     */
25 20
    public function compile(QueryBuilder $qb)
26
    {
27 20
        $clauses = $qb->getQueryClauses();
28
29 20
        $rawSql = implode(' ', array_filter([
30 20
            $clauses->getRawSelectClause(),
31 20
            $clauses->getRawFromClause(),
32 20
            $clauses->getRawJoinClause(),
33 20
            $clauses->getRawWhereClause(),
34 20
            $clauses->getRawGroupByClause(),
35 20
            $clauses->getRawHavingClause(),
36 20
            $clauses->getRawOrderByClause(),
37 20
            $clauses->getRawLimitClause()
38 20
        ]));
39
40 20
        $references = $qb->getReferenceManager()->all();
41
42 20
        foreach ($references as &$value) {
43 12
            if ($value instanceof AbstractTable) {
44 12
                $value = $value->getAliasOrName();
45 12
            }
46 20
        }
47
48 20
        return str_replace(array_keys($references), array_values($references), $rawSql);
49
    }
50
}