Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
<?php declare(strict_types=1); /* * This file is part of PHP CS Fixer. * * (c) Fabien..
Decoded Output download
<?php
declare(strict_types=1);
/*
* This file is part of PHP CS Fixer.
*
* (c) Fabien Potencier <[email protected]>
* Dariusz Rumiski <[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 Rumiski <[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);
}
}
}
?>
Did this file decode correctly?
Original Code
<?php
declare(strict_types=1);
/*
* This file is part of PHP CS Fixer.
*
* (c) Fabien Potencier <[email protected]>
* Dariusz Rumiski <[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 Rumiski <[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);
}
}
}
Function Calls
None |
Stats
MD5 | 80b5150764c6dd9e4a72e7ef4068310f |
Eval Count | 0 |
Decode Time | 133 ms |