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 PhpGedcom\Parser; |
||||||
16 | |||||||
17 | class SourRef extends \PhpGedcom\Parser\Component |
||||||
18 | { |
||||||
19 | public static function parse(\PhpGedcom\Parser $parser) |
||||||
20 | { |
||||||
21 | $record = $parser->getCurrentLineRecord(); |
||||||
22 | $depth = (int) $record[0]; |
||||||
23 | if (isset($record[2])) { |
||||||
24 | $sour = new \PhpGedcom\Record\SourRef(); |
||||||
25 | $sour->setSour($parser->normalizeIdentifier($record[2])); |
||||||
0 ignored issues
–
show
Bug
introduced
by
![]() |
|||||||
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 'PAGE': |
||||||
46 | $sour->setPage(trim($record[2])); |
||||||
0 ignored issues
–
show
The method
setPage() does not exist on PhpGedcom\Record\SourRef . 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
![]() |
|||||||
47 | break; |
||||||
48 | case 'EVEN': |
||||||
49 | $even = \PhpGedcom\Parser\SourRef\Even::parse($parser); |
||||||
50 | $sour->setEven($even); |
||||||
0 ignored issues
–
show
The method
setEven() does not exist on PhpGedcom\Record\SourRef . 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
![]() |
|||||||
51 | break; |
||||||
52 | case 'DATA': |
||||||
53 | $sour->setData(\PhpGedcom\Parser\SourRef\Data::parse($parser)); |
||||||
0 ignored issues
–
show
The method
setData() does not exist on PhpGedcom\Record\SourRef . 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
![]() |
|||||||
54 | break; |
||||||
55 | case 'TEXT': |
||||||
56 | $sour->setText($parser->parseMultiLineRecord()); |
||||||
0 ignored issues
–
show
The method
setText() does not exist on PhpGedcom\Record\SourRef . 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
![]() |
|||||||
57 | break; |
||||||
58 | case 'OBJE': |
||||||
59 | $obje = \PhpGedcom\Parser\ObjeRef::parse($parser); |
||||||
60 | if ($obje) { |
||||||
61 | $sour->addNote($obje); |
||||||
0 ignored issues
–
show
The method
addNote() does not exist on PhpGedcom\Record\SourRef . 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
![]() |
|||||||
62 | } |
||||||
63 | break; |
||||||
64 | case 'NOTE': |
||||||
65 | $note = \PhpGedcom\Parser\NoteRef::parse($parser); |
||||||
66 | if ($note) { |
||||||
67 | $sour->addNote($note); |
||||||
68 | } |
||||||
69 | break; |
||||||
70 | case 'QUAY': |
||||||
71 | $sour->setQuay(trim($record[2])); |
||||||
0 ignored issues
–
show
The method
setQuay() does not exist on PhpGedcom\Record\SourRef . 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
![]() |
|||||||
72 | break; |
||||||
73 | default: |
||||||
74 | $parser->logUnhandledRecord(get_class().' @ '.__LINE__); |
||||||
75 | } |
||||||
76 | |||||||
77 | $parser->forward(); |
||||||
78 | } |
||||||
79 | |||||||
80 | return $sour; |
||||||
81 | } |
||||||
82 | } |
||||||
83 |