1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-17 10:11: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:
vrana 2013-02-25 16:24:59 -08:00
parent bb08b8c905
commit 507a96130c

View file

@ -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