HOME


Mini Shell 1.0
DIR: /home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/classes/db/
Upload File :
Current File : /home/dhnidqcz/journal.pragmaticsng.org/lib__47455f6/pkp/classes/db/XMLDAO.php
<?php

/**
 * @file classes/db/XMLDAO.php
 *
 * Copyright (c) 2014-2021 Simon Fraser University
 * Copyright (c) 2000-2021 John Willinsky
 * Distributed under the GNU GPL v3. For full terms see the file docs/COPYING.
 *
 * @class XMLDAO
 *
 * @ingroup db
 *
 * @brief Operations for retrieving and modifying objects from an XML data source.
 */

namespace PKP\db;

use PKP\xml\PKPXMLParser;

class XMLDAO
{
    /**
     * Parse an XML file and return data in an object.
     *
     * @see PKPXMLParser::parse()
     *
     * @param string $file
     */
    public function parse($file)
    {
        $parser = new PKPXMLParser();
        return $parser->parse($file);
    }

    /**
     * Parse an XML file with the specified handler and return data in an object.
     *
     * @see PKPXMLParser::parse()
     *
     * @param string $file
     * @param \PKP\xml\XMLParserDOMHandler $handler reference to the handler to use with the parser.
     */
    public function parseWithHandler($file, $handler)
    {
        $parser = new PKPXMLParser();
        $parser->setHandler($handler);
        return $parser->parse($file);
    }

    /**
     * Parse an XML file and return data in an array.
     *
     * @see PKPXMLParser::parseStruct()
     *
     * @param string $file
     * @param array $tagsToMatch
     *
     * @return array|null
     */
    public function parseStruct($file, $tagsToMatch = [])
    {
        $parser = new PKPXMLParser();
        return $parser->parseStruct($file, $tagsToMatch);
    }
}

if (!PKP_STRICT_MODE) {
    class_alias('\PKP\db\XMLDAO', '\XMLDAO');
}