PHP-Parser/lib/PhpParser/ParserFactory.php

71 lines
2.5 KiB
PHP
Raw Normal View History

2017-08-18 22:57:27 +02:00
<?php declare(strict_types=1);
2015-06-20 11:28:58 +02:00
namespace PhpParser;
use PhpParser\Parser\Php7;
use PhpParser\Parser\Php8;
class ParserFactory {
public const PREFER_PHP7 = 1;
public const ONLY_PHP7 = 3;
2015-06-20 11:28:58 +02:00
/**
2015-07-12 22:53:04 +02:00
* Creates a Parser instance, according to the provided kind.
*
2022-06-06 16:45:02 +02:00
* @param int $kind One of ::PREFER_PHP7 or ::ONLY_PHP7
2015-07-12 22:53:04 +02:00
* @param Lexer|null $lexer Lexer to use. Defaults to emulative lexer when not specified
*
* @return Parser The parser instance
*
* @deprecated Use createForVersion(), createForNewestSupportedVersion() or createForHostVersion() instead.
2015-06-20 11:28:58 +02:00
*/
2022-07-23 16:35:21 +02:00
public function create(int $kind, ?Lexer $lexer = null): Parser {
2015-07-12 22:53:04 +02:00
if (null === $lexer) {
$lexer = new Lexer\Emulative();
}
2015-06-20 11:28:58 +02:00
switch ($kind) {
case self::PREFER_PHP7:
case self::ONLY_PHP7:
2022-07-23 16:35:21 +02:00
return new Parser\Php7($lexer);
2015-06-20 11:28:58 +02:00
default:
throw new \LogicException(
2022-06-06 16:45:02 +02:00
'Kind must be one of ::PREFER_PHP7 or ::ONLY_PHP7'
2015-06-20 11:28:58 +02:00
);
}
}
/**
* Create a parser targeting the given version on a best-effort basis. The parser will generally
* accept code for the newest supported version, but will try to accommodate code that becomes
* invalid in newer versions or changes in interpretation.
*/
2022-07-23 16:35:21 +02:00
public function createForVersion(PhpVersion $version, array $lexerOptions = []): Parser {
if ($version->isHostVersion()) {
$lexer = new Lexer($lexerOptions);
} else {
$lexer = new Lexer\Emulative($lexerOptions + ['phpVersion' => $version]);
}
2022-07-23 16:35:21 +02:00
if ($version->id >= 80000) {
return new Php8($lexer, $version);
}
2022-07-23 16:35:21 +02:00
return new Php7($lexer, $version);
}
/**
* Create a parser targeting the newest version supported by this library. Code for older
* versions will be accepted if there have been no relevant backwards-compatibility breaks in
* PHP.
*/
2022-07-23 16:35:21 +02:00
public function createForNewestSupportedVersion(array $lexerOptions = []): Parser {
return $this->createForVersion(PhpVersion::getNewestSupported(), $lexerOptions);
}
/**
* Create a parser targeting the host PHP version, that is the PHP version we're currently
* running on. This parser will not use any token emulation.
*/
2022-07-23 16:35:21 +02:00
public function createForHostVersion(array $lexerOptions = []): Parser {
return $this->createForVersion(PhpVersion::getHostVersion(), $lexerOptions);
}
2015-06-20 11:28:58 +02:00
}