![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/vendor/friendsofphp/php-cs-fixer/src/Linter/ |
<?php declare(strict_types=1); /* * This file is part of PHP CS Fixer. * * (c) Fabien Potencier <[email protected]> * Dariusz Rumiński <[email protected]> * * 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 <[email protected]> * * @internal */ final class TokenizerLinter implements LinterInterface { public function isAsync(): bool { return false; } public function lintFile(string $path): LintingResultInterface { return $this->lintSource(FileReader::createSingleton()->read($path)); } 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 (\CompileError|\ParseError $e) { return new TokenizerLintingResult($e); } } }