mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-05 12:21:02 +01:00
Mark revision as closed before attaching commit and loading changes
Summary: D3555 stopped multiple commenting but it still attaches multiple diffs. Save earlier to stop doing unnecessary work. Test Plan: Reparsed the same commit twice at the same time. Reviewers: epriestley Reviewed By: epriestley CC: aran, Korvin Differential Revision: https://secure.phabricator.com/D3598
This commit is contained in:
parent
78784aa1fe
commit
e84c18d734
1 changed files with 38 additions and 37 deletions
|
@ -100,6 +100,9 @@ abstract class PhabricatorRepositoryCommitMessageParserWorker
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($revision_id) {
|
if ($revision_id) {
|
||||||
|
$lock = PhabricatorGlobalLock::newLock(get_class($this).':'.$revision_id);
|
||||||
|
$lock->lock(5 * 60);
|
||||||
|
|
||||||
$revision = id(new DifferentialRevision())->load($revision_id);
|
$revision = id(new DifferentialRevision())->load($revision_id);
|
||||||
if ($revision) {
|
if ($revision) {
|
||||||
$revision->loadRelationships();
|
$revision->loadRelationships();
|
||||||
|
@ -110,44 +113,16 @@ abstract class PhabricatorRepositoryCommitMessageParserWorker
|
||||||
$revision->getID(),
|
$revision->getID(),
|
||||||
$commit->getPHID());
|
$commit->getPHID());
|
||||||
|
|
||||||
$committer_phid = $data->getCommitDetail('committerPHID');
|
|
||||||
if ($committer_phid) {
|
|
||||||
$handle = PhabricatorObjectHandleData::loadOneHandle($committer_phid);
|
|
||||||
$committer_name = '@'.$handle->getName();
|
|
||||||
} else {
|
|
||||||
$committer_name = $data->getCommitDetail('committer');
|
|
||||||
}
|
|
||||||
|
|
||||||
$author_phid = $data->getCommitDetail('authorPHID');
|
|
||||||
if ($author_phid) {
|
|
||||||
$handle = PhabricatorObjectHandleData::loadOneHandle($author_phid);
|
|
||||||
$author_name = '@'.$handle->getName();
|
|
||||||
} else {
|
|
||||||
$author_name = $data->getAuthorName();
|
|
||||||
}
|
|
||||||
|
|
||||||
$commit_name = $repository->formatCommitName(
|
|
||||||
$commit->getCommitIdentifier());
|
|
||||||
|
|
||||||
$info = array();
|
|
||||||
$info[] = "authored by {$author_name}";
|
|
||||||
if ($committer_name && ($committer_name != $author_name)) {
|
|
||||||
$info[] = "committed by {$committer_name}";
|
|
||||||
}
|
|
||||||
$info = implode(', ', $info);
|
|
||||||
|
|
||||||
$message = "Closed by commit {$commit_name} ({$info}).";
|
|
||||||
|
|
||||||
$actor_phid = nonempty(
|
|
||||||
$committer_phid,
|
|
||||||
$author_phid,
|
|
||||||
$revision->getAuthorPHID());
|
|
||||||
|
|
||||||
$status_closed = ArcanistDifferentialRevisionStatus::CLOSED;
|
$status_closed = ArcanistDifferentialRevisionStatus::CLOSED;
|
||||||
$should_close = ($revision->getStatus() != $status_closed) &&
|
$should_close = ($revision->getStatus() != $status_closed) &&
|
||||||
$should_autoclose;
|
$should_autoclose;
|
||||||
|
|
||||||
if ($should_close) {
|
if ($should_close) {
|
||||||
|
$actor_phid = nonempty(
|
||||||
|
$committer_phid,
|
||||||
|
$author_phid,
|
||||||
|
$revision->getAuthorPHID());
|
||||||
|
|
||||||
$diff = $this->attachToRevision($revision, $actor_phid);
|
$diff = $this->attachToRevision($revision, $actor_phid);
|
||||||
|
|
||||||
$revision->setDateCommitted($commit->getEpoch());
|
$revision->setDateCommitted($commit->getEpoch());
|
||||||
|
@ -169,14 +144,32 @@ abstract class PhabricatorRepositoryCommitMessageParserWorker
|
||||||
$editor->setChangedByCommit($changed_by_commit);
|
$editor->setChangedByCommit($changed_by_commit);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Reload revision to check if someone already didn't close it.
|
$commit_name = $repository->formatCommitName(
|
||||||
$current = id(new DifferentialRevision())->load($revision_id);
|
$commit->getCommitIdentifier());
|
||||||
if ($current->getStatus() != $status_closed) {
|
|
||||||
$editor->setMessage($message)->save();
|
$committer_name = $this->loadUserName(
|
||||||
|
$committer_phid,
|
||||||
|
$data->getCommitDetail('committer'));
|
||||||
|
|
||||||
|
$author_name = $this->loadUserName(
|
||||||
|
$author_phid,
|
||||||
|
$data->getAuthorName());
|
||||||
|
|
||||||
|
$info = array();
|
||||||
|
$info[] = "authored by {$author_name}";
|
||||||
|
if ($committer_name && ($committer_name != $author_name)) {
|
||||||
|
$info[] = "committed by {$committer_name}";
|
||||||
}
|
}
|
||||||
|
$info = implode(', ', $info);
|
||||||
|
|
||||||
|
$editor
|
||||||
|
->setMessage("Closed by commit {$commit_name} ({$info}).")
|
||||||
|
->save();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$lock->unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($should_autoclose && $author_phid) {
|
if ($should_autoclose && $author_phid) {
|
||||||
|
@ -214,6 +207,14 @@ abstract class PhabricatorRepositoryCommitMessageParserWorker
|
||||||
$data->save();
|
$data->save();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function loadUserName($user_phid, $default) {
|
||||||
|
if (!$user_phid) {
|
||||||
|
return $default;
|
||||||
|
}
|
||||||
|
$handle = PhabricatorObjectHandleData::loadOneHandle($user_phid);
|
||||||
|
return '@'.$handle->getName();
|
||||||
|
}
|
||||||
|
|
||||||
private function attachToRevision(
|
private function attachToRevision(
|
||||||
DifferentialRevision $revision,
|
DifferentialRevision $revision,
|
||||||
$actor_phid) {
|
$actor_phid) {
|
||||||
|
|
Loading…
Reference in a new issue