mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-13 08:11:04 +01:00
commit
206546a6e3
9 changed files with 32 additions and 22 deletions
|
@ -140,9 +140,9 @@ final class DiffusionSvnDiffQuery extends DiffusionDiffQuery {
|
||||||
$repository = $drequest->getRepository();
|
$repository = $drequest->getRepository();
|
||||||
|
|
||||||
list($ref, $rev) = $spec;
|
list($ref, $rev) = $spec;
|
||||||
return new ExecFuture(
|
return $repository->getRemoteCommandFuture(
|
||||||
'svn --non-interactive cat %s%s@%d',
|
'cat %s%s@%d',
|
||||||
$repository->getDetail('remote-uri'),
|
$repository->getRemoteURI(),
|
||||||
$ref,
|
$ref,
|
||||||
$rev);
|
$rev);
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,6 @@ phutil_require_module('phabricator', 'applications/diffusion/query/pathchange/ba
|
||||||
phutil_require_module('phabricator', 'infrastructure/diff/engine');
|
phutil_require_module('phabricator', 'infrastructure/diff/engine');
|
||||||
|
|
||||||
phutil_require_module('phutil', 'future');
|
phutil_require_module('phutil', 'future');
|
||||||
phutil_require_module('phutil', 'future/exec');
|
|
||||||
phutil_require_module('phutil', 'utils');
|
phutil_require_module('phutil', 'utils');
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -33,11 +33,11 @@ final class DiffusionSvnFileContentQuery extends DiffusionFileContentQuery {
|
||||||
$path = $drequest->getPath();
|
$path = $drequest->getPath();
|
||||||
$commit = $drequest->getCommit();
|
$commit = $drequest->getCommit();
|
||||||
|
|
||||||
$remote_uri = $repository->getDetail('remote-uri');
|
$remote_uri = $repository->getRemoteURI();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
list($corpus) = execx(
|
list($corpus) = $repository->execxRemoteCommand(
|
||||||
'svn --non-interactive %s %s%s@%s',
|
'%s %s%s@%s',
|
||||||
$this->getNeedsBlame() ? 'blame' : 'cat',
|
$this->getNeedsBlame() ? 'blame' : 'cat',
|
||||||
$remote_uri,
|
$remote_uri,
|
||||||
$path,
|
$path,
|
||||||
|
|
|
@ -9,7 +9,6 @@
|
||||||
phutil_require_module('phabricator', 'applications/diffusion/data/filecontent');
|
phutil_require_module('phabricator', 'applications/diffusion/data/filecontent');
|
||||||
phutil_require_module('phabricator', 'applications/diffusion/query/filecontent/base');
|
phutil_require_module('phabricator', 'applications/diffusion/query/filecontent/base');
|
||||||
|
|
||||||
phutil_require_module('phutil', 'future/exec');
|
|
||||||
phutil_require_module('phutil', 'utils');
|
phutil_require_module('phutil', 'utils');
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -28,9 +28,9 @@ class PhabricatorRepositorySvnCommitDiscoveryDaemon
|
||||||
}
|
}
|
||||||
|
|
||||||
$uri = $this->getBaseSVNLogURI();
|
$uri = $this->getBaseSVNLogURI();
|
||||||
list($xml) = execx(
|
list($xml) = $repository->execxRemoteCommand(
|
||||||
'svn log --xml --non-interactive --quiet --limit 1 %s@HEAD',
|
' log --xml --quiet --limit 1 %s@HEAD',
|
||||||
$uri);
|
$uri);
|
||||||
|
|
||||||
$results = $this->parseSVNLogXML($xml);
|
$results = $this->parseSVNLogXML($xml);
|
||||||
$commit = key($results);
|
$commit = key($results);
|
||||||
|
@ -47,6 +47,7 @@ class PhabricatorRepositorySvnCommitDiscoveryDaemon
|
||||||
|
|
||||||
private function discoverCommit($commit, $epoch) {
|
private function discoverCommit($commit, $epoch) {
|
||||||
$uri = $this->getBaseSVNLogURI();
|
$uri = $this->getBaseSVNLogURI();
|
||||||
|
$repository = $this->getRepository();
|
||||||
|
|
||||||
$discover = array(
|
$discover = array(
|
||||||
$commit => $epoch,
|
$commit => $epoch,
|
||||||
|
@ -58,8 +59,8 @@ class PhabricatorRepositorySvnCommitDiscoveryDaemon
|
||||||
// Find all the unknown commits on this path. Note that we permit
|
// Find all the unknown commits on this path. Note that we permit
|
||||||
// importing an SVN subdirectory rather than the entire repository, so
|
// importing an SVN subdirectory rather than the entire repository, so
|
||||||
// commits may be nonsequential.
|
// commits may be nonsequential.
|
||||||
list($err, $xml, $stderr) = exec_manual(
|
list($err, $xml, $stderr) = $repository->execRemoteCommand(
|
||||||
'svn log --xml --non-interactive --quiet --limit %d %s@%d',
|
' log --xml --quiet --limit %d %s@%d',
|
||||||
$limit,
|
$limit,
|
||||||
$uri,
|
$uri,
|
||||||
$upper_bound - 1);
|
$upper_bound - 1);
|
||||||
|
|
|
@ -9,7 +9,6 @@
|
||||||
phutil_require_module('phabricator', 'applications/repository/constants/repositorytype');
|
phutil_require_module('phabricator', 'applications/repository/constants/repositorytype');
|
||||||
phutil_require_module('phabricator', 'applications/repository/daemon/commitdiscovery/base');
|
phutil_require_module('phabricator', 'applications/repository/daemon/commitdiscovery/base');
|
||||||
|
|
||||||
phutil_require_module('phutil', 'future/exec');
|
|
||||||
phutil_require_module('phutil', 'utils');
|
phutil_require_module('phutil', 'utils');
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -97,6 +97,12 @@ class PhabricatorRepository extends PhabricatorRepositoryDAO {
|
||||||
return call_user_func_array('execx', $args);
|
return call_user_func_array('execx', $args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getRemoteCommandFuture($pattern /*, $arg, ... */) {
|
||||||
|
$args = func_get_args();
|
||||||
|
$args = $this->formatRemoteCommand($args);
|
||||||
|
return newv('ExecFuture', $args);
|
||||||
|
}
|
||||||
|
|
||||||
public function passthruRemoteCommand($pattern /*, $arg, ... */) {
|
public function passthruRemoteCommand($pattern /*, $arg, ... */) {
|
||||||
$args = func_get_args();
|
$args = func_get_args();
|
||||||
$args = $this->formatRemoteCommand($args);
|
$args = $this->formatRemoteCommand($args);
|
||||||
|
@ -115,12 +121,19 @@ class PhabricatorRepository extends PhabricatorRepositoryDAO {
|
||||||
return call_user_func_array('execx', $args);
|
return call_user_func_array('execx', $args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getLocalCommandFuture($pattern /*, $arg, ... */) {
|
||||||
|
$args = func_get_args();
|
||||||
|
$args = $this->formatLocalCommand($args);
|
||||||
|
return newv('ExecFuture', $args);
|
||||||
|
|
||||||
|
}
|
||||||
public function passthruLocalCommand($pattern /*, $arg, ... */) {
|
public function passthruLocalCommand($pattern /*, $arg, ... */) {
|
||||||
$args = func_get_args();
|
$args = func_get_args();
|
||||||
$args = $this->formatLocalCommand($args);
|
$args = $this->formatLocalCommand($args);
|
||||||
return call_user_func_array('phutil_passthru', $args);
|
return call_user_func_array('phutil_passthru', $args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private function formatRemoteCommand(array $args) {
|
private function formatRemoteCommand(array $args) {
|
||||||
$pattern = $args[0];
|
$pattern = $args[0];
|
||||||
$args = array_slice($args, 1);
|
$args = array_slice($args, 1);
|
||||||
|
|
|
@ -68,8 +68,8 @@ abstract class PhabricatorRepositoryCommitParserWorker
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
list($xml) = execx(
|
list($xml) = $this->repository->execxRemoteCommand(
|
||||||
"svn log --xml {$verbose} --limit 1 --non-interactive %s@%d",
|
"log --xml {$verbose} --limit 1 %s@%d",
|
||||||
$uri,
|
$uri,
|
||||||
$revision);
|
$revision);
|
||||||
} catch (CommandException $ex) {
|
} catch (CommandException $ex) {
|
||||||
|
|
|
@ -593,10 +593,9 @@ class PhabricatorRepositorySvnCommitChangeParserWorker
|
||||||
// position in the document.
|
// position in the document.
|
||||||
$all_paths = array_reverse(array_keys($parents));
|
$all_paths = array_reverse(array_keys($parents));
|
||||||
foreach (array_chunk($all_paths, 64) as $path_chunk) {
|
foreach (array_chunk($all_paths, 64) as $path_chunk) {
|
||||||
list($raw_xml) = execx(
|
list($raw_xml) = $repository->execxRemoteCommand(
|
||||||
'svn --non-interactive --xml ls %C',
|
'--xml ls %C',
|
||||||
implode(' ', $path_chunk));
|
implode(' ', $path_chunk));
|
||||||
|
|
||||||
$xml = new SimpleXMLElement($raw_xml);
|
$xml = new SimpleXMLElement($raw_xml);
|
||||||
foreach ($xml->list as $list) {
|
foreach ($xml->list as $list) {
|
||||||
$list_path = (string)$list['path'];
|
$list_path = (string)$list['path'];
|
||||||
|
@ -669,8 +668,8 @@ class PhabricatorRepositorySvnCommitChangeParserWorker
|
||||||
$cache_loc = sys_get_temp_dir().'/diffusion.'.$hashkey.'.svnls';
|
$cache_loc = sys_get_temp_dir().'/diffusion.'.$hashkey.'.svnls';
|
||||||
if (!Filesystem::pathExists($cache_loc)) {
|
if (!Filesystem::pathExists($cache_loc)) {
|
||||||
$tmp = new TempFile();
|
$tmp = new TempFile();
|
||||||
execx(
|
$repository->execxRemoteCommand(
|
||||||
'svn --non-interactive --xml ls -R %s%s@%d > %s',
|
'--xml ls -R %s%s@%d > %s',
|
||||||
$repository->getDetail('remote-uri'),
|
$repository->getDetail('remote-uri'),
|
||||||
$path,
|
$path,
|
||||||
$rev,
|
$rev,
|
||||||
|
|
Loading…
Reference in a new issue