1
0
Fork 0
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:
epriestley 2015-03-23 09:10:34 -07:00
parent ae03733378
commit 6eadfe6a6f
3 changed files with 85 additions and 18 deletions

View file

@ -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(

View file

@ -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,
); );
} }

View file

@ -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 )------------------------------------------------- */