mirror of
https://we.phorge.it/source/arcanist.git
synced 2024-11-26 08:42:40 +01:00
Provide arc linters --verbose
to list all available options
Summary: Ref T2039. I'll update the corresponding documentation. It feels a little awkward that this is disconnected from `getLinterConfigurationOptions()`, but I dislike returning weird ad-hoc structures more than I dislike having two methods. Most linters don't implement either of these anyway. Test Plan: Ran `arc linters` and `arc linters --verbose`. Reviewers: btrahan, joshuaspence Reviewed By: joshuaspence Subscribers: epriestley Maniphest Tasks: T2039 Differential Revision: https://secure.phabricator.com/D9062
This commit is contained in:
parent
b6ccfd4ef5
commit
54c377448d
7 changed files with 115 additions and 14 deletions
|
@ -47,6 +47,16 @@ final class ArcanistConfigurationDrivenLintEngine extends ArcanistLintEngine {
|
||||||
$linter = clone $linters[$type];
|
$linter = clone $linters[$type];
|
||||||
$linter->setEngine($this);
|
$linter->setEngine($this);
|
||||||
$more = $linter->getLinterConfigurationOptions();
|
$more = $linter->getLinterConfigurationOptions();
|
||||||
|
|
||||||
|
foreach ($more as $key => $option_spec) {
|
||||||
|
PhutilTypeSpec::checkMap(
|
||||||
|
$option_spec,
|
||||||
|
array(
|
||||||
|
'type' => 'string',
|
||||||
|
'help' => 'string',
|
||||||
|
));
|
||||||
|
$more[$key] = $option_spec['type'];
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
// We'll raise an error below about the invalid "type" key.
|
// We'll raise an error below about the invalid "type" key.
|
||||||
$linter = null;
|
$linter = null;
|
||||||
|
|
|
@ -2,8 +2,6 @@
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* C# linter for Arcanist.
|
* C# linter for Arcanist.
|
||||||
*
|
|
||||||
* @group linter
|
|
||||||
*/
|
*/
|
||||||
final class ArcanistCSharpLinter extends ArcanistLinter {
|
final class ArcanistCSharpLinter extends ArcanistLinter {
|
||||||
|
|
||||||
|
@ -27,8 +25,19 @@ final class ArcanistCSharpLinter extends ArcanistLinter {
|
||||||
public function getLinterConfigurationOptions() {
|
public function getLinterConfigurationOptions() {
|
||||||
$options = parent::getLinterConfigurationOptions();
|
$options = parent::getLinterConfigurationOptions();
|
||||||
|
|
||||||
$options["discovery"] = 'map<string, list<string>>';
|
$options['discovery'] = array(
|
||||||
$options["binary"] = 'string';
|
'type' => 'map<string, list<string>>',
|
||||||
|
'help' => pht('Provide a discovery map.'),
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
// TODO: This should probably be replaced with "bin" when this moves
|
||||||
|
// to extend ExternalLinter.
|
||||||
|
|
||||||
|
$options['binary'] = array(
|
||||||
|
'type' => 'string',
|
||||||
|
'help' => pht('Override default binary.'),
|
||||||
|
);
|
||||||
|
|
||||||
return $options;
|
return $options;
|
||||||
}
|
}
|
||||||
|
|
|
@ -442,15 +442,33 @@ abstract class ArcanistExternalLinter extends ArcanistFutureLinter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function getLinterConfigurationOptions() {
|
public function getLinterConfigurationOptions() {
|
||||||
$options = array(
|
$options = array(
|
||||||
'bin' => 'optional string | list<string>',
|
'bin' => array(
|
||||||
'flags' => 'optional list<string>',
|
'type' => 'optional string | list<string>',
|
||||||
|
'help' => pht(
|
||||||
|
'Specify a string (or list of strings) identifying the binary '.
|
||||||
|
'which should be invoked to execute this linter. This overrides '.
|
||||||
|
'the default binary. If you provide a list of possible binaries, '.
|
||||||
|
'the first one which exists will be used.')
|
||||||
|
),
|
||||||
|
'flags' => array(
|
||||||
|
'type' => 'optional list<string>',
|
||||||
|
'help' => pht(
|
||||||
|
'Provide a list of additional flags to pass to the linter on the '.
|
||||||
|
'command line.'),
|
||||||
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
if ($this->shouldUseInterpreter()) {
|
if ($this->shouldUseInterpreter()) {
|
||||||
$options['interpreter'] = 'optional string | list<string>';
|
$options['interpreter'] = array(
|
||||||
|
'type' => 'optional string | list<string>',
|
||||||
|
'help' => pht(
|
||||||
|
'Specify a string (or list of strings) identifying the interpreter '.
|
||||||
|
'which should be used to invoke the linter binary. If you provide '.
|
||||||
|
'a list of possible interpreters, the first one that exists '.
|
||||||
|
'will be used.'),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $options + parent::getLinterConfigurationOptions();
|
return $options + parent::getLinterConfigurationOptions();
|
||||||
|
|
|
@ -40,8 +40,17 @@ final class ArcanistLesscLinter extends ArcanistExternalLinter {
|
||||||
|
|
||||||
public function getLinterConfigurationOptions() {
|
public function getLinterConfigurationOptions() {
|
||||||
return parent::getLinterConfigurationOptions() + array(
|
return parent::getLinterConfigurationOptions() + array(
|
||||||
'lessc.strict-math' => 'optional bool',
|
'lessc.strict-math' => array(
|
||||||
'lessc.strict-units' => 'optional bool',
|
'type' => 'optional bool',
|
||||||
|
'help' => pht(
|
||||||
|
'Enable strict math, which only processes mathematical expressions '.
|
||||||
|
'inside extraneous parentheses.'),
|
||||||
|
),
|
||||||
|
'lessc.strict-units' => array(
|
||||||
|
'type' => 'optional bool',
|
||||||
|
'help' => pht(
|
||||||
|
'Enable strict handling of units in expressions.'),
|
||||||
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -74,6 +74,7 @@ abstract class ArcanistLinter {
|
||||||
get_class($this));
|
get_class($this));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function getLinterPriority() {
|
public function getLinterPriority() {
|
||||||
return 1.0;
|
return 1.0;
|
||||||
}
|
}
|
||||||
|
@ -360,8 +361,18 @@ abstract class ArcanistLinter {
|
||||||
}
|
}
|
||||||
|
|
||||||
return array(
|
return array(
|
||||||
'severity' => 'optional map<string|int, string>',
|
'severity' => array(
|
||||||
'severity.rules' => 'optional map<string, string>',
|
'type' => 'optional map<string|int, string>',
|
||||||
|
'help' => pht(
|
||||||
|
'Provide a map from lint codes to adjusted severity levels: error, '.
|
||||||
|
'warning, advice, autofix or disabled.')
|
||||||
|
),
|
||||||
|
'severity.rules' => array(
|
||||||
|
'type' => 'optional map<string, string>',
|
||||||
|
'help' => pht(
|
||||||
|
'Provide a map of regular expressions to severity levels. All '.
|
||||||
|
'matching codes have their severity adjusted.'),
|
||||||
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -33,7 +33,12 @@ final class ArcanistTextLinter extends ArcanistLinter {
|
||||||
|
|
||||||
public function getLinterConfigurationOptions() {
|
public function getLinterConfigurationOptions() {
|
||||||
$options = array(
|
$options = array(
|
||||||
'text.max-line-length' => 'optional int',
|
'text.max-line-length' => array(
|
||||||
|
'type' => 'optional int',
|
||||||
|
'help' => pht(
|
||||||
|
'Adjust the maximum line length before a warning is raised. By '.
|
||||||
|
'default, a warning is raised on lines exceeding 80 characters.'),
|
||||||
|
),
|
||||||
);
|
);
|
||||||
|
|
||||||
return $options + parent::getLinterConfigurationOptions();
|
return $options + parent::getLinterConfigurationOptions();
|
||||||
|
|
|
@ -26,7 +26,11 @@ EOTEXT
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getArguments() {
|
public function getArguments() {
|
||||||
return array();
|
return array(
|
||||||
|
'verbose' => array(
|
||||||
|
'help' => pht('Show detailed information, including options.'),
|
||||||
|
),
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function run() {
|
public function run() {
|
||||||
|
@ -77,6 +81,7 @@ EOTEXT
|
||||||
'uri' => $linter->getInfoURI(),
|
'uri' => $linter->getInfoURI(),
|
||||||
'description' => $linter->getInfoDescription(),
|
'description' => $linter->getInfoDescription(),
|
||||||
'exception' => $exception,
|
'exception' => $exception,
|
||||||
|
'options' => $linter->getLinterConfigurationOptions(),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -137,10 +142,44 @@ EOTEXT
|
||||||
$print_tail = true;
|
$print_tail = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$options = $linter['options'];
|
||||||
|
if ($options && $this->getArgument('verbose')) {
|
||||||
|
$console->writeOut(
|
||||||
|
"\n%s**%s**\n\n",
|
||||||
|
$pad,
|
||||||
|
pht('Configuration Options'));
|
||||||
|
|
||||||
|
$last_option = last_key($options);
|
||||||
|
foreach ($options as $option => $option_spec) {
|
||||||
|
$console->writeOut(
|
||||||
|
"%s__%s__ (%s)\n",
|
||||||
|
$pad,
|
||||||
|
$option,
|
||||||
|
$option_spec['type']);
|
||||||
|
|
||||||
|
$console->writeOut(
|
||||||
|
"%s\n",
|
||||||
|
phutil_console_wrap(
|
||||||
|
$option_spec['help'],
|
||||||
|
strlen($pad) + 2));
|
||||||
|
|
||||||
|
if ($option != $last_option) {
|
||||||
|
$console->writeOut("\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$print_tail = true;
|
||||||
|
}
|
||||||
|
|
||||||
if ($print_tail) {
|
if ($print_tail) {
|
||||||
$console->writeOut("\n");
|
$console->writeOut("\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!$this->getArgument('verbose')) {
|
||||||
|
$console->writeOut(
|
||||||
|
"%s\n",
|
||||||
|
pht('(Run `arc linters --verbose` for more details.)'));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue