Completed
Push — 0.3.x ( e294c0...140210 )
by Marko
04:05
created

ShaderAbstract::removeDefaultDOMAttributes()   B

Complexity

Conditions 5
Paths 4

Size

Total Lines 14
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 9
CRAP Score 5

Importance

Changes 6
Bugs 1 Features 0
Metric Value
c 6
b 1
f 0
dl 0
loc 14
ccs 9
cts 9
cp 1
rs 8.8571
cc 5
eloc 8
nc 4
nop 0
crap 5
1
<?php
2
/** @formatter:off
3
 * ******************************************************************
4
 * Created by   Marko Kungla on Jun 25, 2016 - 8:48:28 AM
5
 * Contact      [email protected]
6
 * @copyright   2016 Marko Kungla - https://github.com/mkungla
7
 * @license     The MIT License (MIT)
8
 * 
9
 * @category       AframeVR
10
 * @package        aframe-php
11
 * 
12
 * Lang         PHP (php version >= 7)
13
 * Encoding     UTF-8
14
 * File         ShaderAbstract.php
15
 * Code format  PSR-2 and 12
16
 * @link        https://github.com/mkungla/aframe-php
17
 * @issues      https://github.com/mkungla/aframe-php/issues
18
 * ********************************************************************
19
 * Contributors:
20
 * @author Marko Kungla <[email protected]>
21
 * ********************************************************************
22
 * Comments:
23
 * @formatter:on */
24
namespace AframeVR\Core\Helpers;
25
26
abstract class ShaderAbstract
27
{
28
29
    /**
30
     * Get default class vars
31
     *
32
     * @return array
33
     */
34 7
    protected function getShaderClassDefaultVars()
35
    {
36 7
        return get_class_vars(get_class($this));
37
    }
38
39
    /**
40
     * removeDefaultDOMAttributes
41
     *
42
     * @return void
43
     */
44 7
    public function removeDefaultDOMAttributes()
45
    {
46 7
        $defaults = $this->getShaderClassDefaultVars();
47 7
        $vars = get_object_vars($this);
0 ignored issues
show
Coding Style introduced by
Equals sign not aligned with surrounding assignments; expected 5 spaces but found 1 space

This check looks for multiple assignments in successive lines of code. It will report an issue if the operators are not in a straight line.

To visualize

$a = "a";
$ab = "ab";
$abc = "abc";

will produce issues in the first and second line, while this second example

$a   = "a";
$ab  = "ab";
$abc = "abc";

will produce no issues.

Loading history...
48
        
49 7
        foreach ($vars as $name => $value) {
50 7
            if ($name === 'shader')
51 7
                continue;
52
            
53 7
            if (empty($value) || $value === $defaults[$name]) {
54 7
                unset($this->$name);
55
            }
56
        }
57 7
    }
58
59 5
    public function getAttributes()
60
    {
61 5
        $this->removeDefaultDOMAttributes();
62 5
        return get_object_vars($this);
63
    }
64
}
65