Passed
Push — master ( 43e436...5667bd )
by Konrad
08:19
created

Pages   A

Complexity

Total Complexity 6

Size/Duplication

Total Lines 32
Duplicated Lines 0 %

Test Coverage

Coverage 85.71%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 6
eloc 14
c 1
b 0
f 0
dl 0
loc 32
ccs 12
cts 14
cp 0.8571
rs 10

1 Method

Rating   Name   Duplication   Size   Complexity  
A getPages() 0 25 6
1
<?php
2
3
/**
4
 * @file
5
 *          This file is part of the PdfParser library.
6
 *
7
 * @author  Sébastien MALOT <[email protected]>
8
 * @date    2017-01-03
9
 *
10
 * @license LGPLv3
11
 * @url     <https://github.com/smalot/pdfparser>
12
 *
13
 *  PdfParser is a pdf library written in PHP, extraction oriented.
14
 *  Copyright (C) 2017 - Sébastien MALOT <[email protected]>
15
 *
16
 *  This program is free software: you can redistribute it and/or modify
17
 *  it under the terms of the GNU Lesser General Public License as published by
18
 *  the Free Software Foundation, either version 3 of the License, or
19
 *  (at your option) any later version.
20
 *
21
 *  This program is distributed in the hope that it will be useful,
22
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
23
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
24
 *  GNU Lesser General Public License for more details.
25
 *
26
 *  You should have received a copy of the GNU Lesser General Public License
27
 *  along with this program.
28
 *  If not, see <http://www.pdfparser.org/sites/default/LICENSE.txt>.
29
 */
30
31
namespace Smalot\PdfParser;
32
33
use Smalot\PdfParser\Element\ElementArray;
34
35
/**
36
 * Class Pages
37
 */
38
class Pages extends PDFObject
39
{
40
    /**
41
     * @todo Objects other than Pages or Page might need to be treated specifically in order to get Page objects out of them,
42
     *
43
     * @see https://github.com/smalot/pdfparser/issues/331
44
     */
45 29
    public function getPages(bool $deep = false): array
46
    {
47 29
        if (!$this->has('Kids')) {
48
            return [];
49
        }
50
51
        /** @var ElementArray $kidsElement */
52 29
        $kidsElement = $this->get('Kids');
53
54 29
        if (!$deep) {
55
            return $kidsElement->getContent();
56
        }
57
58 29
        $kids = $kidsElement->getContent();
59 29
        $pages = [];
60
61 29
        foreach ($kids as $kid) {
62 29
            if ($kid instanceof self) {
63 2
                $pages = array_merge($pages, $kid->getPages(true));
64 29
            } elseif ($kid instanceof Page) {
65 29
                $pages[] = $kid;
66
            }
67
        }
68
69 29
        return $pages;
70
    }
71
}
72