Test Failed
Pull Request — master (#614)
by
unknown
02:15
created

ElementStruct   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 32
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 16
c 1
b 0
f 0
dl 0
loc 32
ccs 16
cts 16
cp 1
rs 10
wmc 5
1
<?php
2
3
/**
4
 * @file
5
 *          This file is part of the PdfParser library.
6
 *
7
 * @author  Sébastien MALOT <[email protected]>
8
 *
9
 * @date    2017-01-03
10
 *
11
 * @license LGPLv3
12
 *
13
 * @url     <https://github.com/smalot/pdfparser>
14
 *
15
 *  PdfParser is a pdf library written in PHP, extraction oriented.
16
 *  Copyright (C) 2017 - Sébastien MALOT <[email protected]>
17
 *
18
 *  This program is free software: you can redistribute it and/or modify
19
 *  it under the terms of the GNU Lesser General Public License as published by
20
 *  the Free Software Foundation, either version 3 of the License, or
21
 *  (at your option) any later version.
22
 *
23
 *  This program is distributed in the hope that it will be useful,
24
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
25
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
26
 *  GNU Lesser General Public License for more details.
27
 *
28
 *  You should have received a copy of the GNU Lesser General Public License
29
 *  along with this program.
30
 *  If not, see <http://www.pdfparser.org/sites/default/LICENSE.txt>.
31
 */
32
33
namespace Smalot\PdfParser\Element;
34
35
use Smalot\PdfParser\Document;
36
use Smalot\PdfParser\Element;
37
use Smalot\PdfParser\Header;
38
39
/**
40
 * Class ElementStruct
41
 */
42
class ElementStruct extends Element
43
{
44
    /**
45
     * @return false|Header
46
     */
47 26
    public static function parse(string $content, Document $document = null, int &$offset = 0)
0 ignored issues
show
Bug introduced by
A parse error occurred: Syntax error, unexpected T_VARIABLE, expecting T_STRING or T_NAME_QUALIFIED or T_NAME_FULLY_QUALIFIED or T_NAME_RELATIVE on line 47 at column 82
Loading history...
48
    {
49 26
        if (preg_match('/^\s*<<(?P<struct>.*)/is', $content)) {
50 26
            preg_match_all('/(.*?)(<<|>>)/s', trim($content), $matches);
51
52 26
            $level = 0;
53 26
            $sub = '';
54 26
            foreach ($matches[0] as $part) {
55 26
                $sub .= $part;
56 26
                $level += (false !== strpos($part, '<<') ? 1 : -1);
57 26
                if ($level <= 0) {
58 26
                    break;
59
                }
60
            }
61
62 26
            $offset += strpos($content, '<<') + \strlen(rtrim($sub));
63
64
            // Removes '<<' and '>>'.
65 26
            $sub = trim((string) preg_replace('/^\s*<<(.*)>>\s*$/s', '\\1', $sub));
66
67 26
            $position = 0;
68 26
            $elements = Element::parse($sub, $document, $position);
69
70 26
            return new Header($elements, $document);
71
        }
72
73 18
        return false;
74
    }
75
}
76