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

Allow anyone to run arc commit on an accepted revision

Test Plan:
Using SVN make some changes to the repo, run `arc diff`.  As other user accept
the revision, add the changes to your repo using `arc patch` and then run `arc
commit --revision revisionID` to commit them.  Arcanist should ask if you are
sure that you want to commit this revision and if you answer `Y` it should
commit to SNV repo.

Reviewers: epriestley, jungejason

Reviewed By: epriestley

CC: aran, mareksapota, epriestley

Differential Revision: 1055
This commit is contained in:
Marek Sapota 2011-10-25 20:03:41 -07:00
parent ebc2644994
commit bb05ddfb5a
2 changed files with 71 additions and 29 deletions

View file

@ -68,6 +68,9 @@ EOTEXT
$repository_api = $this->getRepositoryAPI();
$conduit = $this->getConduit();
$revision_id = $this->getArgument('revision');
if (!$revision_id) {
$revision_data = $conduit->callMethodSynchronous(
'differential.find',
array(
@ -75,26 +78,53 @@ EOTEXT
'guids' => array(
$this->getUserPHID(),
),
));
)
);
try {
$revision_id = $this->getArgument('revision');
$revision = $this->chooseRevision(
$revision_data,
$revision_id,
'Which revision do you want to commit?');
} catch (ArcanistChooseInvalidRevisionException $ex) {
throw new ArcanistUsageException(
"Revision D{$revision_id} is not committable. You can only commit ".
"revisions you own which have been 'accepted'.");
null,
'Which revision do you want to commit?'
);
$revision_id = $revision->getID();
} catch (ArcanistChooseNoRevisionsException $ex) {
throw new ArcanistUsageException(
"You have no committable Differential revisions. You can only commit ".
"revisions you own which have been 'accepted'.");
"You have no committable Differential revisions. You can only ".
"commit revisions which have been 'accepted'.");
}
}
$revision_id = $revision->getID();
$revision_name = $revision->getName();
$revision = null;
try {
$revision = $conduit->callMethodSynchronous(
'differential.getrevision',
array(
'revision_id' => $revision_id,
)
);
} catch (Exception $ex) {
throw new ArcanistUsageException(
"Revision D{$revision_id} does not exist."
);
}
if ($revision['statusName'] != 'Accepted') {
throw new ArcanistUsageException(
"Revision D{$revision_id} is not committable. You can only commit ".
"revisions which have been 'accepted'."
);
}
if ($revision['authorPHID'] != $this->getUserPHID()) {
$prompt = "You are not the author of revision D{$revision_id}, ".
'are you sure you want to commit it?';
if (!phutil_console_confirm($prompt)) {
throw new ArcanistUserAbortException();
}
}
$revision_name = $revision['title'];
$message = $conduit->callMethodSynchronous(
'differential.getcommitmessage',
@ -140,8 +170,7 @@ EOTEXT
return $err;
}
protected function getCommitFileList(
ArcanistDifferentialRevisionRef $revision) {
protected function getCommitFileList(array $revision) {
$repository_api = $this->getRepositoryAPI();
if (!($repository_api instanceof ArcanistSubversionAPI)) {
@ -151,9 +180,22 @@ EOTEXT
$conduit = $this->getConduit();
$revision_id = $revision->getID();
$revision_id = $revision['id'];
$revision = reset($conduit->callMethodSynchronous(
'differential.find',
array(
'query' => 'revision-ids',
'guids' => array($revision_id,)
)
));
if (!$revision) {
throw new ArcanistUsageException(
"Revision D{$revision_id} does not exist."
);
}
$revision_source = $revision['sourcePath'];
$revision_source = $revision->getSourcePath();
$working_copy = $repository_api->getPath();
if ($revision_source != $working_copy) {
$prompt =

View file

@ -106,7 +106,7 @@ EOTEXT
}
if ($revision) {
if ($revision['authorPHID'] != $this->getUserPHID()) {
if (!$is_finalize && $revision['authorPHID'] != $this->getUserPHID()) {
$prompt = "You are not the author of revision D{$revision_id}, ".
'are you sure you want to mark it committed?';
if (!phutil_console_confirm($prompt)) {