1
0
Fork 0
mirror of https://we.phorge.it/source/arcanist.git synced 2025-01-11 15:21:03 +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( return array(
'show' => array( 'show' => array(
'help' => 'help' =>
"Show the amended commit message." "Show the amended commit message, without modifying the working copy."
), ),
'revision' => array( 'revision' => array(
'param' => 'revision_id', 'param' => 'revision_id',
@ -65,13 +65,7 @@ EOTEXT
} }
public function run() { public function run() {
if ($this->isHistoryImmutable()) { $is_show = $this->getArgument('show');
throw new ArcanistUsageException(
"This project is marked as adhering to a conservative history ".
"mutability doctrine (having an immutable local history), which ".
"precludes amending commit messages. You can use 'arc merge' to ".
"merge feature branches instead.");
}
$repository_api = $this->getRepositoryAPI(); $repository_api = $this->getRepositoryAPI();
if (!($repository_api instanceof ArcanistGitAPI)) { if (!($repository_api instanceof ArcanistGitAPI)) {
@ -79,10 +73,20 @@ EOTEXT
"You may only run 'arc amend' in a git working copy."); "You may only run 'arc amend' in a git working copy.");
} }
if ($repository_api->getUncommittedChanges()) { if (!$is_show) {
throw new ArcanistUsageException( if ($this->isHistoryImmutable()) {
"You have uncommitted changes in this branch. Stage and commit (or ". throw new ArcanistUsageException(
"revert) them before proceeding."); "This project is marked as adhering to a conservative history ".
"mutability doctrine (having an immutable local history), which ".
"precludes amending commit messages. You can use 'arc merge' to ".
"merge feature branches instead.");
}
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')) { if ($this->getArgument('revision')) {
@ -120,7 +124,7 @@ EOTEXT
'edit' => false, 'edit' => false,
)); ));
if ($this->getArgument('show')) { if ($is_show) {
echo $message."\n"; echo $message."\n";
} else { } else {
$repository_api->amendGitHeadCommit($message); $repository_api->amendGitHeadCommit($message);