1
0
mirror of https://github.com/danog/PHP-Parser.git synced 2024-12-02 17:28:27 +01:00
PHP-Parser/lib/PhpParser/Parser/Multiple.php

64 lines
1.8 KiB
PHP
Raw Normal View History

2015-06-13 13:30:20 +02:00
<?php
namespace PhpParser\Parser;
use PhpParser\Error;
use PhpParser\Parser;
2015-06-13 13:30:20 +02:00
class Multiple implements Parser {
/** @var Parser[] List of parsers to try, in order of preference */
2015-06-13 13:30:20 +02:00
private $parsers;
/** @var Error[] Errors collected during last parse */
private $errors;
/**
* Create a parser which will try multiple parsers in an order of preference.
*
2015-07-12 22:00:02 +02:00
* Parsers will be invoked in the order they're provided to the constructor. If one of the
* parsers runs without errors, it's output is returned. Otherwise the errors (and
* PhpParser\Error exception) of the first parser are used.
2015-06-13 13:30:20 +02:00
*
* @param Parser[] $parsers
2015-06-13 13:30:20 +02:00
*/
public function __construct(array $parsers) {
$this->parsers = $parsers;
$this->errors = [];
}
public function parse($code) {
list($firstStmts, $firstErrors, $firstError) = $this->tryParse($this->parsers[0], $code);
if ($firstErrors === []) {
$this->errors = [];
return $firstStmts;
}
for ($i = 1, $c = count($this->parsers); $i < $c; ++$i) {
list($stmts, $errors) = $this->tryParse($this->parsers[$i], $code);
if ($errors === []) {
$this->errors = [];
return $stmts;
}
}
$this->errors = $firstErrors;
if ($firstError) {
throw $firstError;
}
return $firstStmts;
}
public function getErrors() {
return $this->errors;
}
private function tryParse(Parser $parser, $code) {
2015-06-13 13:30:20 +02:00
$stmts = null;
$error = null;
try {
$stmts = $parser->parse($code);
} catch (Error $error) {}
$errors = $parser->getErrors();
return [$stmts, $errors, $error];
}
}