12 * Creates a Parser instance, according to the provided kind.
14 * @param int $kind One of ::PREFER_PHP7, ::PREFER_PHP5, ::ONLY_PHP7 or ::ONLY_PHP5
15 * @param Lexer|null $lexer Lexer to use. Defaults to emulative lexer when not specified
16 * @param array $parserOptions Parser options. See ParserAbstract::__construct() argument
18 * @return Parser The parser instance
20 public function create($kind, Lexer $lexer = null, array $parserOptions = array()) {
21 if (null === $lexer) {
22 $lexer = new Lexer\Emulative();
25 case self::PREFER_PHP7:
26 return new Parser\Multiple([
27 new Parser\Php7($lexer, $parserOptions), new Parser\Php5($lexer, $parserOptions)
29 case self::PREFER_PHP5:
30 return new Parser\Multiple([
31 new Parser\Php5($lexer, $parserOptions), new Parser\Php7($lexer, $parserOptions)
34 return new Parser\Php7($lexer, $parserOptions);
36 return new Parser\Php5($lexer, $parserOptions);
38 throw new \LogicException(
39 'Kind must be one of ::PREFER_PHP7, ::PREFER_PHP5, ::ONLY_PHP7 or ::ONLY_PHP5'