mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-20 03:31:10 +01:00
Set cache granularity for Javelin linter
Test Plan: Made an error, rebuilt the map, linted the file, saw the error. Reviewers: epriestley Reviewed By: epriestley CC: aran, Korvin Differential Revision: https://secure.phabricator.com/D5113
This commit is contained in:
parent
bb08b8c905
commit
507a96130c
1 changed files with 26 additions and 10 deletions
|
@ -4,7 +4,7 @@ final class PhabricatorJavelinLinter extends ArcanistLinter {
|
||||||
|
|
||||||
private $symbols = array();
|
private $symbols = array();
|
||||||
|
|
||||||
private $haveSymbolsBinary;
|
private $symbolsBinary;
|
||||||
private $haveWarnedAboutBinary;
|
private $haveWarnedAboutBinary;
|
||||||
|
|
||||||
const LINT_PRIVATE_ACCESS = 1;
|
const LINT_PRIVATE_ACCESS = 1;
|
||||||
|
@ -13,19 +13,22 @@ final class PhabricatorJavelinLinter extends ArcanistLinter {
|
||||||
const LINT_UNKNOWN_DEPENDENCY = 4;
|
const LINT_UNKNOWN_DEPENDENCY = 4;
|
||||||
const LINT_MISSING_BINARY = 5;
|
const LINT_MISSING_BINARY = 5;
|
||||||
|
|
||||||
|
private function getBinaryPath() {
|
||||||
|
if ($this->symbolsBinary === null) {
|
||||||
|
list($err, $stdout) = exec_manual('which javelinsymbols');
|
||||||
|
$this->symbolsBinary = ($err ? false : rtrim($stdout));
|
||||||
|
}
|
||||||
|
return $this->symbolsBinary;
|
||||||
|
}
|
||||||
|
|
||||||
public function willLintPaths(array $paths) {
|
public function willLintPaths(array $paths) {
|
||||||
|
if (!$this->getBinaryPath()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
$root = dirname(phutil_get_library_root('phabricator'));
|
$root = dirname(phutil_get_library_root('phabricator'));
|
||||||
require_once $root.'/scripts/__init_script__.php';
|
require_once $root.'/scripts/__init_script__.php';
|
||||||
|
|
||||||
if ($this->haveSymbolsBinary === null) {
|
|
||||||
list($err) = exec_manual('which javelinsymbols');
|
|
||||||
$this->haveSymbolsBinary = !$err;
|
|
||||||
if (!$this->haveSymbolsBinary) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$futures = array();
|
$futures = array();
|
||||||
foreach ($paths as $path) {
|
foreach ($paths as $path) {
|
||||||
if ($this->shouldIgnorePath($path)) {
|
if ($this->shouldIgnorePath($path)) {
|
||||||
|
@ -61,6 +64,19 @@ final class PhabricatorJavelinLinter extends ArcanistLinter {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getCacheGranularity() {
|
||||||
|
return ArcanistLinter::GRANULARITY_REPOSITORY;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getCacheVersion() {
|
||||||
|
$version = '0';
|
||||||
|
$binary_path = $this->getBinaryPath();
|
||||||
|
if ($binary_path) {
|
||||||
|
$version .= '-'.md5_file($binary_path);
|
||||||
|
}
|
||||||
|
return $version;
|
||||||
|
}
|
||||||
|
|
||||||
private function shouldIgnorePath($path) {
|
private function shouldIgnorePath($path) {
|
||||||
return preg_match('@/__tests__/|externals/javelinjs/src/docs/@', $path);
|
return preg_match('@/__tests__/|externals/javelinjs/src/docs/@', $path);
|
||||||
}
|
}
|
||||||
|
@ -70,7 +86,7 @@ final class PhabricatorJavelinLinter extends ArcanistLinter {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$this->haveSymbolsBinary) {
|
if (!$this->symbolsBinary) {
|
||||||
if (!$this->haveWarnedAboutBinary) {
|
if (!$this->haveWarnedAboutBinary) {
|
||||||
$this->haveWarnedAboutBinary = true;
|
$this->haveWarnedAboutBinary = true;
|
||||||
// TODO: Write build documentation for the Javelin binaries and point
|
// TODO: Write build documentation for the Javelin binaries and point
|
||||||
|
|
Loading…
Reference in a new issue