GitHub Access Token became invalid

It seems like the GitHub access token used for retrieving details about this repository from GitHub became invalid. This might prevent certain types of inspections from being run (in particular, everything related to pull requests).
Please ask an admin of your repository to re-new the access token on this website.

AbstractFile::createFile()   A
last analyzed

Complexity

Conditions 3
Paths 4

Size

Total Lines 11
Code Lines 5

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 3
eloc 5
nc 4
nop 1
dl 0
loc 11
rs 10
c 0
b 0
f 0
1
<?php
2
/**
3
 * This file is part of the O2System Framework package.
4
 *
5
 * For the full copyright and license information, please view the LICENSE
6
 * file that was distributed with this source code.
7
 *
8
 * @author         Steeve Andrian Salim
9
 * @copyright      Copyright (c) Steeve Andrian Salim
10
 */
11
12
// ------------------------------------------------------------------------
13
14
namespace O2System\Filesystem\Files\Abstracts;
15
16
// ------------------------------------------------------------------------
17
18
use O2System\Spl\Patterns\Structural\Repository\AbstractRepository;
19
20
/**
21
 * Class AbstractFile
22
 *
23
 * @package O2System\Filesystem\Files\Abstracts
24
 */
25
abstract class AbstractFile extends AbstractRepository
26
{
27
    /**
28
     * AbstractFile::$fileExtension
29
     *
30
     * @var string
31
     */
32
    protected $fileExtension;
33
34
    /**
35
     * AbstractFile::$filePath
36
     *
37
     * @var string
38
     */
39
    protected $filePath;
40
41
    // ------------------------------------------------------------------------
42
43
    /**
44
     * AbstractFile::__construct
45
     *
46
     * @param string|null $filePath Path to the file.
47
     */
48
    final public function __construct($filePath = null)
49
    {
50
        if (isset($filePath)) {
51
            $this->filePath = $filePath;
52
        }
53
    }
54
55
    // ------------------------------------------------------------------------
56
57
    /**
58
     * AbstractFile::createFile
59
     *
60
     * @param string $filePath Path to the file.
61
     *
62
     * @return static
63
     */
64
    final public function createFile($filePath = null)
65
    {
66
        if (isset($filePath)) {
67
            $this->filePath = $filePath;
68
        }
69
70
        if (pathinfo($this->filePath, PATHINFO_EXTENSION) === '') {
71
            $this->filePath .= $this->fileExtension;
72
        }
73
74
        return $this;
75
    }
76
77
    // ------------------------------------------------------------------------
78
79
    /**
80
     * AbstractFile::readFile
81
     *
82
     * @param string $filePath Path to the file.
83
     * @param array  $options  Read file options.
84
     *
85
     * @return mixed
86
     */
87
    abstract public function readFile($filePath = null, array $options = []);
88
89
    // ------------------------------------------------------------------------
90
91
    /**
92
     * AbstractFile::writeFile
93
     *
94
     * @param string $filePath Path to the file.
95
     * @param array  $options  Write file options.
96
     *
97
     * @return bool Returns TRUE on success or FALSE on failure.
98
     */
99
    abstract public function writeFile($filePath = null, array $options = []);
100
}