mirror of
https://we.phorge.it/source/arcanist.git
synced 2025-01-11 07:11:03 +01:00
Improve PEP8 Linter
Summary: This cleans up the PEP8 linter to bring it inline with the new JSHint Linter's level of quality. It adds a getPEP8Path method which gives the ability for users to override the pep8 binary with two new options in .arcconfig: * lint.pep8.prefix * lint.pep8.bin * lint.pep8.options Test Plan: Adjust your engine to use the 'ArcanistPEP8Linter' and run arc lint against Python files. Reviewers: epriestley Reviewed By: epriestley CC: aran Differential Revision: https://secure.phabricator.com/D1440
This commit is contained in:
parent
9be9554f2d
commit
06334a69b4
3 changed files with 63 additions and 12 deletions
|
@ -99,7 +99,7 @@ phutil_register_library_map(array(
|
||||||
'ArcanistXHPASTLinter' => 'lint/linter/xhpast',
|
'ArcanistXHPASTLinter' => 'lint/linter/xhpast',
|
||||||
'ArcanistXHPASTLinterTestCase' => 'lint/linter/xhpast/__tests__',
|
'ArcanistXHPASTLinterTestCase' => 'lint/linter/xhpast/__tests__',
|
||||||
'BranchInfo' => 'branch',
|
'BranchInfo' => 'branch',
|
||||||
'ComprehensiveEngine' => 'lint/engine/comprehensive',
|
'ComprehensiveLintEngine' => 'lint/engine/comprehensive',
|
||||||
'ExampleLintEngine' => 'lint/engine/example',
|
'ExampleLintEngine' => 'lint/engine/example',
|
||||||
'PhutilLintEngine' => 'lint/engine/phutil',
|
'PhutilLintEngine' => 'lint/engine/phutil',
|
||||||
'PhutilModuleRequirements' => 'parser/phutilmodule',
|
'PhutilModuleRequirements' => 'parser/phutilmodule',
|
||||||
|
@ -166,7 +166,7 @@ phutil_register_library_map(array(
|
||||||
'ArcanistUserAbortException' => 'ArcanistUsageException',
|
'ArcanistUserAbortException' => 'ArcanistUsageException',
|
||||||
'ArcanistXHPASTLinter' => 'ArcanistLinter',
|
'ArcanistXHPASTLinter' => 'ArcanistLinter',
|
||||||
'ArcanistXHPASTLinterTestCase' => 'ArcanistLinterTestCase',
|
'ArcanistXHPASTLinterTestCase' => 'ArcanistLinterTestCase',
|
||||||
'ComprehensiveEngine' => 'ArcanistLintEngine',
|
'ComprehensiveLintEngine' => 'ArcanistLintEngine',
|
||||||
'ExampleLintEngine' => 'ArcanistLintEngine',
|
'ExampleLintEngine' => 'ArcanistLintEngine',
|
||||||
'PhutilLintEngine' => 'ArcanistLintEngine',
|
'PhutilLintEngine' => 'ArcanistLintEngine',
|
||||||
'PhutilUnitTestEngine' => 'ArcanistBaseUnitTestEngine',
|
'PhutilUnitTestEngine' => 'ArcanistBaseUnitTestEngine',
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2011 Facebook, Inc.
|
* Copyright 2012 Facebook, Inc.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -36,25 +36,73 @@ class ArcanistPEP8Linter extends ArcanistLinter {
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getLintNameMap() {
|
public function getLintNameMap() {
|
||||||
return array(
|
return array();
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getPEP8Options() {
|
public function getPEP8Options() {
|
||||||
// W293 (blank line contains whitespace) is redundant when used
|
$working_copy = $this->getEngine()->getWorkingCopy();
|
||||||
// alongside TXT6, causing pain to python programmers.
|
$options = $working_copy->getConfig('lint.pep8.options');
|
||||||
return '--ignore=W293';
|
|
||||||
|
if ($options === null) {
|
||||||
|
// W293 (blank line contains whitespace) is redundant when used
|
||||||
|
// alongside TXT6, causing pain to python programmers.
|
||||||
|
return '--ignore=W293';
|
||||||
|
}
|
||||||
|
|
||||||
|
return $options;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getPEP8Path() {
|
||||||
|
$working_copy = $this->getEngine()->getWorkingCopy();
|
||||||
|
$prefix = $working_copy->getConfig('lint.pep8.prefix');
|
||||||
|
$bin = $working_copy->getConfig('lint.pep8.bin');
|
||||||
|
|
||||||
|
if ($bin === null && $prefix === null) {
|
||||||
|
$bin = csprintf('/usr/bin/env python2.6 %s',
|
||||||
|
phutil_get_library_root('arcanist').
|
||||||
|
'/../externals/pep8/pep8.py');
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if ($bin === null) {
|
||||||
|
$bin = 'pep8';
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($prefix !== null) {
|
||||||
|
if (!Filesystem::pathExists($prefix.'/'.$bin)) {
|
||||||
|
throw new ArcanistUsageException(
|
||||||
|
"Unable to find PEP8 binary in a specified directory. Make sure ".
|
||||||
|
"that 'lint.pep8.prefix' and 'lint.pep8.bin' keys are set ".
|
||||||
|
"correctly. If you'd rather use a copy of PEP8 installed ".
|
||||||
|
"globally, you can just remove these keys from your .arcconfig");
|
||||||
|
}
|
||||||
|
|
||||||
|
$bin = csprintf("%s/%s", $prefix, $bin);
|
||||||
|
|
||||||
|
return $bin;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Look for globally installed PEP8
|
||||||
|
list($err) = exec_manual('which %s', $bin);
|
||||||
|
if ($err) {
|
||||||
|
throw new ArcanistUsageException(
|
||||||
|
"PEP8 does not appear to be installed on this system. Install it ".
|
||||||
|
"(e.g., with 'easy_install pep8') or configure ".
|
||||||
|
"'lint.pep8.prefix' in your .arcconfig to point to the directory ".
|
||||||
|
"where it resides.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $bin;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function lintPath($path) {
|
public function lintPath($path) {
|
||||||
$pep8_bin = phutil_get_library_root('arcanist').
|
$pep8_bin = $this->getPEP8Path();
|
||||||
'/../externals/pep8/pep8.py';
|
|
||||||
|
|
||||||
$options = $this->getPEP8Options();
|
$options = $this->getPEP8Options();
|
||||||
|
|
||||||
list($rc, $stdout) = exec_manual(
|
list($rc, $stdout) = exec_manual(
|
||||||
"/usr/bin/env python2.6 %s {$options} %s",
|
"%C %C %s",
|
||||||
$pep8_bin,
|
$pep8_bin,
|
||||||
|
$options,
|
||||||
$this->getEngine()->getFilePathOnDisk($path));
|
$this->getEngine()->getFilePathOnDisk($path));
|
||||||
|
|
||||||
$lines = explode("\n", $stdout);
|
$lines = explode("\n", $stdout);
|
||||||
|
|
|
@ -6,12 +6,15 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_module('arcanist', 'exception/usage');
|
||||||
phutil_require_module('arcanist', 'lint/linter/base');
|
phutil_require_module('arcanist', 'lint/linter/base');
|
||||||
phutil_require_module('arcanist', 'lint/message');
|
phutil_require_module('arcanist', 'lint/message');
|
||||||
phutil_require_module('arcanist', 'lint/severity');
|
phutil_require_module('arcanist', 'lint/severity');
|
||||||
|
|
||||||
|
phutil_require_module('phutil', 'filesystem');
|
||||||
phutil_require_module('phutil', 'future/exec');
|
phutil_require_module('phutil', 'future/exec');
|
||||||
phutil_require_module('phutil', 'moduleutils');
|
phutil_require_module('phutil', 'moduleutils');
|
||||||
|
phutil_require_module('phutil', 'xsprintf/csprintf');
|
||||||
|
|
||||||
|
|
||||||
phutil_require_source('ArcanistPEP8Linter.php');
|
phutil_require_source('ArcanistPEP8Linter.php');
|
||||||
|
|
Loading…
Reference in a new issue