Quoter   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 20
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 2
Bugs 0 Features 0
Metric Value
eloc 8
c 2
b 0
f 0
dl 0
loc 20
ccs 9
cts 9
cp 1
rs 10
wmc 4

2 Methods

Rating   Name   Duplication   Size   Complexity  
A quoteColumnName() 0 7 2
A getTableNameParts() 0 9 2
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Yiisoft\Db\Mssql;
6
7
use Yiisoft\Db\Schema\Quoter as BaseQuoter;
8
9
use function preg_match;
10
use function preg_match_all;
11
12
/**
13
 * Implements the MSSQL Server quoting and unquoting methods.
14
 */
15
final class Quoter extends BaseQuoter
16
{
17 581
    public function quoteColumnName(string $name): string
18
    {
19 581
        if (preg_match('/^\[.*]$/', $name)) {
20 9
            return $name;
21
        }
22
23 579
        return parent::quoteColumnName($name);
24
    }
25
26 591
    public function getTableNameParts(string $name, bool $withColumn = false): array
27
    {
28 591
        if (preg_match_all('/([^.\[\]]+)|\[([^\[\]]+)]/', $name, $matches) > 0) {
29 589
            $parts = array_slice($matches[0], -4, 4);
30
        } else {
31 2
            $parts = [$name];
32
        }
33
34 591
        return $this->unquoteParts($parts, $withColumn);
35
    }
36
}
37