Skip to content

Commit

Permalink
Split the errors, adding the *CloserSameLine ones
Browse files Browse the repository at this point in the history
Some standards may want to have different rules when
the array closer is in the same line than the last element.

When that happens, the new *CloserSameLine errors are
emitted, allowing to disable them via ruleset.

For testing, a couple of cases have been added to CommaAfterLastUnitTest.1.inc
and then, the fixtures have been 100% duplicated into CommaAfterLastUnitTest.3.inc
that runs with the *CloserSameLine errors disabled.

A simple diff shows the 8 cases in which the outcome is different, as
expected.

Fixes #283.
  • Loading branch information
stronk7 committed Nov 7, 2023
1 parent 746c319 commit 865c8d9
Show file tree
Hide file tree
Showing 6 changed files with 502 additions and 21 deletions.
7 changes: 4 additions & 3 deletions NormalizedArrays/Sniffs/Arrays/CommaAfterLastSniff.php
Original file line number Diff line number Diff line change
Expand Up @@ -145,7 +145,8 @@ public function process(File $phpcsFile, $stackPtr)
return;
}

$isComma = ($tokens[$lastNonEmpty]['code'] === \T_COMMA);
$isComma = ($tokens[$lastNonEmpty]['code'] === \T_COMMA);
$sameLineCloser = ($tokens[$lastNonEmpty]['line'] === $tokens[$closer]['line']) ? 'CloserSameLine' : '';

$phpcsFile->recordMetric(
$stackPtr,
Expand All @@ -160,7 +161,7 @@ public function process(File $phpcsFile, $stackPtr)
}

$error = 'There should be a comma after the last array item in a %s array.';
$errorCode = 'Missing' . $errorCode;
$errorCode = 'Missing' . $errorCode . $sameLineCloser;
$data = [$phrase];
$fix = $phpcsFile->addFixableError($error, $lastNonEmpty, $errorCode, $data);
if ($fix === true) {
Expand All @@ -186,7 +187,7 @@ public function process(File $phpcsFile, $stackPtr)
}

$error = 'A comma after the last array item in a %s array is not allowed.';
$errorCode = 'Found' . $errorCode;
$errorCode = 'Found' . $errorCode . $sameLineCloser;
$data = [$phrase];
$fix = $phpcsFile->addFixableError($error, $lastNonEmpty, $errorCode, $data);
if ($fix === true) {
Expand Down
23 changes: 23 additions & 0 deletions NormalizedArrays/Tests/Arrays/CommaAfterLastUnitTest.1.inc
Original file line number Diff line number Diff line change
@@ -1,5 +1,12 @@
<?php

// This is exactly the same as CommasInArrayUnitTest.3.inc, but with these lines
// and all the *LineCloserSameLine errors not enabled for the whole file.
// nophpcs:disable NormalizedArrays.Arrays.CommaAfterLast.FoundSingleLineCloserSameLine
// nophpcs:disable NormalizedArrays.Arrays.CommaAfterLast.FoundMultiLineCloserSameLine
// nophpcs:disable NormalizedArrays.Arrays.CommaAfterLast.MissingSingleLineCloserSameLine
// nophpcs:disable NormalizedArrays.Arrays.CommaAfterLast.MissingMultiLineCloserSameLine

/*
* Verify that non-arrays are not touched by the sniff.
* - square brackets, not short array.
Expand Down Expand Up @@ -79,6 +86,14 @@ $missing = [
'c'/* Comment. */
];

$missing = array(
1, 2,
3, 4);

$missing = [
'1', '2',
'3', '4'];

