mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-10 23:01:04 +01:00
Refactor freeform field specification
Summary: I want to attach the task also to revision, not only to commit by mentioning it in summary. This is a preparation for it, useful by itself: * One query instead of N. * Lower CRAP score, yay! Refs T945. Test Plan: My Test Plan is really //plan// this time. I want to update Phabricator in the minute when I commit this. Reviewers: 20after4, epriestley Reviewed By: epriestley CC: aran, Korvin Maniphest Tasks: T945 Differential Revision: https://secure.phabricator.com/D3873
This commit is contained in:
parent
197fad554b
commit
040fac06d4
1 changed files with 32 additions and 26 deletions
|
@ -3,18 +3,7 @@
|
||||||
abstract class DifferentialFreeformFieldSpecification
|
abstract class DifferentialFreeformFieldSpecification
|
||||||
extends DifferentialFieldSpecification {
|
extends DifferentialFieldSpecification {
|
||||||
|
|
||||||
public function didParseCommit(
|
private function findMentionedTasks($message) {
|
||||||
PhabricatorRepository $repository,
|
|
||||||
PhabricatorRepositoryCommit $commit,
|
|
||||||
PhabricatorRepositoryCommitData $data) {
|
|
||||||
|
|
||||||
$user = id(new PhabricatorUser())->loadOneWhere(
|
|
||||||
'phid = %s',
|
|
||||||
$data->getCommitDetail('authorPHID'));
|
|
||||||
if (!$user) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$prefixes = array(
|
$prefixes = array(
|
||||||
'resolves' => ManiphestTaskStatus::STATUS_CLOSED_RESOLVED,
|
'resolves' => ManiphestTaskStatus::STATUS_CLOSED_RESOLVED,
|
||||||
'fixes' => ManiphestTaskStatus::STATUS_CLOSED_RESOLVED,
|
'fixes' => ManiphestTaskStatus::STATUS_CLOSED_RESOLVED,
|
||||||
|
@ -55,16 +44,13 @@ abstract class DifferentialFreeformFieldSpecification
|
||||||
$suffix_regex = implode('|', $suffix_regex);
|
$suffix_regex = implode('|', $suffix_regex);
|
||||||
|
|
||||||
$matches = null;
|
$matches = null;
|
||||||
$ok = preg_match_all(
|
preg_match_all(
|
||||||
"/({$prefix_regex})\s+T(\d+)\s*({$suffix_regex})/i",
|
"/({$prefix_regex})\s+T(\d+)\s*({$suffix_regex})/i",
|
||||||
$this->renderValueForCommitMessage($is_edit = false),
|
$message,
|
||||||
$matches,
|
$matches,
|
||||||
PREG_SET_ORDER);
|
PREG_SET_ORDER);
|
||||||
|
|
||||||
if (!$ok) {
|
$tasks_statuses = array();
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ($matches as $set) {
|
foreach ($matches as $set) {
|
||||||
$prefix = strtolower($set[1]);
|
$prefix = strtolower($set[1]);
|
||||||
$task_id = (int)$set[2];
|
$task_id = (int)$set[2];
|
||||||
|
@ -75,16 +61,35 @@ abstract class DifferentialFreeformFieldSpecification
|
||||||
$status = idx($prefixes, $prefix);
|
$status = idx($prefixes, $prefix);
|
||||||
}
|
}
|
||||||
|
|
||||||
$tasks = id(new ManiphestTaskQuery())
|
$tasks_statuses[$task_id] = $status;
|
||||||
->withTaskIDs(array($task_id))
|
|
||||||
->execute();
|
|
||||||
$task = idx($tasks, $task_id);
|
|
||||||
|
|
||||||
if (!$task) {
|
|
||||||
// Task doesn't exist, or the user can't see it.
|
|
||||||
continue;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $tasks_statuses;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function didParseCommit(
|
||||||
|
PhabricatorRepository $repository,
|
||||||
|
PhabricatorRepositoryCommit $commit,
|
||||||
|
PhabricatorRepositoryCommitData $data) {
|
||||||
|
|
||||||
|
$user = id(new PhabricatorUser())->loadOneWhere(
|
||||||
|
'phid = %s',
|
||||||
|
$data->getCommitDetail('authorPHID'));
|
||||||
|
if (!$user) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$message = $this->renderValueForCommitMessage($is_edit = false);
|
||||||
|
$tasks_statuses = $this->findMentionedTasks($message);
|
||||||
|
if (!$tasks_statuses) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$tasks = id(new ManiphestTaskQuery())
|
||||||
|
->withTaskIDs(array_keys($tasks_statuses))
|
||||||
|
->execute();
|
||||||
|
|
||||||
|
foreach ($tasks as $task_id => $task) {
|
||||||
id(new PhabricatorEdgeEditor())
|
id(new PhabricatorEdgeEditor())
|
||||||
->setActor($user)
|
->setActor($user)
|
||||||
->addEdge(
|
->addEdge(
|
||||||
|
@ -93,6 +98,7 @@ abstract class DifferentialFreeformFieldSpecification
|
||||||
$commit->getPHID())
|
$commit->getPHID())
|
||||||
->save();
|
->save();
|
||||||
|
|
||||||
|
$status = $tasks_statuses[$task_id];
|
||||||
if (!$status) {
|
if (!$status) {
|
||||||
// Text like "Ref T123", don't change the task status.
|
// Text like "Ref T123", don't change the task status.
|
||||||
continue;
|
continue;
|
||||||
|
|
Loading…
Reference in a new issue