mirror of
https://we.phorge.it/source/arcanist.git
synced 2025-01-22 12:41:18 +01:00
Improve behavior for detecting the failure to parse external linter output
Summary: Currently, a lot of `ArcanistExternalLinter` subclasses have something like this: ```lang=php if ($err && !$messages) { return false; } ``` We can avoid this code duplication by moving this check to the `ArcanistExternalLinter` class. Test Plan: `arc unit` Reviewers: #blessed_reviewers, epriestley Reviewed By: #blessed_reviewers, epriestley Subscribers: Korvin, epriestley Differential Revision: https://secure.phabricator.com/D11321
This commit is contained in:
parent
26c4f12a21
commit
8244b3582a
12 changed files with 7 additions and 44 deletions
|
@ -120,10 +120,6 @@ final class ArcanistCoffeeLintLinter extends ArcanistExternalLinter {
|
|||
}
|
||||
}
|
||||
|
||||
if ($err && !$messages) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $messages;
|
||||
}
|
||||
|
||||
|
|
|
@ -56,10 +56,6 @@ final class ArcanistCpplintLinter extends ArcanistExternalLinter {
|
|||
$messages[] = $message;
|
||||
}
|
||||
|
||||
if ($err && !$messages) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $messages;
|
||||
}
|
||||
|
||||
|
|
|
@ -354,6 +354,13 @@ abstract class ArcanistExternalLinter extends ArcanistFutureLinter {
|
|||
|
||||
$messages = $this->parseLinterOutput($path, $err, $stdout, $stderr);
|
||||
|
||||
if ($err && $this->shouldExpectCommandErrors() && !$messages) {
|
||||
// We assume that if the future exits with a non-zero status and we
|
||||
// failed to parse any linter messages, then something must've gone wrong
|
||||
// during parsing.
|
||||
$messages = false;
|
||||
}
|
||||
|
||||
if ($messages === false) {
|
||||
if ($err) {
|
||||
$future->resolvex();
|
||||
|
|
|
@ -78,10 +78,6 @@ final class ArcanistFlake8Linter extends ArcanistExternalLinter {
|
|||
$messages[] = $message;
|
||||
}
|
||||
|
||||
if ($err && !$messages) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $messages;
|
||||
}
|
||||
|
||||
|
|
|
@ -79,10 +79,6 @@ final class ArcanistJSONLintLinter extends ArcanistExternalLinter {
|
|||
}
|
||||
}
|
||||
|
||||
if ($err && !$messages) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $messages;
|
||||
}
|
||||
|
||||
|
|
|
@ -129,10 +129,6 @@ final class ArcanistJscsLinter extends ArcanistExternalLinter {
|
|||
}
|
||||
}
|
||||
|
||||
if ($err && !$messages) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $messages;
|
||||
}
|
||||
|
||||
|
|
|
@ -177,10 +177,6 @@ final class ArcanistLesscLinter extends ArcanistExternalLinter {
|
|||
}
|
||||
}
|
||||
|
||||
if ($err && !$messages) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $messages;
|
||||
}
|
||||
|
||||
|
|
|
@ -70,10 +70,6 @@ final class ArcanistPEP8Linter extends ArcanistExternalLinter {
|
|||
$messages[] = $message;
|
||||
}
|
||||
|
||||
if ($err && !$messages) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $messages;
|
||||
}
|
||||
|
||||
|
|
|
@ -133,10 +133,6 @@ final class ArcanistPuppetLintLinter extends ArcanistExternalLinter {
|
|||
$messages[] = $message;
|
||||
}
|
||||
|
||||
if ($err && !$messages) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $messages;
|
||||
}
|
||||
|
||||
|
|
|
@ -77,10 +77,6 @@ final class ArcanistPyFlakesLinter extends ArcanistExternalLinter {
|
|||
$messages[] = $message;
|
||||
}
|
||||
|
||||
if ($err && !$messages) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $messages;
|
||||
}
|
||||
|
||||
|
|
|
@ -142,10 +142,6 @@ final class ArcanistPyLintLinter extends ArcanistExternalLinter {
|
|||
$messages[] = $message;
|
||||
}
|
||||
|
||||
if ($err && !$messages) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $messages;
|
||||
}
|
||||
|
||||
|
|
|
@ -81,10 +81,6 @@ final class ArcanistRubyLinter extends ArcanistExternalLinter {
|
|||
$messages[] = $message;
|
||||
}
|
||||
|
||||
if ($err && !$messages) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $messages;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue