mirror of
https://we.phorge.it/source/phorge.git
synced 2025-04-08 02:18:33 +02:00
Summary: D9087 adds a nice typeahead but breaks the existing regex search by quoting the pattern. Ideally, this change won't break the typeahead, which as far as I can tell doesn't use the `pattern` argument. Test Plan: Not yet. RFC as to whether this change makes sense, will fix my local setup and resend if so. Reviewers: epriestley, #blessed_reviewers Reviewed By: epriestley, #blessed_reviewers Subscribers: Korvin Differential Revision: https://secure.phabricator.com/D15500
104 lines
2.7 KiB
PHP
104 lines
2.7 KiB
PHP
<?php
|
|
|
|
final class DiffusionQueryPathsConduitAPIMethod
|
|
extends DiffusionQueryConduitAPIMethod {
|
|
|
|
public function getAPIMethodName() {
|
|
return 'diffusion.querypaths';
|
|
}
|
|
|
|
public function getMethodDescription() {
|
|
return pht('Filename search on a repository.');
|
|
}
|
|
|
|
protected function defineReturnType() {
|
|
return 'list<string>';
|
|
}
|
|
|
|
protected function defineCustomParamTypes() {
|
|
return array(
|
|
'path' => 'required string',
|
|
'commit' => 'required string',
|
|
'pattern' => 'optional string',
|
|
'limit' => 'optional int',
|
|
'offset' => 'optional int',
|
|
);
|
|
}
|
|
|
|
protected function getResult(ConduitAPIRequest $request) {
|
|
$results = parent::getResult($request);
|
|
$offset = $request->getValue('offset');
|
|
return array_slice($results, $offset);
|
|
}
|
|
|
|
protected function getGitResult(ConduitAPIRequest $request) {
|
|
$drequest = $this->getDiffusionRequest();
|
|
$path = $drequest->getPath();
|
|
$commit = $request->getValue('commit');
|
|
$repository = $drequest->getRepository();
|
|
|
|
// http://comments.gmane.org/gmane.comp.version-control.git/197735
|
|
|
|
$future = $repository->getLocalCommandFuture(
|
|
'ls-tree --name-only -r -z %s -- %s',
|
|
$commit,
|
|
$path);
|
|
|
|
$lines = id(new LinesOfALargeExecFuture($future))->setDelimiter("\0");
|
|
return $this->filterResults($lines, $request);
|
|
}
|
|
|
|
protected function getMercurialResult(ConduitAPIRequest $request) {
|
|
$drequest = $this->getDiffusionRequest();
|
|
$repository = $drequest->getRepository();
|
|
$path = $request->getValue('path');
|
|
$commit = $request->getValue('commit');
|
|
|
|
$entire_manifest = id(new DiffusionLowLevelMercurialPathsQuery())
|
|
->setRepository($repository)
|
|
->withCommit($commit)
|
|
->withPath($path)
|
|
->execute();
|
|
|
|
$match_against = trim($path, '/');
|
|
$match_len = strlen($match_against);
|
|
|
|
$lines = array();
|
|
foreach ($entire_manifest as $path) {
|
|
if (strlen($path) && !strncmp($path, $match_against, $match_len)) {
|
|
$lines[] = $path;
|
|
}
|
|
}
|
|
|
|
return $this->filterResults($lines, $request);
|
|
}
|
|
|
|
protected function filterResults($lines, ConduitAPIRequest $request) {
|
|
$pattern = $request->getValue('pattern');
|
|
$limit = (int)$request->getValue('limit');
|
|
$offset = (int)$request->getValue('offset');
|
|
|
|
if (strlen($pattern)) {
|
|
// Add delimiters to the regex pattern.
|
|
$pattern = '('.$pattern.')';
|
|
}
|
|
|
|
$results = array();
|
|
$count = 0;
|
|
foreach ($lines as $line) {
|
|
if (strlen($pattern) && !preg_match($pattern, $line)) {
|
|
continue;
|
|
}
|
|
|
|
$results[] = $line;
|
|
$count++;
|
|
|
|
if ($limit && ($count >= ($offset + $limit))) {
|
|
break;
|
|
}
|
|
}
|
|
|
|
return $results;
|
|
}
|
|
|
|
}
|