Completed
Push — master ( eae939...155019 )
by Yo
02:20
created

ClassHeaderProcessor::getCallingClassName()   B

Complexity

Conditions 7
Paths 10

Size

Total Lines 20
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
c 0
b 0
f 0
dl 0
loc 20
rs 8.2222
cc 7
eloc 14
nc 10
nop 0
1
<?php
2
namespace Yoanm\Behat3SymfonyExtension\Logger\Processor;
3
4
use Monolog\Logger;
5
6
/**
7
 * Will automatically add header with the calling class name
8
 * @codeCoverageIgnore
9
 */
10
class ClassHeaderProcessor
11
{
12
    /**
13
     * @param  array $record
14
     * @return array
15
     */
16
    public function __invoke(array $record)
17
    {
18
        $record['message'] = sprintf(
19
            '[%s] %s',
20
            $this->getCallingClassName(),
21
            $record['message']
22
        );
23
24
        return $record;
25
    }
26
27
    /**
28
     * @return string|null
29
     */
30
    private function getCallingClassName()
31
    {
32
        $trace = debug_backtrace();
33
        $loggerFound = false;
34
        $classIndex = 2;
35
        foreach ($trace as $index => $traceData) {
36
            if (true === $loggerFound) {
37
                if (!isset($traceData['class']) || Logger::class !== $traceData['class']) {
38
                    $classIndex = $index;
39
                    break;
40
                }
41
            } else {
42
                $loggerFound = isset($traceData['class']) && Logger::class == $traceData['class'];
43
            }
44
        }
45
46
        return isset($trace[$classIndex]['class'])
47
            ? preg_replace('#(?:[^\\\]+\\\)#', '', $trace[$classIndex]['class'])
48
            : null;
49
    }
50
}
51