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

ShaderAbstract   A

Complexity

Total Complexity 7

Size/Duplication

Total Lines 39
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 0

Test Coverage

Coverage 100%

Importance

Changes 9
Bugs 2 Features 0
Metric Value
wmc 7
c 9
b 2
f 0
lcom 0
cbo 0
dl 0
loc 39
ccs 14
cts 14
cp 1
rs 10

3 Methods

Rating   Name   Duplication   Size   Complexity  
A getShaderClassDefaultVars() 0 4 1
B removeDefaultDOMAttributes() 0 14 5
A getAttributes() 0 5 1
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