1
<?php
2
/**
3
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
4
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
5
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
6
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
7
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
8
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
9
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
10
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
11
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
12
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
13
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
14
 *
15
 * This software consists of voluntary contributions made by many individuals
16
 * and is licensed under the LGPL. For more information please see
17
 * <http://phing.info>.
18
 */
19

20
/**
21
 * The factory to create fileParsers based on extension name from
22
 * PhingFile->getFileExtension()
23
 *
24
 * @author  Mike Lohmann <mike.lohmann@deck36.de>
25
 * @package phing.system.io
26
 */
27
class FileParserFactory implements FileParserFactoryInterface
28
{
29
    private const XML_FILE_EXTENSION = 'xml';
30
    /**
31
     * @const string
32
     */
33
    private const YAML_FILE_EXTENSION = 'yml';
34

35
    /**
36
     * @const string
37
     */
38
    private const YAML_FILE_EXTENSION_LONG = 'yaml';
39

40
    /**
41
     * {@inheritDoc}
42
     */
43 1
    public function createParser($fileExtension)
44
    {
45 1
        switch ($fileExtension) {
46
            case self::XML_FILE_EXTENSION:
47 0
                $fileParser = new XmlFileParser();
48 0
                break;
49
            case self::YAML_FILE_EXTENSION:
50
            case self::YAML_FILE_EXTENSION_LONG:
51 1
                $fileParser = new YamlFileParser();
52 1
                break;
53
            default:
54 1
                $fileParser = new IniFileParser();
55
        }
56

57 1
        return $fileParser;
58
    }
59
}

Read our documentation on viewing source code .

Loading