Page MenuHomePhabricator

D8387.diff
No OneTemporary

D8387.diff

diff --git a/src/lint/linter/ArcanistCSSLintLinter.php b/src/lint/linter/ArcanistCSSLintLinter.php
--- a/src/lint/linter/ArcanistCSSLintLinter.php
+++ b/src/lint/linter/ArcanistCSSLintLinter.php
@@ -19,13 +19,13 @@
}
public function getMandatoryFlags() {
- return '--format=lint-xml';
+ return array('--format=lint-xml');
}
public function getDefaultFlags() {
// TODO: Deprecation warning.
$config = $this->getEngine()->getConfigurationManager();
- return $config->getConfigFromAnySource('lint.csslint.options');
+ return $config->getConfigFromAnySource('lint.csslint.options', array());
}
public function getDefaultBinary() {
diff --git a/src/lint/linter/ArcanistExternalLinter.php b/src/lint/linter/ArcanistExternalLinter.php
--- a/src/lint/linter/ArcanistExternalLinter.php
+++ b/src/lint/linter/ArcanistExternalLinter.php
@@ -117,11 +117,11 @@
* Flags which are not mandatory should be provided in
* @{method:getDefaultFlags} instead.
*
- * @return string|null Mandatory flags, like `"--format=xml"`.
+ * @return list<string> Mandatory flags, like `"--format=xml"`.
* @task bin
*/
protected function getMandatoryFlags() {
- return null;
+ return array();
}
@@ -133,11 +133,11 @@
*
* Default flags can be overridden with @{method:setFlags}.
*
- * @return string|null Overridable default flags.
+ * @return list<string> Overridable default flags.
* @task bin
*/
protected function getDefaultFlags() {
- return null;
+ return array();
}
@@ -145,12 +145,12 @@
* Override default flags with custom flags. If not overridden, flags provided
* by @{method:getDefaultFlags} are used.
*
- * @param string New flags.
+ * @param list<string> New flags.
* @return this
* @task bin
*/
final public function setFlags($flags) {
- $this->flags = $flags;
+ $this->flags = (array) $flags;
return $this;
}
@@ -348,21 +348,32 @@
* Get the composed flags for the executable, including both mandatory and
* configured flags.
*
- * @return string Composed flags.
+ * @return list<string> Composed flags.
* @task exec
*/
protected function getCommandFlags() {
- return csprintf(
- '%C %C',
- $this->getMandatoryFlags(),
- coalesce($this->flags, $this->getDefaultFlags()));
+ $mandatory_flags = $this->getMandatoryFlags();
+ if (!is_array($mandatory_flags)) {
+ phutil_deprecated(
+ 'String support for flags.', 'You should use list<string> instead.');
+ $mandatory_flags = (array) $mandatory_flags;
+ }
+
+ $flags = nonempty($this->flags, $this->getDefaultFlags());
+ if (!is_array($flags)) {
+ phutil_deprecated(
+ 'String support for flags.', 'You should use list<string> instead.');
+ $flags = (array) $flags;
+ }
+
+ return array_merge($mandatory_flags, $flags);
}
protected function buildFutures(array $paths) {
$executable = $this->getExecutableCommand();
- $bin = csprintf('%C %C', $executable, $this->getCommandFlags());
+ $bin = csprintf('%C %Ls', $executable, $this->getCommandFlags());
$futures = array();
foreach ($paths as $path) {
@@ -410,7 +421,7 @@
public function getLinterConfigurationOptions() {
$options = array(
'bin' => 'optional string | list<string>',
- 'flags' => 'optional string',
+ 'flags' => 'optional list<string>',
);
if ($this->shouldUseInterpreter()) {
@@ -465,9 +476,13 @@
throw new Exception(
pht('None of the configured binaries can be located.'));
case 'flags':
- if (strlen($value)) {
- $this->setFlags($value);
+ if (!is_array($value)) {
+ phutil_deprecated(
+ 'String support for flags.',
+ 'You should use list<string> instead.');
+ $value = (array) $value;
}
+ $this->setFlags($value);
return;
}
diff --git a/src/lint/linter/ArcanistFlake8Linter.php b/src/lint/linter/ArcanistFlake8Linter.php
--- a/src/lint/linter/ArcanistFlake8Linter.php
+++ b/src/lint/linter/ArcanistFlake8Linter.php
@@ -19,7 +19,7 @@
public function getDefaultFlags() {
// TODO: Deprecated.
$config = $this->getEngine()->getConfigurationManager();
- return $config->getConfigFromAnySource('lint.flake8.options', '');
+ return $config->getConfigFromAnySource('lint.flake8.options', array());
}
public function getDefaultBinary() {
diff --git a/src/lint/linter/ArcanistPEP8Linter.php b/src/lint/linter/ArcanistPEP8Linter.php
--- a/src/lint/linter/ArcanistPEP8Linter.php
+++ b/src/lint/linter/ArcanistPEP8Linter.php
@@ -17,7 +17,7 @@
public function getCacheVersion() {
list($stdout) = execx('%C --version', $this->getExecutableCommand());
- return $stdout.$this->getCommandFlags();
+ return $stdout.implode(' ', $this->getCommandFlags());
}
public function getDefaultFlags() {
@@ -25,7 +25,7 @@
$config = $this->getEngine()->getConfigurationManager();
return $config->getConfigFromAnySource(
'lint.pep8.options',
- $this->getConfig('options'));
+ $this->getConfig('options', array()));
}
public function shouldUseInterpreter() {
diff --git a/src/lint/linter/ArcanistPhpcsLinter.php b/src/lint/linter/ArcanistPhpcsLinter.php
--- a/src/lint/linter/ArcanistPhpcsLinter.php
+++ b/src/lint/linter/ArcanistPhpcsLinter.php
@@ -26,7 +26,7 @@
}
public function getMandatoryFlags() {
- return '--report=xml';
+ return array('--report=xml');
}
public function getInstallInstructions() {
@@ -38,10 +38,16 @@
$config = $this->getEngine()->getConfigurationManager();
- $options = $config->getConfigFromAnySource('lint.phpcs.options');
+ $options = $config->getConfigFromAnySource('lint.phpcs.options', array());
$standard = $config->getConfigFromAnySource('lint.phpcs.standard');
- $options .= !empty($standard) ? ' --standard=' . $standard : '';
+ if (!empty($standard)) {
+ if (is_array($options)) {
+ $options[] = '--standard='.$standard;
+ } else {
+ $options .= ' --standard='.$standard;
+ }
+ }
return $options;
}
diff --git a/src/lint/linter/ArcanistRubyLinter.php b/src/lint/linter/ArcanistRubyLinter.php
--- a/src/lint/linter/ArcanistRubyLinter.php
+++ b/src/lint/linter/ArcanistRubyLinter.php
@@ -41,7 +41,7 @@
protected function getMandatoryFlags() {
// -w: turn on warnings
// -c: check syntax
- return '-w -c';
+ return array('-w', '-c');
}
protected function getDefaultMessageSeverity($code) {

File Metadata

Mime Type
text/plain
Expires
Wed, Mar 26, 4:04 AM (1 w, 1 d ago)
Storage Engine
blob
Storage Format
Encrypted (AES-256-CBC)
Storage Handle
7534306
Default Alt Text
D8387.diff (6 KB)

Event Timeline