Passed
Pull Request — master (#2215)
by Arnaud
08:31 queued 03:40
created

Load::process()   D

Complexity

Conditions 18
Paths 108

Size

Total Lines 66
Code Lines 44

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 30
CRAP Score 31.6311

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 18
eloc 44
c 1
b 0
f 0
nc 108
nop 0
dl 0
loc 66
ccs 30
cts 46
cp 0.6522
crap 31.6311
rs 4.8

How to fix   Long Method    Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
3
/**
4
 * This file is part of Cecil.
5
 *
6
 * (c) Arnaud Ligny <[email protected]>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
declare(strict_types=1);
13
14
namespace Cecil\Step\Pages;
15
16
use Cecil\Step\AbstractStep;
17
use Cecil\Util;
18
use Symfony\Component\Finder\Finder;
19
use Symfony\Component\Finder\SplFileInfo;
20
21
/**
22
 * Load pages step.
23
 *
24
 * This step is responsible for loading pages from the configured pages directory.
25
 * It initializes the pages finder, applies sorting, and filters based on the
26
 * specified page or the default configuration. It also handles exclusions and
27
 * respects the `.gitignore` file if present. The loaded pages are then set in
28
 * the builder for further processing.
29
 */
30
class Load extends AbstractStep
31
{
32
    /** @var string */
33
    protected $page;
34
35
    /**
36
     * {@inheritdoc}
37
     */
38 1
    public function getName(): string
39
    {
40 1
        return 'Loading pages';
41
    }
42
43
    /**
44
     * {@inheritdoc}
45
     */
46 1
    public function init(array $options): void
47
    {
48 1
        if (!is_dir($this->config->getPagesPath())) {
49
            $this->builder->getLogger()->debug(\sprintf('"%s" is not a valid pages directory', $this->config->getPagesPath()));
50
            $this->canProcess = false;
51
52
            return;
53
        }
54
55 1
        $this->page = $options['page'];
56 1
        $this->canProcess = true;
57
    }
58
59
    /**
60
     * {@inheritdoc}
61
     */
62 1
    public function process(): void
63
    {
64 1
        $namePattern = '/\.(' . implode('|', (array) $this->config->get('pages.ext')) . ')$/';
65 1
        $pages = Finder::create()
66 1
            ->files()
67 1
            ->in($this->config->getPagesPath())
68 1
            ->sort(function (SplFileInfo $a, SplFileInfo $b): int {
69
                // root pages first
70 1
                if (empty($a->getRelativePath()) && !empty($b->getRelativePath())) {
71 1
                    return -1;
72
                }
73 1
                if (empty($b->getRelativePath()) && !empty($a->getRelativePath())) {
74 1
                    return 1;
75
                }
76
                // section's index first
77 1
                if ($a->getRelativePath() == $b->getRelativePath() && in_array(strtolower($a->getFilenameWithoutExtension()), ['index', 'readme'])) {
78 1
                    return -1;
79
                }
80 1
                if ($b->getRelativePath() == $a->getRelativePath() && in_array(strtolower($b->getFilenameWithoutExtension()), ['index', 'readme'])) {
81 1
                    return 1;
82
                }
83
                // sort by name
84 1
                return strnatcasecmp($a->getRelativePath(), $b->getRelativePath());
85 1
            });
86
        // load only one page?
87 1
        if ($this->page) {
88
            // is the page path starts with the `pages.dir` configuration option?
89
            // (i.e.: `pages/...`, `/pages/...`, `./pages/...`)
90
            $pagePathAsArray = explode(DIRECTORY_SEPARATOR, Util::joinFile($this->page));
91
            if ($pagePathAsArray[0] == (string) $this->config->get('pages.dir')) {
92
                unset($pagePathAsArray[0]);
93
                $this->page = implode(DIRECTORY_SEPARATOR, $pagePathAsArray);
94
            }
95
            if ($pagePathAsArray[0] == '.' && $pagePathAsArray[1] == (string) $this->config->get('pages.dir')) {
96
                unset($pagePathAsArray[0]);
97
                unset($pagePathAsArray[1]);
98
                $this->page = implode(DIRECTORY_SEPARATOR, $pagePathAsArray);
99
            }
100
            if (!util\File::getFS()->exists(Util::joinFile($this->config->getPagesPath(), $this->page))) {
101
                $this->builder->getLogger()->error(\sprintf('File "%s" doesn\'t exist.', $this->page));
102
            }
103
            $pages->path('.')->path(\dirname($this->page));
104
            $pages->name('/index\.(' . implode('|', (array) $this->config->get('pages.ext')) . ')$/');
105
            $namePattern = basename($this->page);
106
        }
107 1
        $pages->name($namePattern);
108 1
        if (\is_array($exclude = $this->config->get('pages.exclude'))) {
109 1
            $pages->exclude($exclude);
110 1
            $pages->notPath($exclude);
111 1
            $pages->notName($exclude);
112
        }
113 1
        if (file_exists(Util::joinFile($this->config->getPagesPath(), '.gitignore'))) {
114
            $pages->ignoreVCSIgnored(true);
115
        }
116 1
        $this->builder->setPagesFiles($pages);
117
118 1
        $total = $pages->count();
119 1
        $count = 0;
120 1
        if ($total === 0) {
121
            $this->builder->getLogger()->info('Nothing to load');
122
123
            return;
124
        }
125 1
        foreach ($pages as $file) {
126 1
            $count++;
127 1
            $this->builder->getLogger()->info(\sprintf('File "%s" loaded', $file->getRelativePathname()), ['progress' => [$count, $total]]);
128
        }
129
    }
130
}
131