1
0
Fork 0
mirror of https://we.phorge.it/source/arcanist.git synced 2025-01-25 22:18:18 +01:00

Don't do working copy checks for "arc amend --show"

Summary: See T587. Reduce the strictness of working copy checks when using
"--show", since there's a reasonable workflow where you 'arc patch' and then
'arc amend --revision X --show | git commit -a -F -' that currently won't work.
There are other ways to accomplish the same thing but this increases flexibility
overall.

Test Plan: Ran 'arc amend --show' with a dirty working copy, didn't get yelled
at.

Reviewers: jungejason, nh, tuomaspelkonen, aran

Reviewed By: nh

CC: aran, nh

Differential Revision: 1033
This commit is contained in:
epriestley 2011-10-23 12:55:43 -07:00
parent f41d6889d2
commit df8c0e5e25

View file

@ -53,7 +53,7 @@ EOTEXT
return array(
'show' => array(
'help' =>
"Show the amended commit message."
"Show the amended commit message, without modifying the working copy."
),
'revision' => array(
'param' => 'revision_id',
@ -65,6 +65,15 @@ EOTEXT
}
public function run() {
$is_show = $this->getArgument('show');
$repository_api = $this->getRepositoryAPI();
if (!($repository_api instanceof ArcanistGitAPI)) {
throw new ArcanistUsageException(
"You may only run 'arc amend' in a git working copy.");
}
if (!$is_show) {
if ($this->isHistoryImmutable()) {
throw new ArcanistUsageException(
"This project is marked as adhering to a conservative history ".
@ -73,17 +82,12 @@ EOTEXT
"merge feature branches instead.");
}
$repository_api = $this->getRepositoryAPI();
if (!($repository_api instanceof ArcanistGitAPI)) {
throw new ArcanistUsageException(
"You may only run 'arc amend' in a git working copy.");
}
if ($repository_api->getUncommittedChanges()) {
throw new ArcanistUsageException(
"You have uncommitted changes in this branch. Stage and commit (or ".
"revert) them before proceeding.");
}
}
if ($this->getArgument('revision')) {
$revision_id = $this->getArgument('revision');
@ -120,7 +124,7 @@ EOTEXT
'edit' => false,
));
if ($this->getArgument('show')) {
if ($is_show) {
echo $message."\n";
} else {
$repository_api->amendGitHeadCommit($message);