Completed
Pull Request — master (#19)
by John
05:56 queued 03:42
created

FieldParserFactory::getFieldParser()   C

Complexity

Conditions 8
Paths 8

Size

Total Lines 35
Code Lines 25

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 35
rs 5.3846
c 0
b 0
f 0
cc 8
eloc 25
nc 8
nop 1
1
<?php
2
3
namespace Graze\CiffRenderer\Parser\FieldParser;
4
5
use Graze\CiffRenderer\Parser\FieldType;
6
use Graze\CiffRenderer\Parser\FieldParser\FieldParserFixedText;
7
use Graze\CiffRenderer\Parser\FieldParser\FieldParserBarcode;
8
use Graze\CiffRenderer\Parser\FieldParser\FieldParserDate\FieldParserDate;
9
use Graze\CiffRenderer\Parser\FieldParser\FieldParserDate\FieldParserDateOffset;
10
use Graze\CiffRenderer\Parser\FieldParser\FieldParserStaticGraphic;
11
use Graze\CiffRenderer\Parser\FieldParser\FieldParserGraphicPrimitive;
12
use Graze\CiffRenderer\Exception\UnsupportedFieldTypeException;
13
14
class FieldParserFactory
15
{
16
    /**
17
     * @param \SimpleXMLElement $xml
18
     * @return FieldParserInterface
19
     */
20
    public function getFieldParser(\SimpleXMLElement $xml)
21
    {
22
        switch ((string) $xml->FldType) { // @codingStandardsIgnoreLine
23
            case FieldType::FIELD_FIXED_TEXT:
24
            case FieldType::FIELD_MERGE_FIELD:
25
                $className = FieldParserFixedText::class;
26
                break;
27
28
            case FieldType::FIELD_BARCODE:
29
                $className = FieldParserBarcode::class;
30
                break;
31
32
            case FieldType::FIELD_DATE:
33
                $className = FieldParserDate::class;
34
                break;
35
36
            case FieldType::FIELD_OFFSET_DATE:
37
                $className = FieldParserDateOffset::class;
38
                break;
39
40
            case FieldType::FIELD_STATIC_GRAPHIC:
41
                $className = FieldParserStaticGraphic::class;
42
                break;
43
44
            case FieldType::FIELD_GRAPHIC_PRIMITIVE:
45
                $className = FieldParserGraphicPrimitive::class;
46
                break;
47
48
            default:
49
                throw new UnsupportedFieldTypeException($fieldType);
50
                break;
0 ignored issues
show
Unused Code introduced by
break; does not seem to be reachable.

This check looks for unreachable code. It uses sophisticated control flow analysis techniques to find statements which will never be executed.

Unreachable code is most often the result of return, die or exit statements that have been added for debug purposes.

function fx() {
    try {
        doSomething();
        return true;
    }
    catch (\Exception $e) {
        return false;
    }

    return false;
}

In the above example, the last return false will never be executed, because a return statement has already been met in every possible execution path.

Loading history...
51
        }
52
53
        return $className::factory();
54
    }
55
}
56