$missingInNested = array(
1 => 'value' ,
2 => [
Expand Down Expand Up @@ -140,6 +155,14 @@ $found = [
'c',
];

$found = array(
1, 2,
3, 4,);

$found = [
'1', '2',
'3', '4',];

$foundInNested = array(
1 => 'value' ,
2 => [
Expand Down
23 changes: 23 additions & 0 deletions NormalizedArrays/Tests/Arrays/CommaAfterLastUnitTest.1.inc.fixed
Original file line number Diff line number Diff line change
@@ -1,5 +1,12 @@
<?php

// This is exactly the same as CommasInArrayUnitTest.3.inc, but with these lines
// and all the *LineCloserSameLine errors not enabled for the whole file.
// nophpcs:disable NormalizedArrays.Arrays.CommaAfterLast.FoundSingleLineCloserSameLine
// nophpcs:disable NormalizedArrays.Arrays.CommaAfterLast.FoundMultiLineCloserSameLine
// nophpcs:disable NormalizedArrays.Arrays.CommaAfterLast.MissingSingleLineCloserSameLine
// nophpcs:disable NormalizedArrays.Arrays.CommaAfterLast.MissingMultiLineCloserSameLine

/*
* Verify that non-arrays are not touched by the sniff.
* - square brackets, not short array.
Expand Down Expand Up @@ -79,6 +86,14 @@ $missing = [
'c',/* Comment. */
];

$missing = array(
1, 2,
3, 4,);

$missing = [
'1', '2',
'3', '4',];

$missingInNested = array(
1 => 'value' ,
2 => [
Expand Down Expand Up @@ -141,6 +156,14 @@ $found = [
'c'
];

$found = array(
1, 2,
3, 4);

$found = [
'1', '2',
'3', '4'];

$foundInNested = array(
1 => 'value' ,
2 => [
Expand Down
201 changes: 201 additions & 0 deletions NormalizedArrays/Tests/Arrays/CommaAfterLastUnitTest.3.inc
Original file line number Diff line number Diff line change
@@ -0,0 +1,201 @@
<?php

// This is exactly the same as CommasInArrayUnitTest.1.inc, but with these lines
// and all the *LineCloserSameLine errors disabled for the whole file.
// phpcs:disable NormalizedArrays.Arrays.CommaAfterLast.FoundSingleLineCloserSameLine
// phpcs:disable NormalizedArrays.Arrays.CommaAfterLast.FoundMultiLineCloserSameLine
// phpcs:disable NormalizedArrays.Arrays.CommaAfterLast.MissingSingleLineCloserSameLine
// phpcs:disable NormalizedArrays.Arrays.CommaAfterLast.MissingMultiLineCloserSameLine

/*
* Verify that non-arrays are not touched by the sniff.
* - square brackets, not short array.
* - short lists.
*/
$a['array_access'] = 123;

// Short list, not short array.
[,,] = $array;
[$var1, , [$var2, $var3,], $var4,] = $array;

/*
* Empty arrays should be ignored.
*/
$empty = array();
$empty = [ /* comment */ ];

/*
* Test skipping the checks when 'skip' has been passed.
*/
// phpcs:set NormalizedArrays.Arrays.CommaAfterLast singleLine skip
// phpcs:set NormalizedArrays.Arrays.CommaAfterLast multiLine skip

$ignore = array(1, 2, 3,);
$ignore = [
1,
3
];

/*
* Test skipping the checks when invalid property settings have been passed.
*/
// phpcs:set NormalizedArrays.Arrays.CommaAfterLast singleLine disallow
// phpcs:set NormalizedArrays.Arrays.CommaAfterLast multiLine demand

$ignore = array(1, 2, 3,);
$ignore = [
1,
3
];

/*
* Test enforcing a comma after the last array item.
*/
// phpcs:set NormalizedArrays.Arrays.CommaAfterLast singleLine enforce

$good = array( 1, 2, 3, );
$good = [ 'a', 'b', 'c', ];

$missing = array( 1, 2, 3 );
$missing = [ 'a', 'b', 'c' ];

// phpcs:set NormalizedArrays.Arrays.CommaAfterLast multiLine enforce

$good = array(
1,
3,
);
$good = [
'a',
'c',
];

$goodHeredoc = function_call()->method_name( array(
'phrase' => <<<EOD
Here comes some text.
EOD
,
) );

$missing = array(
1,
3
);
$missing = [
'a',
'c'/* Comment. */
];

$missing = array(
1, 2,
3, 4);

$missing = [
'1', '2',
'3', '4'];

$missingInNested = array(
1 => 'value' ,
2 => [
'a' => 'value' ,// phpcs:disable Standard.Category.Sniff - the extra spacing is fine, might be for alignment with other comments.
'b' => array(
1
),
'c' => apply_filters( 'filter', $input, $var )
],
3 => apply_filters( 'filter', $input, $var )/* phpcs:ignore Standard.Category.Sniff */
);

$missing = array(
'first',
'second'
//'third',
);

$missingNowdoc = function_call()->method_name( array(
'phrase' => <<<'EOD'
Here comes some text.
EOD
) );

/*
* Test forbidding a comma after the last array item.
*/
// phpcs:set NormalizedArrays.Arrays.CommaAfterLast singleLine forbid

$good = array( 1, 2, 3 );
$good = [ 'a', 'b', 'c' ];

$found = array( 1, 2, 3, );
$found = [ 'a', 'b', 'c', ];

// phpcs:set NormalizedArrays.Arrays.CommaAfterLast multiLine forbid

$good = array(
1,
3
);
$good = [
'a',
'c'
];

$goodNowdoc = function_call()->method_name( array(
'phrase' => <<<'EOD'
Here comes some text.
EOD
) );

$found = array(
1,
3,/* Comment. */
);
$found = [
'a',
'c',
];

$found = array(
1, 2,
3, 4,);

$found = [
'1', '2',
'3', '4',];

$foundInNested = array(
1 => 'value' ,
2 => [
'a' => 'value' ,// phpcs:disable Standard.Category.Sniff - the extra spacing is fine, might be for alignment with other comments.
'b' => array(
1,
),
'c' => apply_filters( 'filter', $input, $var ),
],
3 => apply_filters( 'filter', $input, $var ), /* phpcs:ignore Standard.Category.Sniff */
);

$foundHeredoc = function_call()->method_name( array(
'phrase' => <<<"EOD"
Here comes some text.
EOD
,
) );

$foundHeredoc = function_call()->method_name( array(
'phrase' => <<<"EOD"
Here comes some text.
EOD
, /*comment*/
) );

// Reset the properties to the defaults.
// phpcs:set NormalizedArrays.Arrays.CommaAfterLast singleLine forbid
// phpcs:set NormalizedArrays.Arrays.CommaAfterLast multiLine enforce
// phpcs:enable

/*
* Test live coding. This should be the last test in the file.
*/
// Intentional parse error.
$ignore = array(
Loading

0 comments on commit 865c8d9

Please sign in to comment.