mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-19 19:21:10 +01:00
Clean up Diffusion branch query a bit
Summary: Ref T2716. - Serve from `DiffusionCommitQuery`, not `PhabricatorAuditCommitQuery` (which should probably die). - Fix logic for `limit`, which incorrectly failed to display the "Showing %d branches." text. - Clean up things a touch. - I didn't end up actually needing `needCommitData()`, but left it in there since I think it will be needed soon. - Removed a "TODO" because I don't remember what "etc etc" means. Test Plan: Looked at branches in several repositories. Reviewers: btrahan Reviewed By: btrahan CC: aran Maniphest Tasks: T2716 Differential Revision: https://secure.phabricator.com/D7451
This commit is contained in:
parent
70b53c49fd
commit
d1c4b5081c
4 changed files with 93 additions and 59 deletions
|
@ -198,61 +198,62 @@ final class DiffusionRepositoryController extends DiffusionController {
|
||||||
}
|
}
|
||||||
|
|
||||||
private function buildBranchListTable(DiffusionRequest $drequest) {
|
private function buildBranchListTable(DiffusionRequest $drequest) {
|
||||||
if ($drequest->getBranch() !== null) {
|
$viewer = $this->getRequest()->getUser();
|
||||||
$limit = 15;
|
|
||||||
|
|
||||||
$branches = DiffusionBranchInformation::newFromConduit(
|
if ($drequest->getBranch() === null) {
|
||||||
$this->callConduitWithDiffusionRequest(
|
return null;
|
||||||
'diffusion.branchquery',
|
|
||||||
array(
|
|
||||||
'limit' => $limit
|
|
||||||
)));
|
|
||||||
if (!$branches) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
$more_branches = (count($branches) > $limit);
|
|
||||||
$branches = array_slice($branches, 0, $limit);
|
|
||||||
|
|
||||||
$commits = id(new PhabricatorAuditCommitQuery())
|
|
||||||
->withIdentifiers(
|
|
||||||
$drequest->getRepository()->getID(),
|
|
||||||
mpull($branches, 'getHeadCommitIdentifier'))
|
|
||||||
->needCommitData(true)
|
|
||||||
->execute();
|
|
||||||
|
|
||||||
$table = new DiffusionBranchTableView();
|
|
||||||
$table->setDiffusionRequest($drequest);
|
|
||||||
$table->setBranches($branches);
|
|
||||||
$table->setCommits($commits);
|
|
||||||
$table->setUser($this->getRequest()->getUser());
|
|
||||||
|
|
||||||
$panel = new AphrontPanelView();
|
|
||||||
$panel->setHeader(pht('Branches'));
|
|
||||||
$panel->setNoBackground();
|
|
||||||
|
|
||||||
if ($more_branches) {
|
|
||||||
$panel->setCaption(pht('Showing %d branches.', $limit));
|
|
||||||
}
|
|
||||||
|
|
||||||
$panel->addButton(
|
|
||||||
phutil_tag(
|
|
||||||
'a',
|
|
||||||
array(
|
|
||||||
'href' => $drequest->generateURI(
|
|
||||||
array(
|
|
||||||
'action' => 'branches',
|
|
||||||
)),
|
|
||||||
'class' => 'grey button',
|
|
||||||
),
|
|
||||||
pht("Show All Branches \xC2\xBB")));
|
|
||||||
|
|
||||||
$panel->appendChild($table);
|
|
||||||
|
|
||||||
return $panel;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
$limit = 15;
|
||||||
|
|
||||||
|
$branches = DiffusionBranchInformation::newFromConduit(
|
||||||
|
$this->callConduitWithDiffusionRequest(
|
||||||
|
'diffusion.branchquery',
|
||||||
|
array(
|
||||||
|
'limit' => $limit + 1,
|
||||||
|
)));
|
||||||
|
if (!$branches) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
$more_branches = (count($branches) > $limit);
|
||||||
|
$branches = array_slice($branches, 0, $limit);
|
||||||
|
|
||||||
|
$commits = id(new DiffusionCommitQuery())
|
||||||
|
->setViewer($viewer)
|
||||||
|
->withIdentifiers(mpull($branches, 'getHeadCommitIdentifier'))
|
||||||
|
->withRepositoryIDs(array($drequest->getRepository()->getID()))
|
||||||
|
->execute();
|
||||||
|
|
||||||
|
$table = new DiffusionBranchTableView();
|
||||||
|
$table->setDiffusionRequest($drequest);
|
||||||
|
$table->setBranches($branches);
|
||||||
|
$table->setCommits($commits);
|
||||||
|
$table->setUser($this->getRequest()->getUser());
|
||||||
|
|
||||||
|
$panel = new AphrontPanelView();
|
||||||
|
$panel->setHeader(pht('Branches'));
|
||||||
|
$panel->setNoBackground();
|
||||||
|
|
||||||
|
if ($more_branches) {
|
||||||
|
$panel->setCaption(pht('Showing %d branches.', $limit));
|
||||||
|
}
|
||||||
|
|
||||||
|
$panel->addButton(
|
||||||
|
phutil_tag(
|
||||||
|
'a',
|
||||||
|
array(
|
||||||
|
'href' => $drequest->generateURI(
|
||||||
|
array(
|
||||||
|
'action' => 'branches',
|
||||||
|
)),
|
||||||
|
'class' => 'grey button',
|
||||||
|
),
|
||||||
|
pht("Show All Branches \xC2\xBB")));
|
||||||
|
|
||||||
|
$panel->appendChild($table);
|
||||||
|
|
||||||
|
return $panel;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function buildTagListTable(DiffusionRequest $drequest) {
|
private function buildTagListTable(DiffusionRequest $drequest) {
|
||||||
|
|
|
@ -8,6 +8,9 @@ final class DiffusionCommitQuery
|
||||||
private $phids;
|
private $phids;
|
||||||
private $defaultRepository;
|
private $defaultRepository;
|
||||||
private $identifierMap;
|
private $identifierMap;
|
||||||
|
private $repositoryIDs;
|
||||||
|
|
||||||
|
private $needCommitData;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Load commits by partial or full identifiers, e.g. "rXab82393", "rX1234",
|
* Load commits by partial or full identifiers, e.g. "rXab82393", "rX1234",
|
||||||
|
@ -34,6 +37,11 @@ final class DiffusionCommitQuery
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function withRepositoryIDs(array $repository_ids) {
|
||||||
|
$this->repositoryIDs = $repository_ids;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function withIDs(array $ids) {
|
public function withIDs(array $ids) {
|
||||||
$this->ids = $ids;
|
$this->ids = $ids;
|
||||||
return $this;
|
return $this;
|
||||||
|
@ -44,6 +52,11 @@ final class DiffusionCommitQuery
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function needCommitData($need) {
|
||||||
|
$this->needCommitData = $need;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function getIdentifierMap() {
|
public function getIdentifierMap() {
|
||||||
if ($this->identifierMap === null) {
|
if ($this->identifierMap === null) {
|
||||||
throw new Exception(
|
throw new Exception(
|
||||||
|
@ -71,7 +84,7 @@ final class DiffusionCommitQuery
|
||||||
return $table->loadAllFromArray($data);
|
return $table->loadAllFromArray($data);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function willFilterPage(array $commits) {
|
protected function willFilterPage(array $commits) {
|
||||||
$repository_ids = mpull($commits, 'getRepositoryID', 'getRepositoryID');
|
$repository_ids = mpull($commits, 'getRepositoryID', 'getRepositoryID');
|
||||||
$repos = id(new PhabricatorRepositoryQuery())
|
$repos = id(new PhabricatorRepositoryQuery())
|
||||||
->setViewer($this->getViewer())
|
->setViewer($this->getViewer())
|
||||||
|
@ -131,6 +144,22 @@ final class DiffusionCommitQuery
|
||||||
return $commits;
|
return $commits;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function didFilterPage(array $commits) {
|
||||||
|
|
||||||
|
if ($this->needCommitData) {
|
||||||
|
$data = id(new PhabricatorRepositoryCommitData())->loadAllWhere(
|
||||||
|
'commitID in (%Ld)',
|
||||||
|
mpull($commits, 'getID'));
|
||||||
|
$data = mpull($data, null, 'getCommitID');
|
||||||
|
foreach ($commits as $commit) {
|
||||||
|
$commit_data = idx($data, $commit->getID());
|
||||||
|
$commit->attachCommitData($commit_data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $commits;
|
||||||
|
}
|
||||||
|
|
||||||
private function buildWhereClause(AphrontDatabaseConnection $conn_r) {
|
private function buildWhereClause(AphrontDatabaseConnection $conn_r) {
|
||||||
$where = array();
|
$where = array();
|
||||||
|
|
||||||
|
@ -237,6 +266,13 @@ final class DiffusionCommitQuery
|
||||||
$this->phids);
|
$this->phids);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->repositoryIDs) {
|
||||||
|
$where[] = qsprintf(
|
||||||
|
$conn_r,
|
||||||
|
'repositoryID IN (%Ld)',
|
||||||
|
$this->repositoryIDs);
|
||||||
|
}
|
||||||
|
|
||||||
return $this->formatWhereClause($where);
|
return $this->formatWhereClause($where);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,10 +25,7 @@ final class DiffusionBranchTableView extends DiffusionView {
|
||||||
foreach ($this->branches as $branch) {
|
foreach ($this->branches as $branch) {
|
||||||
$commit = idx($this->commits, $branch->getHeadCommitIdentifier());
|
$commit = idx($this->commits, $branch->getHeadCommitIdentifier());
|
||||||
if ($commit) {
|
if ($commit) {
|
||||||
$details = $commit->getCommitData()->getCommitMessage();
|
$details = $commit->getSummary();
|
||||||
$details = idx(explode("\n", $details), 0);
|
|
||||||
$details = substr($details, 0, 80);
|
|
||||||
|
|
||||||
$datetime = phabricator_datetime($commit->getEpoch(), $this->user);
|
$datetime = phabricator_datetime($commit->getEpoch(), $this->user);
|
||||||
} else {
|
} else {
|
||||||
$datetime = null;
|
$datetime = null;
|
||||||
|
@ -61,7 +58,6 @@ final class DiffusionBranchTableView extends DiffusionView {
|
||||||
$branch->getHeadCommitIdentifier()),
|
$branch->getHeadCommitIdentifier()),
|
||||||
$datetime,
|
$datetime,
|
||||||
AphrontTableView::renderSingleDisplayLine($details),
|
AphrontTableView::renderSingleDisplayLine($details),
|
||||||
// TODO: etc etc
|
|
||||||
);
|
);
|
||||||
if ($branch->getName() == $current_branch) {
|
if ($branch->getName() == $current_branch) {
|
||||||
$rowc[] = 'highlighted';
|
$rowc[] = 'highlighted';
|
||||||
|
|
|
@ -81,7 +81,8 @@ final class PhabricatorRepositoryCommit
|
||||||
$this->getID());
|
$this->getID());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function attachCommitData(PhabricatorRepositoryCommitData $data) {
|
public function attachCommitData(
|
||||||
|
PhabricatorRepositoryCommitData $data = null) {
|
||||||
$this->commitData = $data;
|
$this->commitData = $data;
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue