mirror of
https://we.phorge.it/source/arcanist.git
synced 2025-01-01 10:20:58 +01:00
Provide more information about merge progress in "arc land" under Git
Summary: Ref T13546. Communicate more progress information and provide additional details when merge conflicts occur. Test Plan: Hit a merge conflict, saw more helpful output. Maniphest Tasks: T13546 Differential Revision: https://secure.phabricator.com/D21318
This commit is contained in:
parent
1552397c86
commit
94f78cf87c
1 changed files with 43 additions and 9 deletions
|
@ -235,11 +235,13 @@ final class ArcanistGitLandEngine
|
|||
|
||||
protected function executeMerge(ArcanistLandCommitSet $set, $into_commit) {
|
||||
$api = $this->getRepositoryAPI();
|
||||
$log = $this->getLogEngine();
|
||||
|
||||
$this->updateWorkingCopy($into_commit);
|
||||
|
||||
$commits = $set->getCommits();
|
||||
$source_commit = last($commits)->getHash();
|
||||
$max_commit = last($commits);
|
||||
$source_commit = $max_commit->getHash();
|
||||
|
||||
// NOTE: See T11435 for some history. See PHI1727 for a case where a user
|
||||
// modified their working copy while running "arc land". This attempts to
|
||||
|
@ -263,10 +265,15 @@ final class ArcanistGitLandEngine
|
|||
$this->getDisplayHash($into_commit)));
|
||||
}
|
||||
|
||||
list($original_author, $original_date) = $this->getAuthorAndDate(
|
||||
$source_commit);
|
||||
$log->writeStatus(
|
||||
pht('MERGING'),
|
||||
pht(
|
||||
'%s %s',
|
||||
$this->getDisplayHash($source_commit),
|
||||
$max_commit->getDisplaySummary()));
|
||||
|
||||
try {
|
||||
|
||||
if ($this->isSquashStrategy()) {
|
||||
// NOTE: We're explicitly specifying "--ff" to override the presence
|
||||
// of "merge.ff" options in user configuration.
|
||||
|
@ -280,17 +287,44 @@ final class ArcanistGitLandEngine
|
|||
$source_commit);
|
||||
}
|
||||
} catch (CommandException $ex) {
|
||||
|
||||
// TODO: If we previously succeeded with at least one merge, we could
|
||||
// provide a hint that "--incremental" can do some of the work.
|
||||
|
||||
$api->execManualLocal('merge --abort');
|
||||
$api->execManualLocal('reset --hard HEAD --');
|
||||
|
||||
throw new PhutilArgumentUsageException(
|
||||
pht(
|
||||
'Local "%s" does not merge cleanly into "%s". Merge or rebase '.
|
||||
'local changes so they can merge cleanly.',
|
||||
$source_commit,
|
||||
$into_commit));
|
||||
$direct_symbols = $max_commit->getDirectSymbols();
|
||||
$indirect_symbols = $max_commit->getIndirectSymbols();
|
||||
if ($direct_symbols) {
|
||||
$message = pht(
|
||||
'Local commit "%s" (%s) does not merge cleanly into "%s". '.
|
||||
'Merge or rebase local changes so they can merge cleanly.',
|
||||
$this->getDisplayHash($source_commit),
|
||||
$this->getDisplaySymbols($direct_symbols),
|
||||
$this->getDisplayHash($into_commit));
|
||||
} else if ($indirect_symbols) {
|
||||
$message = pht(
|
||||
'Local commit "%s" (reachable from: %s) does not merge cleanly '.
|
||||
'into "%s". Merge or rebase local changes so they can merge '.
|
||||
'cleanly.',
|
||||
$this->getDisplayHash($source_commit),
|
||||
$this->getDisplaySymbols($indirect_symbols),
|
||||
$this->getDisplayHash($into_commit));
|
||||
} else {
|
||||
$message = pht(
|
||||
'Local commit "%s" does not merge cleanly into "%s". Merge or '.
|
||||
'rebase local changes so they can merge cleanly.',
|
||||
$this->getDisplayHash($source_commit),
|
||||
$this->getDisplayHash($into_commit));
|
||||
}
|
||||
|
||||
throw new PhutilArgumentUsageException($message);
|
||||
}
|
||||
|
||||
list($original_author, $original_date) = $this->getAuthorAndDate(
|
||||
$source_commit);
|
||||
|
||||
$revision_ref = $set->getRevisionRef();
|
||||
$commit_message = $revision_ref->getCommitMessage();
|
||||
|
||||
|
|
Loading…
Reference in a new issue