Issues (384)

src/Parser/Head/Date.php (2 issues)

Labels
Severity
1
<?php
2
/**
3
 * php-gedcom.
4
 *
5
 * php-gedcom is a library for parsing, manipulating, importing and exporting
6
 * GEDCOM 5.5 files in PHP 5.3+.
7
 *
8
 * @author          Kristopher Wilson <[email protected]>
9
 * @copyright       Copyright (c) 2010-2013, Kristopher Wilson
10
 * @license         MIT
11
 *
12
 * @link            http://github.com/mrkrstphr/php-gedcom
13
 */
14
15
namespace Gedcom\Parser\Head;
16
17
class Date extends \Gedcom\Parser\Component
18
{
19
    public static function parse(\Gedcom\Parser $parser)
20
    {
21
        $record = $parser->getCurrentLineRecord();
22
        $depth = (int) $record[0];
23
        if (isset($record[2])) {
24
            $date = new \Gedcom\Record\Head\Date();
25
            $date->setDate(trim($record[2]));
0 ignored issues
show
The method setDate() does not exist on Gedcom\Record\Head\Date. Since you implemented __call, consider adding a @method annotation. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

25
            $date->/** @scrutinizer ignore-call */ 
26
                   setDate(trim($record[2]));
Loading history...
26
        } else {
27
            $parser->skipToNextLevel($depth);
28
29
            return null;
30
        }
31
32
        $parser->forward();
33
34
        while (!$parser->eof()) {
35
            $record = $parser->getCurrentLineRecord();
36
            $recordType = strtoupper(trim($record[1]));
37
            $currentDepth = (int) $record[0];
38
39
            if ($currentDepth <= $depth) {
40
                $parser->back();
41
                break;
42
            }
43
44
            switch ($recordType) {
45
                case 'TIME':
46
                    $date->setTime(trim($record[2]));
0 ignored issues
show
The method setTime() does not exist on Gedcom\Record\Head\Date. Since you implemented __call, consider adding a @method annotation. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

46
                    $date->/** @scrutinizer ignore-call */ 
47
                           setTime(trim($record[2]));
Loading history...
47
                    break;
48
                default:
49
                    $parser->logUnhandledRecord(self::class.' @ '.__LINE__);
50
            }
51
52
            $parser->forward();
53
        }
54
55
        return $date;
56
    }
57
}
58