mirror of
https://we.phorge.it/source/arcanist.git
synced 2024-11-22 06:42:41 +01:00
Further improvements to array comma linter rule
Summary: Improve the `ArcanistXHPASTLinter::LINT_ARRAY_SEPARATOR` rule to be able to autofix the following code: ```lang=php array( 1, 2, 3, /* comment */ ); ``` Test Plan: Added unit tests. Reviewers: epriestley, #blessed_reviewers Reviewed By: epriestley, #blessed_reviewers Subscribers: epriestley Differential Revision: https://secure.phabricator.com/D12308
This commit is contained in:
parent
25855c4427
commit
993166fa49
3 changed files with 43 additions and 23 deletions
|
@ -13,7 +13,7 @@ max_line_length = 80
|
||||||
indent_style =
|
indent_style =
|
||||||
end_of_line =
|
end_of_line =
|
||||||
max_line_length =
|
max_line_length =
|
||||||
trim_trailing_whitespace =
|
trim_trailing_whitespace = false
|
||||||
|
|
||||||
[src/parser/__tests__/bundle/*]
|
[src/parser/__tests__/bundle/*]
|
||||||
insert_final_newline = false
|
insert_final_newline = false
|
||||||
|
|
|
@ -3223,29 +3223,39 @@ final class ArcanistXHPASTLinter extends ArcanistBaseXHPASTLinter {
|
||||||
$value = last($values);
|
$value = last($values);
|
||||||
$after = last($value->getTokens())->getNextToken();
|
$after = last($value->getTokens())->getNextToken();
|
||||||
|
|
||||||
if ($multiline && (!$after || $after->getValue() != ',')) {
|
if ($multiline) {
|
||||||
if ($value->getChildByIndex(1)->getTypeName() == 'n_HEREDOC') {
|
if (!$after || $after->getValue() != ',') {
|
||||||
continue;
|
if ($value->getChildByIndex(1)->getTypeName() == 'n_HEREDOC') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
list($before, $after) = $value->getSurroundingNonsemanticTokens();
|
||||||
|
$after = implode('', mpull($after, 'getValue'));
|
||||||
|
|
||||||
|
$original = $value->getConcreteString();
|
||||||
|
$replacement = $value->getConcreteString().',';
|
||||||
|
|
||||||
|
if (strpos($after, "\n") === false) {
|
||||||
|
$original .= $after;
|
||||||
|
$replacement .= $after."\n".$array->getIndentation();
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->raiseLintAtOffset(
|
||||||
|
$value->getOffset(),
|
||||||
|
self::LINT_ARRAY_SEPARATOR,
|
||||||
|
pht('Multi-lined arrays should have trailing commas.'),
|
||||||
|
$original,
|
||||||
|
$replacement);
|
||||||
|
} else if ($value->getLineNumber() == $array->getEndLineNumber()) {
|
||||||
|
$close = last($array->getTokens());
|
||||||
|
|
||||||
|
$this->raiseLintAtToken(
|
||||||
|
$close,
|
||||||
|
self::LINT_ARRAY_SEPARATOR,
|
||||||
|
pht('Closing parenthesis should be on a new line.'),
|
||||||
|
"\n".$array->getIndentation().$close->getValue());
|
||||||
}
|
}
|
||||||
|
} else if ($after && $after->getValue() == ',') {
|
||||||
list($before, $after) = $value->getSurroundingNonsemanticTokens();
|
|
||||||
$after = implode('', mpull($after, 'getValue'));
|
|
||||||
|
|
||||||
$original = $value->getConcreteString();
|
|
||||||
$replacement = $value->getConcreteString().',';
|
|
||||||
|
|
||||||
if (strpos($after, "\n") === false) {
|
|
||||||
$original .= $after;
|
|
||||||
$replacement .= rtrim($after)."\n".$array->getIndentation();
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->raiseLintAtOffset(
|
|
||||||
$value->getOffset(),
|
|
||||||
self::LINT_ARRAY_SEPARATOR,
|
|
||||||
pht('Multi-lined arrays should have trailing commas.'),
|
|
||||||
$original,
|
|
||||||
$replacement);
|
|
||||||
} else if (!$multiline && $after && $after->getValue() == ',') {
|
|
||||||
$this->raiseLintAtToken(
|
$this->raiseLintAtToken(
|
||||||
$after,
|
$after,
|
||||||
self::LINT_ARRAY_SEPARATOR,
|
self::LINT_ARRAY_SEPARATOR,
|
||||||
|
|
|
@ -28,12 +28,17 @@ array(
|
||||||
1,
|
1,
|
||||||
2,
|
2,
|
||||||
3 /* comment */ );
|
3 /* comment */ );
|
||||||
|
array(
|
||||||
|
1,
|
||||||
|
2,
|
||||||
|
3, /* comment */ );
|
||||||
~~~~~~~~~~
|
~~~~~~~~~~
|
||||||
advice:3:14
|
advice:3:14
|
||||||
advice:12:3
|
advice:12:3
|
||||||
advice:16:3
|
advice:16:3
|
||||||
advice:26:3
|
advice:26:3
|
||||||
advice:30:3
|
advice:30:3
|
||||||
|
advice:34:20
|
||||||
~~~~~~~~~~
|
~~~~~~~~~~
|
||||||
<?php
|
<?php
|
||||||
array(1, 2, 3);
|
array(1, 2, 3);
|
||||||
|
@ -67,3 +72,8 @@ array(
|
||||||
2,
|
2,
|
||||||
3, /* comment */
|
3, /* comment */
|
||||||
);
|
);
|
||||||
|
array(
|
||||||
|
1,
|
||||||
|
2,
|
||||||
|
3, /* comment */
|
||||||
|
);
|
||||||
|
|
Loading…
Reference in a new issue