Passed
Push — master ( 127e3c...a9335c )
by Siad
06:34
created

LogLevelAware::setLevel()   B

Complexity

Conditions 6
Paths 6

Size

Total Lines 26
Code Lines 24

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 23
CRAP Score 6

Importance

Changes 2
Bugs 0 Features 0
Metric Value
cc 6
eloc 24
c 2
b 0
f 0
nc 6
nop 1
dl 0
loc 26
ccs 23
cts 23
cp 1
crap 6
rs 8.9137
1
<?php
2
/**
3
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
4
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
5
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
6
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
7
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
8
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
9
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
10
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
11
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
12
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
13
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
14
 *
15
 * This software consists of voluntary contributions made by many individuals
16
 * and is licensed under the LGPL. For more information please see
17
 * <http://phing.info>.
18
 */
19
20
21
/**
22
 * @author   Siad Ardroumli <[email protected]>
23
 * @package  phing.tasks.system
24
 */
25
trait LogLevelAware
26
{
27
    protected $logLevel = Project::MSG_VERBOSE;
28
    protected $logLevelName = 'verbose';
29
30
    /**
31
     * Set level of log messages generated (default = verbose)
32
     *
33
     * @param string $level
34
     */
35 15
    public function setLevel($level): void
36
    {
37
        switch ($level) {
38 15
            case 'error':
39 1
                $this->logLevel = Project::MSG_ERR;
40 1
                $this->logLevelName = 'error';
41 1
                break;
42 14
            case 'warning':
43 1
                $this->logLevel = Project::MSG_WARN;
44 1
                $this->logLevelName = 'warning';
45 1
                break;
46 13
            case 'info':
47 9
                $this->logLevel = Project::MSG_INFO;
48 9
                $this->logLevelName = 'info';
49 9
                break;
50 4
            case 'verbose':
51 1
                $this->logLevel = Project::MSG_VERBOSE;
52 1
                $this->logLevelName = 'verbose';
53 1
                break;
54 3
            case 'debug':
55 2
                $this->logLevel = Project::MSG_DEBUG;
56 2
                $this->logLevelName = 'debug';
57 2
                break;
58
            default:
59 1
                throw new BuildException(
60 1
                    sprintf('Unknown log level "%s"', $level)
61
                );
62
        }
63 14
    }
64
}
65