Passed
Push — master ( 26e0e4...4a85b9 )
by Peter
10:37
created

Participant   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 44
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 17
dl 0
loc 44
rs 10
c 0
b 0
f 0
wmc 3

3 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 6 1
A toDOMElement() 0 8 1
A getElementTag() 0 3 1
1
<?php
2
3
/**
4
 * The MIT License
5
 *
6
 * Copyright 2018  Peter Gee <https://github.com/pgee70>.
7
 *
8
 * Permission is hereby granted, free of charge, to any person obtaining a copy
9
 * of this software and associated documentation files (the "Software"), to deal
10
 * in the Software without restriction, including without limitation the rights
11
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
12
 * copies of the Software, and to permit persons to whom the Software is
13
 * furnished to do so, subject to the following conditions:
14
 *
15
 * The above copyright notice and this permission notice shall be included in
16
 * all copies or substantial portions of the Software.
17
 *
18
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20
 * FITNESS FOR A PARTICULAR PURPOSE AND NON INFRINGEMENT. IN NO EVENT SHALL THE
21
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
23
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
24
 * THE SOFTWARE.
25
 */
26
27
/**
28
 *
29
 * @package     i3Soft\CDA
30
 * @author      Peter Gee <https://github.com/pgee70>
31
 * @link        https://github.com/pgee70/cda
32
 *
33
 */
34
35
36
namespace i3Soft\CDA\RIM\Participation;
37
38
39
use i3Soft\CDA\Elements\AbstractElement;
40
use i3Soft\CDA\Interfaces\TypeCodeInterface;
41
use i3Soft\CDA\RIM\Role\ParticipantRole;
42
use i3Soft\CDA\Traits\AwarenessCodeTrait;
43
use i3Soft\CDA\Traits\ContextControlCodeTrait;
44
use i3Soft\CDA\Traits\ParticipantRoleTrait;
45
use i3Soft\CDA\Traits\TimeTrait;
46
use i3Soft\CDA\Traits\TypeCodeTrait;
47
48
/**
49
 * Class Participant
50
 *
51
 * @package i3Soft\CDA\Elements
52
 */
53
class Participant extends AbstractElement implements TypeCodeInterface
54
{
55
    use AwarenessCodeTrait;
56
    use ContextControlCodeTrait;
57
    use ParticipantRoleTrait;
58
    use TimeTrait;
59
    use TypeCodeTrait;
60
61
62
    public function __construct(ParticipantRole $participant_role)
63
    {
64
        $this->setAcceptableTypeCodes(['', TypeCodeInterface::CAUSATIVE_AGENT])
65
          ->setTypeCode(TypeCodeInterface::CAUSATIVE_AGENT)
66
          ->setContextControlCode('OP')
67
          ->setParticipantRole($participant_role);
68
    }
69
70
    /**
71
     * Transforms the element into a DOMElement, which will be included
72
     * into the final CDA XML
73
     *
74
     * @param \DOMDocument $doc
75
     *
76
     * @return \DOMElement
77
     */
78
    public function toDOMElement(\DOMDocument $doc): \DOMElement
79
    {
80
        $el = $this->createElement($doc);
81
        $this->renderContextControlCode($el, $doc)
0 ignored issues
show
Unused Code introduced by
The call to i3Soft\CDA\RIM\Participa...derContextControlCode() has too many arguments starting with $doc. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

81
        $this->/** @scrutinizer ignore-call */ 
82
               renderContextControlCode($el, $doc)

This check compares calls to functions or methods with their respective definitions. If the call has more arguments than are defined, it raises an issue.

If a function is defined several times with a different number of parameters, the check may pick up the wrong definition and report false positives. One codebase where this has been known to happen is Wordpress. Please note the @ignore annotation hint above.

Loading history...
82
          ->renderTime($el, $doc)
83
          ->renderAwarenessCode($el, $doc)
84
          ->renderParticipantRole($el, $doc);
85
        return $el;
86
    }
87
88
89
    /**
90
     * get the element tag name
91
     *
92
     * @return string
93
     */
94
    protected function getElementTag(): string
95
    {
96
        return 'participant';
97
    }
98
99
100
}