class ByteOrderMarkSniff
Hierarchy
- class \PHP_CodeSniffer\Standards\Generic\Sniffs\Files\ByteOrderMarkSniff implements \PHP_CodeSniffer\Sniffs\Sniff
Expanded class hierarchy of ByteOrderMarkSniff
File
-
vendor/
squizlabs/ php_codesniffer/ src/ Standards/ Generic/ Sniffs/ Files/ ByteOrderMarkSniff.php, line 16
Namespace
PHP_CodeSniffer\Standards\Generic\Sniffs\FilesView source
class ByteOrderMarkSniff implements Sniff {
/**
* List of supported BOM definitions.
*
* Use encoding names as keys and hex BOM representations as values.
*
* @var array
*/
protected $bomDefinitions = [
'UTF-8' => 'efbbbf',
'UTF-16 (BE)' => 'feff',
'UTF-16 (LE)' => 'fffe',
];
/**
* Returns an array of tokens this test wants to listen for.
*
* @return array<int|string>
*/
public function register() {
return [
T_INLINE_HTML,
];
}
//end register()
/**
* Processes this sniff, when one of its tokens is encountered.
*
* @param \PHP_CodeSniffer\Files\File $phpcsFile The file being scanned.
* @param int $stackPtr The position of the current token in
* the stack passed in $tokens.
*
* @return int
*/
public function process(File $phpcsFile, $stackPtr) {
// The BOM will be the very first token in the file.
if ($stackPtr !== 0) {
return $phpcsFile->numTokens;
}
$tokens = $phpcsFile->getTokens();
foreach ($this->bomDefinitions as $bomName => $expectedBomHex) {
$bomByteLength = strlen($expectedBomHex) / 2;
$htmlBomHex = bin2hex(substr($tokens[$stackPtr]['content'], 0, $bomByteLength));
if ($htmlBomHex === $expectedBomHex) {
$errorData = [
$bomName,
];
$error = 'File contains %s byte order mark, which may corrupt your application';
$phpcsFile->addError($error, $stackPtr, 'Found', $errorData);
$phpcsFile->recordMetric($stackPtr, 'Using byte order mark', 'yes');
return $phpcsFile->numTokens;
}
}
$phpcsFile->recordMetric($stackPtr, 'Using byte order mark', 'no');
return $phpcsFile->numTokens;
}
//end process()
}
Members
Title Sort descending | Modifiers | Object type | Summary | Overriden Title |
---|---|---|---|---|
ByteOrderMarkSniff::$bomDefinitions | protected | property | List of supported BOM definitions. | |
ByteOrderMarkSniff::process | public | function | Processes this sniff, when one of its tokens is encountered. | Overrides Sniff::process |
ByteOrderMarkSniff::register | public | function | Returns an array of tokens this test wants to listen for. | Overrides Sniff::register |