*/ public function register() { return [\T_FOREACH]; } /** * Processes this test, when one of its tokens is encountered. * * @since 9.0.0 * * @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 void */ public function process(File $phpcsFile, $stackPtr) { if (ScannedCode::shouldRunOnOrBelow('5.4') === false) { return; } $tokens = $phpcsFile->getTokens(); if (isset($tokens[$stackPtr]['parenthesis_opener'], $tokens[$stackPtr]['parenthesis_closer']) === false) { return; } $opener = $tokens[$stackPtr]['parenthesis_opener']; $closer = $tokens[$stackPtr]['parenthesis_closer']; $asToken = $phpcsFile->findNext(\T_AS, ($opener + 1), $closer); if ($asToken === false) { return; } $hasList = $phpcsFile->findNext([\T_LIST, \T_OPEN_SHORT_ARRAY], ($asToken + 1), $closer); if ($hasList === false) { return; } /* * @internal No need to check for short array vs short list as if this token is found after the `as` * in a `foreach`, it will always be a short list. * Also not affected by any known tokenizer bugs which would tokenize the open bracket as * `T_OPEN_SQUARE_BRACKET`. */ $phpcsFile->addError( 'Unpacking nested arrays with list() in a foreach is not supported in PHP 5.4 or earlier.', $hasList, 'Found' ); } }