mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-17 10:11:10 +01:00
Allow repositories to be ordered by commit count
Summary: Fixes T7640. Test Plan: {F346553} Reviewers: btrahan Reviewed By: btrahan Subscribers: epriestley Maniphest Tasks: T7640 Differential Revision: https://secure.phabricator.com/D12122
This commit is contained in:
parent
ae03733378
commit
6eadfe6a6f
3 changed files with 85 additions and 18 deletions
|
@ -27,6 +27,7 @@ final class PhabricatorRepositoryQuery
|
||||||
const ORDER_COMMITTED = 'order-committed';
|
const ORDER_COMMITTED = 'order-committed';
|
||||||
const ORDER_CALLSIGN = 'order-callsign';
|
const ORDER_CALLSIGN = 'order-callsign';
|
||||||
const ORDER_NAME = 'order-name';
|
const ORDER_NAME = 'order-name';
|
||||||
|
const ORDER_SIZE = 'order-size';
|
||||||
private $order = self::ORDER_CREATED;
|
private $order = self::ORDER_CREATED;
|
||||||
|
|
||||||
const HOSTED_PHABRICATOR = 'hosted-phab';
|
const HOSTED_PHABRICATOR = 'hosted-phab';
|
||||||
|
@ -151,7 +152,7 @@ final class PhabricatorRepositoryQuery
|
||||||
$table->getTableName(),
|
$table->getTableName(),
|
||||||
$this->buildJoinsClause($conn_r),
|
$this->buildJoinsClause($conn_r),
|
||||||
$this->buildWhereClause($conn_r),
|
$this->buildWhereClause($conn_r),
|
||||||
$this->buildOrderClause($conn_r),
|
$this->buildCustomOrderClause($conn_r),
|
||||||
$this->buildLimitClause($conn_r));
|
$this->buildLimitClause($conn_r));
|
||||||
|
|
||||||
$repositories = $table->loadAllFromArray($data);
|
$repositories = $table->loadAllFromArray($data);
|
||||||
|
@ -294,29 +295,44 @@ final class PhabricatorRepositoryQuery
|
||||||
return $repositories;
|
return $repositories;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function getReversePaging() {
|
protected function buildCustomOrderClause(AphrontDatabaseConnection $conn) {
|
||||||
switch ($this->order) {
|
$parts = array();
|
||||||
case self::ORDER_CALLSIGN:
|
|
||||||
case self::ORDER_NAME:
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected function getPagingColumn() {
|
|
||||||
$order = $this->order;
|
$order = $this->order;
|
||||||
switch ($order) {
|
switch ($order) {
|
||||||
case self::ORDER_CREATED:
|
case self::ORDER_CREATED:
|
||||||
return 'r.id';
|
break;
|
||||||
case self::ORDER_COMMITTED:
|
case self::ORDER_COMMITTED:
|
||||||
return 's.epoch';
|
$parts[] = array(
|
||||||
|
'name' => 's.epoch',
|
||||||
|
);
|
||||||
|
break;
|
||||||
case self::ORDER_CALLSIGN:
|
case self::ORDER_CALLSIGN:
|
||||||
return 'r.callsign';
|
$parts[] = array(
|
||||||
|
'name' => 'r.callsign',
|
||||||
|
'reverse' => true,
|
||||||
|
);
|
||||||
|
break;
|
||||||
case self::ORDER_NAME:
|
case self::ORDER_NAME:
|
||||||
return 'r.name';
|
$parts[] = array(
|
||||||
|
'name' => 'r.name',
|
||||||
|
'reverse' => true,
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
case self::ORDER_SIZE:
|
||||||
|
$parts[] = array(
|
||||||
|
'name' => 's.size',
|
||||||
|
);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
throw new Exception("Unknown order '{$order}!'");
|
throw new Exception("Unknown order '{$order}!'");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$parts[] = array(
|
||||||
|
'name' => 'r.id',
|
||||||
|
);
|
||||||
|
|
||||||
|
return $this->formatOrderClause($conn, $parts);
|
||||||
}
|
}
|
||||||
|
|
||||||
private function loadCursorObject($id) {
|
private function loadCursorObject($id) {
|
||||||
|
@ -328,6 +344,10 @@ final class PhabricatorRepositoryQuery
|
||||||
$query->needMostRecentCommits(true);
|
$query->needMostRecentCommits(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->order == self::ORDER_SIZE) {
|
||||||
|
$query->needCommitCounts(true);
|
||||||
|
}
|
||||||
|
|
||||||
$results = $query->execute();
|
$results = $query->execute();
|
||||||
return head($results);
|
return head($results);
|
||||||
}
|
}
|
||||||
|
@ -394,6 +414,14 @@ final class PhabricatorRepositoryQuery
|
||||||
);
|
);
|
||||||
$columns[] = $id_column;
|
$columns[] = $id_column;
|
||||||
break;
|
break;
|
||||||
|
case self::ORDER_SIZE:
|
||||||
|
$columns[] = array(
|
||||||
|
'name' => 's.size',
|
||||||
|
'type' => 'int',
|
||||||
|
'value' => $cursor->getCommitCount(),
|
||||||
|
);
|
||||||
|
$columns[] = $id_column;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
throw new Exception("Unknown order '{$order}'!");
|
throw new Exception("Unknown order '{$order}'!");
|
||||||
}
|
}
|
||||||
|
@ -402,9 +430,7 @@ final class PhabricatorRepositoryQuery
|
||||||
$conn_r,
|
$conn_r,
|
||||||
$columns,
|
$columns,
|
||||||
array(
|
array(
|
||||||
// TODO: Clean up the column ordering stuff and then make this
|
'reversed' => ($this->getReversePaging() xor (bool)($before_id)),
|
||||||
// depend on getReversePaging().
|
|
||||||
'reversed' => (bool)($before_id),
|
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -413,7 +439,8 @@ final class PhabricatorRepositoryQuery
|
||||||
|
|
||||||
$join_summary_table = $this->needCommitCounts ||
|
$join_summary_table = $this->needCommitCounts ||
|
||||||
$this->needMostRecentCommits ||
|
$this->needMostRecentCommits ||
|
||||||
($this->order == self::ORDER_COMMITTED);
|
($this->order == self::ORDER_COMMITTED) ||
|
||||||
|
($this->order == self::ORDER_SIZE);
|
||||||
|
|
||||||
if ($join_summary_table) {
|
if ($join_summary_table) {
|
||||||
$joins[] = qsprintf(
|
$joins[] = qsprintf(
|
||||||
|
|
|
@ -195,6 +195,7 @@ final class PhabricatorRepositorySearchEngine
|
||||||
'name' => pht('Name'),
|
'name' => pht('Name'),
|
||||||
'callsign' => pht('Callsign'),
|
'callsign' => pht('Callsign'),
|
||||||
'created' => pht('Date Created'),
|
'created' => pht('Date Created'),
|
||||||
|
'size' => pht('Commit Count'),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -204,6 +205,7 @@ final class PhabricatorRepositorySearchEngine
|
||||||
'name' => PhabricatorRepositoryQuery::ORDER_NAME,
|
'name' => PhabricatorRepositoryQuery::ORDER_NAME,
|
||||||
'callsign' => PhabricatorRepositoryQuery::ORDER_CALLSIGN,
|
'callsign' => PhabricatorRepositoryQuery::ORDER_CALLSIGN,
|
||||||
'created' => PhabricatorRepositoryQuery::ORDER_CREATED,
|
'created' => PhabricatorRepositoryQuery::ORDER_CREATED,
|
||||||
|
'size' => PhabricatorRepositoryQuery::ORDER_SIZE,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -284,6 +284,44 @@ abstract class PhabricatorCursorPagedPolicyAwareQuery
|
||||||
return '('.implode(') OR (', $clauses).')';
|
return '('.implode(') OR (', $clauses).')';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function formatOrderClause(
|
||||||
|
AphrontDatabaseConnection $conn,
|
||||||
|
array $parts) {
|
||||||
|
|
||||||
|
$is_query_reversed = false;
|
||||||
|
if ($this->getReversePaging()) {
|
||||||
|
$is_query_reversed = !$is_query_reversed;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->getBeforeID()) {
|
||||||
|
$is_query_reversed = !$is_query_reversed;
|
||||||
|
}
|
||||||
|
|
||||||
|
$sql = array();
|
||||||
|
foreach ($parts as $key => $part) {
|
||||||
|
$is_column_reversed = !empty($part['reverse']);
|
||||||
|
|
||||||
|
$descending = true;
|
||||||
|
if ($is_query_reversed) {
|
||||||
|
$descending = !$descending;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($is_column_reversed) {
|
||||||
|
$descending = !$descending;
|
||||||
|
}
|
||||||
|
|
||||||
|
$name = $part['name'];
|
||||||
|
|
||||||
|
if ($descending) {
|
||||||
|
$sql[] = qsprintf($conn, '%Q DESC', $name);
|
||||||
|
} else {
|
||||||
|
$sql[] = qsprintf($conn, '%Q ASC', $name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return qsprintf($conn, 'ORDER BY %Q', implode(', ', $sql));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* -( Application Search )------------------------------------------------- */
|
/* -( Application Search )------------------------------------------------- */
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue