Current File : /var/www/vinorea/modules/psxdesign/vendor/friendsofphp/php-cs-fixer/src/Linter/TokenizerLinter.php |
<?php
declare(strict_types=1);
/*
* This file is part of PHP CS Fixer.
*
* (c) Fabien Potencier <fabien@symfony.com>
* Dariusz Rumiński <dariusz.ruminski@gmail.com>
*
* This source file is subject to the MIT license that is bundled
* with this source code in the file LICENSE.
*/
namespace PhpCsFixer\Linter;
use PhpCsFixer\FileReader;
use PhpCsFixer\Tokenizer\CodeHasher;
use PhpCsFixer\Tokenizer\Tokens;
/**
* Handle PHP code linting.
*
* @author Dariusz Rumiński <dariusz.ruminski@gmail.com>
*
* @internal
*/
final class TokenizerLinter implements LinterInterface
{
public function __construct()
{
if (
// @TODO: drop condition when PHP 7.3+ is required
false === class_exists(\CompileError::class)
) {
throw new UnavailableLinterException('Cannot use tokenizer as linter.');
}
}
/**
* {@inheritdoc}
*/
public function isAsync(): bool
{
return false;
}
/**
* {@inheritdoc}
*/
public function lintFile(string $path): LintingResultInterface
{
return $this->lintSource(FileReader::createSingleton()->read($path));
}
/**
* {@inheritdoc}
*/
public function lintSource(string $source): LintingResultInterface
{
try {
// To lint, we will parse the source into Tokens.
// During that process, it might throw a ParseError or CompileError.
// If it won't, cache of tokenized version of source will be kept, which is great for Runner.
// Yet, first we need to clear already existing cache to not hit it and lint the code indeed.
$codeHash = CodeHasher::calculateCodeHash($source);
Tokens::clearCache($codeHash);
Tokens::fromCode($source);
return new TokenizerLintingResult();
} catch (\ParseError $e) {
return new TokenizerLintingResult($e);
} catch (\CompileError $e) {
return new TokenizerLintingResult($e);
}
}
}