FileBuilder   A
last analyzed

Complexity

Total Complexity 3

Size/Duplication

Total Lines 32
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
dl 0
loc 32
rs 10
c 0
b 0
f 0
wmc 3

3 Methods

Rating   Name   Duplication   Size   Complexity  
A getElement() 0 2 1
A __construct() 0 5 1
A getFile() 0 2 1
1
<?php
2
/**
3
 * @copyright Copyright (c) 2017 Julius Härtl <[email protected]>
4
 *
5
 * @author Julius Härtl <[email protected]>
6
 *
7
 * @license GNU AGPL version 3 or any later version
8
 *
9
 *  This program is free software: you can redistribute it and/or modify
10
 *  it under the terms of the GNU Affero General Public License as
11
 *  published by the Free Software Foundation, either version 3 of the
12
 *  License, or (at your option) any later version.
13
 *
14
 *  This program is distributed in the hope that it will be useful,
15
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 *  GNU Affero General Public License for more details.
18
 *
19
 *  You should have received a copy of the GNU Affero General Public License
20
 *  along with this program. If not, see <http://www.gnu.org/licenses/>.
21
 *
22
 */
23
24
namespace JuliusHaertl\PHPDocToRst\Builder;
25
26
use JuliusHaertl\PHPDocToRst\Extension\Extension;
27
use phpDocumentor\Reflection\Element;
28
use phpDocumentor\Reflection\Php\File;
29
30
/**
31
 * Abstract building class to build sphinxcontrib-phpdomain from a php file
32
 *
33
 * @package JuliusHaertl\PHPDocToRst\Builder
34
 */
35
abstract class FileBuilder extends PhpDomainBuilder {
36
37
    /** @var File */
38
    protected $file;
39
40
    /** @var Element */
41
    protected $element;
42
43
    /** @var Extension[] */
44
    protected $extensions = [];
45
46
    protected abstract function render();
47
48
    public function __construct($file, $element, $extensions) {
49
        parent::__construct($extensions);
50
        $this->file = $file;
51
        $this->element = $element;
52
        $this->render();
53
    }
54
55
    /**
56
     * @return Element that is used to build the rst file
57
     */
58
    public function getElement() {
59
        return $this->element;
60
    }
61
62
    /**
63
     * @return File
64
     */
65
    public function getFile() {
66
        return $this->file;
67
    }
68
69
}