mirror of
https://we.phorge.it/source/arcanist.git
synced 2024-11-28 17:52:42 +01:00
Move some VCS-specific logic into VCS APIs
Summary: We have some git-specific logic on main pathways which should be in the API class, move it around so "arc lint" with an engine works under Mercurial. This resovles the error @makinde reported: > PHP Catchable fatal error: Argument 1 passed to ArcanistBaseWorkflow::parseGitRelativeCommit() must be an instance of ArcanistGitAPI, instance of ArcanistMercurialAPI given, called in /home/makinde/.arc_install/arcanist/src/workflow/lint/ArcanistLintWorkflow.php on line 131 and defined in /home/makinde/.arc_install/arcanist/src/workflow/base/ArcanistBaseWorkflow.php on line 830 Test Plan: Ran "arc diff" in git and hg working copies, plus "arc lint" with a configured "lint_engine". Reviewers: Makinde, aran, jungejason, nh, tuomaspelkonen Reviewed By: Makinde CC: aran, Makinde Differential Revision: 935
This commit is contained in:
parent
9df1b8a4bd
commit
31ec011922
9 changed files with 85 additions and 43 deletions
|
@ -159,4 +159,15 @@ abstract class ArcanistRepositoryAPI {
|
||||||
abstract public function getCurrentFileData($path);
|
abstract public function getCurrentFileData($path);
|
||||||
abstract public function getLocalCommitInformation();
|
abstract public function getLocalCommitInformation();
|
||||||
|
|
||||||
|
|
||||||
|
abstract public function supportsRelativeLocalCommits();
|
||||||
|
|
||||||
|
public function parseRelativeLocalCommit(array $argv) {
|
||||||
|
throw new Exception("This VCS does not support relative local commits.");
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getAllLocalChanges() {
|
||||||
|
throw new Exception("This VCS does not support getting all local changes.");
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -512,4 +512,37 @@ class ArcanistGitAPI extends ArcanistRepositoryAPI {
|
||||||
return trim($owner);
|
return trim($owner);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function supportsRelativeLocalCommits() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function parseRelativeLocalCommit(array $argv) {
|
||||||
|
if (count($argv) == 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (count($argv) != 1) {
|
||||||
|
throw new ArcanistUsageException("Specify only one commit.");
|
||||||
|
}
|
||||||
|
$base = reset($argv);
|
||||||
|
if ($base == ArcanistGitAPI::GIT_MAGIC_ROOT_COMMIT) {
|
||||||
|
$merge_base = $base;
|
||||||
|
} else {
|
||||||
|
list($err, $merge_base) = exec_manual(
|
||||||
|
'(cd %s; git merge-base %s HEAD)',
|
||||||
|
$this->getPath(),
|
||||||
|
$base);
|
||||||
|
if ($err) {
|
||||||
|
throw new ArcanistUsageException(
|
||||||
|
"Unable to parse git commit name '{$base}'.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$this->setRelativeCommit(trim($merge_base));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getAllLocalChanges() {
|
||||||
|
$diff = $this->getFullGitDiff();
|
||||||
|
$parser = new ArcanistDiffParser();
|
||||||
|
return $parser->parseDiff($diff);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,8 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_module('arcanist', 'exception/usage');
|
||||||
|
phutil_require_module('arcanist', 'parser/diff');
|
||||||
phutil_require_module('arcanist', 'repository/api/base');
|
phutil_require_module('arcanist', 'repository/api/base');
|
||||||
|
|
||||||
phutil_require_module('phutil', 'future');
|
phutil_require_module('phutil', 'future');
|
||||||
|
|
|
@ -374,4 +374,26 @@ class ArcanistMercurialAPI extends ArcanistRepositoryAPI {
|
||||||
return trim($match[1]);
|
return trim($match[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function supportsRelativeLocalCommits() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function parseRelativeLocalCommit(array $argv) {
|
||||||
|
if (count($argv) == 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (count($argv) != 1) {
|
||||||
|
throw new ArcanistUsageException("Specify only one commit.");
|
||||||
|
}
|
||||||
|
// This does the "hg id" call we need to normalize/validate the revision
|
||||||
|
// identifier.
|
||||||
|
$this->setRelativeCommit(reset($argv));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getAllLocalChanges() {
|
||||||
|
$diff = $this->getFullMercurialDiff();
|
||||||
|
$parser = new ArcanistDiffParser();
|
||||||
|
return $parser->parseDiff($diff);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -482,4 +482,8 @@ EODIFF;
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function supportsRelativeCommits() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -768,6 +768,8 @@ class ArcanistBaseWorkflow {
|
||||||
$repository_api = $this->getRepositoryAPI();
|
$repository_api = $this->getRepositoryAPI();
|
||||||
|
|
||||||
if ($repository_api instanceof ArcanistSubversionAPI) {
|
if ($repository_api instanceof ArcanistSubversionAPI) {
|
||||||
|
// NOTE: In SVN, we don't currently support a "get all local changes"
|
||||||
|
// operation, so special case it.
|
||||||
if (empty($this->changeCache[$path])) {
|
if (empty($this->changeCache[$path])) {
|
||||||
$diff = $repository_api->getRawDiffText($path);
|
$diff = $repository_api->getRawDiffText($path);
|
||||||
$parser = new ArcanistDiffParser();
|
$parser = new ArcanistDiffParser();
|
||||||
|
@ -777,15 +779,15 @@ class ArcanistBaseWorkflow {
|
||||||
}
|
}
|
||||||
$this->changeCache[$path] = reset($changes);
|
$this->changeCache[$path] = reset($changes);
|
||||||
}
|
}
|
||||||
} else {
|
} else if ($repository_api->supportsRelativeLocalCommits()) {
|
||||||
if (empty($this->changeCache)) {
|
if (empty($this->changeCache)) {
|
||||||
$diff = $repository_api->getFullGitDiff();
|
$changes = $repository_api->getAllLocalChanges();
|
||||||
$parser = new ArcanistDiffParser();
|
|
||||||
$changes = $parser->parseDiff($diff);
|
|
||||||
foreach ($changes as $change) {
|
foreach ($changes as $change) {
|
||||||
$this->changeCache[$change->getCurrentPath()] = $change;
|
$this->changeCache[$change->getCurrentPath()] = $change;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
throw new Exception("Missing VCS support.");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (empty($this->changeCache[$path])) {
|
if (empty($this->changeCache[$path])) {
|
||||||
|
@ -827,30 +829,6 @@ class ArcanistBaseWorkflow {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function parseGitRelativeCommit(ArcanistGitAPI $api, array $argv) {
|
|
||||||
if (count($argv) == 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (count($argv) != 1) {
|
|
||||||
throw new ArcanistUsageException(
|
|
||||||
"Specify exactly one commit.");
|
|
||||||
}
|
|
||||||
$base = reset($argv);
|
|
||||||
if ($base == ArcanistGitAPI::GIT_MAGIC_ROOT_COMMIT) {
|
|
||||||
$merge_base = $base;
|
|
||||||
} else {
|
|
||||||
list($err, $merge_base) = exec_manual(
|
|
||||||
'(cd %s; git merge-base %s HEAD)',
|
|
||||||
$api->getPath(),
|
|
||||||
$base);
|
|
||||||
if ($err) {
|
|
||||||
throw new ArcanistUsageException(
|
|
||||||
"Unable to parse git commit name '{$base}'.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$api->setRelativeCommit(trim($merge_base));
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function normalizeRevisionID($revision_id) {
|
protected function normalizeRevisionID($revision_id) {
|
||||||
return ltrim(strtoupper($revision_id), 'D');
|
return ltrim(strtoupper($revision_id), 'D');
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,6 @@ phutil_require_module('arcanist', 'exception/usage/userabort');
|
||||||
phutil_require_module('arcanist', 'parser/bundle');
|
phutil_require_module('arcanist', 'parser/bundle');
|
||||||
phutil_require_module('arcanist', 'parser/diff');
|
phutil_require_module('arcanist', 'parser/diff');
|
||||||
phutil_require_module('arcanist', 'parser/diff/change');
|
phutil_require_module('arcanist', 'parser/diff/change');
|
||||||
phutil_require_module('arcanist', 'repository/api/git');
|
|
||||||
|
|
||||||
phutil_require_module('phutil', 'conduit/client');
|
phutil_require_module('phutil', 'conduit/client');
|
||||||
phutil_require_module('phutil', 'console');
|
phutil_require_module('phutil', 'console');
|
||||||
|
|
|
@ -603,17 +603,10 @@ EOTEXT
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if ($repository_api instanceof ArcanistGitAPI) {
|
} else if ($repository_api->supportsRelativeLocalCommits()) {
|
||||||
$this->parseGitRelativeCommit(
|
$repository_api->parseRelativeLocalCommit(
|
||||||
$repository_api,
|
|
||||||
$this->getArgument('paths', array()));
|
$this->getArgument('paths', array()));
|
||||||
$paths = $repository_api->getWorkingCopyStatus();
|
$paths = $repository_api->getWorkingCopyStatus();
|
||||||
} else if ($repository_api instanceof ArcanistMercurialAPI) {
|
|
||||||
// TODO: Unify this and the previous block.
|
|
||||||
|
|
||||||
// TODO: Parse the relative commit.
|
|
||||||
|
|
||||||
$paths = $repository_api->getWorkingCopyStatus();
|
|
||||||
} else {
|
} else {
|
||||||
throw new Exception("Unknown VCS!");
|
throw new Exception("Unknown VCS!");
|
||||||
}
|
}
|
||||||
|
|
|
@ -125,11 +125,12 @@ EOTEXT
|
||||||
unset($paths[$path]);
|
unset($paths[$path]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else if ($repository_api->supportsRelativeLocalCommits()) {
|
||||||
$this->parseGitRelativeCommit(
|
$repository_api->parseRelativeLocalCommit(
|
||||||
$repository_api,
|
$this->getArgument('paths', array()));
|
||||||
$this->getArgument('paths'));
|
|
||||||
$paths = $repository_api->getWorkingCopyStatus();
|
$paths = $repository_api->getWorkingCopyStatus();
|
||||||
|
} else {
|
||||||
|
throw new Exception("Unknown VCS!");
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach ($paths as $path => $flags) {
|
foreach ($paths as $path => $flags) {
|
||||||
|
@ -139,7 +140,6 @@ EOTEXT
|
||||||
}
|
}
|
||||||
|
|
||||||
$paths = array_keys($paths);
|
$paths = array_keys($paths);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
$paths = $this->getArgument('paths');
|
$paths = $this->getArgument('paths');
|
||||||
if (empty($paths)) {
|
if (empty($paths)) {
|
||||||
|
|
Loading…
Reference in a new issue