mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-18 10:41:08 +01:00
Add "DiffusionRawDiffQuery"
Summary: - This is only slightly useful for updating Differential, since DiffQuery (vs RawDiffQuery) already gets you most of what you need. The only thing is that DiffQuery returns the diff for one path only right now(and the SVN version is very "special"). Should be easy to fix in the Git/HG cases at least, though (or maybe just use RawDiffQuery to avoid the SVN mess). - Added a "download raw diff" link. Test Plan: Viewed Diffusion and raw commits for SVN, Mercurial and Git repositories. Reviewers: vrana, btrahan, jungejason Reviewed By: vrana CC: aran Differential Revision: https://secure.phabricator.com/D2350
This commit is contained in:
parent
5ab14d0879
commit
63ce372480
18 changed files with 339 additions and 47 deletions
|
@ -645,6 +645,7 @@ return array(
|
||||||
'image/png' => 'image/png',
|
'image/png' => 'image/png',
|
||||||
'image/gif' => 'image/gif',
|
'image/gif' => 'image/gif',
|
||||||
'text/plain' => 'text/plain; charset=utf-8',
|
'text/plain' => 'text/plain; charset=utf-8',
|
||||||
|
'text/x-diff' => 'text/plain; charset=utf-8',
|
||||||
|
|
||||||
// ".ico" favicon files, which have mime type diversity. See:
|
// ".ico" favicon files, which have mime type diversity. See:
|
||||||
// http://en.wikipedia.org/wiki/ICO_(file_format)#MIME_type
|
// http://en.wikipedia.org/wiki/ICO_(file_format)#MIME_type
|
||||||
|
|
|
@ -325,6 +325,7 @@ phutil_register_library_map(array(
|
||||||
'DiffusionGitHistoryQuery' => 'applications/diffusion/query/history/git',
|
'DiffusionGitHistoryQuery' => 'applications/diffusion/query/history/git',
|
||||||
'DiffusionGitLastModifiedQuery' => 'applications/diffusion/query/lastmodified/git',
|
'DiffusionGitLastModifiedQuery' => 'applications/diffusion/query/lastmodified/git',
|
||||||
'DiffusionGitMergedCommitsQuery' => 'applications/diffusion/query/mergedcommits/git',
|
'DiffusionGitMergedCommitsQuery' => 'applications/diffusion/query/mergedcommits/git',
|
||||||
|
'DiffusionGitRawDiffQuery' => 'applications/diffusion/query/rawdiff/git',
|
||||||
'DiffusionGitRenameHistoryQuery' => 'applications/diffusion/query/renamehistory/git',
|
'DiffusionGitRenameHistoryQuery' => 'applications/diffusion/query/renamehistory/git',
|
||||||
'DiffusionGitRequest' => 'applications/diffusion/request/git',
|
'DiffusionGitRequest' => 'applications/diffusion/request/git',
|
||||||
'DiffusionGitTagListQuery' => 'applications/diffusion/query/taglist/git',
|
'DiffusionGitTagListQuery' => 'applications/diffusion/query/taglist/git',
|
||||||
|
@ -345,6 +346,7 @@ phutil_register_library_map(array(
|
||||||
'DiffusionMercurialHistoryQuery' => 'applications/diffusion/query/history/mercurial',
|
'DiffusionMercurialHistoryQuery' => 'applications/diffusion/query/history/mercurial',
|
||||||
'DiffusionMercurialLastModifiedQuery' => 'applications/diffusion/query/lastmodified/mercurial',
|
'DiffusionMercurialLastModifiedQuery' => 'applications/diffusion/query/lastmodified/mercurial',
|
||||||
'DiffusionMercurialMergedCommitsQuery' => 'applications/diffusion/query/mergedcommits/mercurial',
|
'DiffusionMercurialMergedCommitsQuery' => 'applications/diffusion/query/mergedcommits/mercurial',
|
||||||
|
'DiffusionMercurialRawDiffQuery' => 'applications/diffusion/query/rawdiff/mercurial',
|
||||||
'DiffusionMercurialRenameHistoryQuery' => 'applications/diffusion/query/renamehistory/mercurial',
|
'DiffusionMercurialRenameHistoryQuery' => 'applications/diffusion/query/renamehistory/mercurial',
|
||||||
'DiffusionMercurialRequest' => 'applications/diffusion/request/mercurial',
|
'DiffusionMercurialRequest' => 'applications/diffusion/request/mercurial',
|
||||||
'DiffusionMercurialTagListQuery' => 'applications/diffusion/query/taglist/mercurial',
|
'DiffusionMercurialTagListQuery' => 'applications/diffusion/query/taglist/mercurial',
|
||||||
|
@ -357,6 +359,7 @@ phutil_register_library_map(array(
|
||||||
'DiffusionPathQueryTestCase' => 'applications/diffusion/query/pathid/base/__tests__',
|
'DiffusionPathQueryTestCase' => 'applications/diffusion/query/pathid/base/__tests__',
|
||||||
'DiffusionPathValidateController' => 'applications/diffusion/controller/pathvalidate',
|
'DiffusionPathValidateController' => 'applications/diffusion/controller/pathvalidate',
|
||||||
'DiffusionQuery' => 'applications/diffusion/query/base',
|
'DiffusionQuery' => 'applications/diffusion/query/base',
|
||||||
|
'DiffusionRawDiffQuery' => 'applications/diffusion/query/rawdiff/base',
|
||||||
'DiffusionRenameHistoryQuery' => 'applications/diffusion/query/renamehistory/base',
|
'DiffusionRenameHistoryQuery' => 'applications/diffusion/query/renamehistory/base',
|
||||||
'DiffusionRepositoryController' => 'applications/diffusion/controller/repository',
|
'DiffusionRepositoryController' => 'applications/diffusion/controller/repository',
|
||||||
'DiffusionRepositoryPath' => 'applications/diffusion/data/repositorypath',
|
'DiffusionRepositoryPath' => 'applications/diffusion/data/repositorypath',
|
||||||
|
@ -371,6 +374,7 @@ phutil_register_library_map(array(
|
||||||
'DiffusionSvnHistoryQuery' => 'applications/diffusion/query/history/svn',
|
'DiffusionSvnHistoryQuery' => 'applications/diffusion/query/history/svn',
|
||||||
'DiffusionSvnLastModifiedQuery' => 'applications/diffusion/query/lastmodified/svn',
|
'DiffusionSvnLastModifiedQuery' => 'applications/diffusion/query/lastmodified/svn',
|
||||||
'DiffusionSvnMergedCommitsQuery' => 'applications/diffusion/query/mergedcommits/svn',
|
'DiffusionSvnMergedCommitsQuery' => 'applications/diffusion/query/mergedcommits/svn',
|
||||||
|
'DiffusionSvnRawDiffQuery' => 'applications/diffusion/query/rawdiff/svn',
|
||||||
'DiffusionSvnRenameHistoryQuery' => 'applications/diffusion/query/renamehistory/svn',
|
'DiffusionSvnRenameHistoryQuery' => 'applications/diffusion/query/renamehistory/svn',
|
||||||
'DiffusionSvnRequest' => 'applications/diffusion/request/svn',
|
'DiffusionSvnRequest' => 'applications/diffusion/request/svn',
|
||||||
'DiffusionSvnTagListQuery' => 'applications/diffusion/query/taglist/svn',
|
'DiffusionSvnTagListQuery' => 'applications/diffusion/query/taglist/svn',
|
||||||
|
@ -1301,6 +1305,7 @@ phutil_register_library_map(array(
|
||||||
'DiffusionGitHistoryQuery' => 'DiffusionHistoryQuery',
|
'DiffusionGitHistoryQuery' => 'DiffusionHistoryQuery',
|
||||||
'DiffusionGitLastModifiedQuery' => 'DiffusionLastModifiedQuery',
|
'DiffusionGitLastModifiedQuery' => 'DiffusionLastModifiedQuery',
|
||||||
'DiffusionGitMergedCommitsQuery' => 'DiffusionMergedCommitsQuery',
|
'DiffusionGitMergedCommitsQuery' => 'DiffusionMergedCommitsQuery',
|
||||||
|
'DiffusionGitRawDiffQuery' => 'DiffusionRawDiffQuery',
|
||||||
'DiffusionGitRenameHistoryQuery' => 'DiffusionRenameHistoryQuery',
|
'DiffusionGitRenameHistoryQuery' => 'DiffusionRenameHistoryQuery',
|
||||||
'DiffusionGitRequest' => 'DiffusionRequest',
|
'DiffusionGitRequest' => 'DiffusionRequest',
|
||||||
'DiffusionGitTagListQuery' => 'DiffusionTagListQuery',
|
'DiffusionGitTagListQuery' => 'DiffusionTagListQuery',
|
||||||
|
@ -1321,6 +1326,7 @@ phutil_register_library_map(array(
|
||||||
'DiffusionMercurialHistoryQuery' => 'DiffusionHistoryQuery',
|
'DiffusionMercurialHistoryQuery' => 'DiffusionHistoryQuery',
|
||||||
'DiffusionMercurialLastModifiedQuery' => 'DiffusionLastModifiedQuery',
|
'DiffusionMercurialLastModifiedQuery' => 'DiffusionLastModifiedQuery',
|
||||||
'DiffusionMercurialMergedCommitsQuery' => 'DiffusionMergedCommitsQuery',
|
'DiffusionMercurialMergedCommitsQuery' => 'DiffusionMergedCommitsQuery',
|
||||||
|
'DiffusionMercurialRawDiffQuery' => 'DiffusionRawDiffQuery',
|
||||||
'DiffusionMercurialRenameHistoryQuery' => 'DiffusionRenameHistoryQuery',
|
'DiffusionMercurialRenameHistoryQuery' => 'DiffusionRenameHistoryQuery',
|
||||||
'DiffusionMercurialRequest' => 'DiffusionRequest',
|
'DiffusionMercurialRequest' => 'DiffusionRequest',
|
||||||
'DiffusionMercurialTagListQuery' => 'DiffusionTagListQuery',
|
'DiffusionMercurialTagListQuery' => 'DiffusionTagListQuery',
|
||||||
|
@ -1328,6 +1334,7 @@ phutil_register_library_map(array(
|
||||||
'DiffusionPathCompleteController' => 'DiffusionController',
|
'DiffusionPathCompleteController' => 'DiffusionController',
|
||||||
'DiffusionPathQueryTestCase' => 'PhabricatorTestCase',
|
'DiffusionPathQueryTestCase' => 'PhabricatorTestCase',
|
||||||
'DiffusionPathValidateController' => 'DiffusionController',
|
'DiffusionPathValidateController' => 'DiffusionController',
|
||||||
|
'DiffusionRawDiffQuery' => 'DiffusionQuery',
|
||||||
'DiffusionRenameHistoryQuery' => 'DiffusionQuery',
|
'DiffusionRenameHistoryQuery' => 'DiffusionQuery',
|
||||||
'DiffusionRepositoryController' => 'DiffusionController',
|
'DiffusionRepositoryController' => 'DiffusionController',
|
||||||
'DiffusionSvnBrowseQuery' => 'DiffusionBrowseQuery',
|
'DiffusionSvnBrowseQuery' => 'DiffusionBrowseQuery',
|
||||||
|
@ -1339,6 +1346,7 @@ phutil_register_library_map(array(
|
||||||
'DiffusionSvnHistoryQuery' => 'DiffusionHistoryQuery',
|
'DiffusionSvnHistoryQuery' => 'DiffusionHistoryQuery',
|
||||||
'DiffusionSvnLastModifiedQuery' => 'DiffusionLastModifiedQuery',
|
'DiffusionSvnLastModifiedQuery' => 'DiffusionLastModifiedQuery',
|
||||||
'DiffusionSvnMergedCommitsQuery' => 'DiffusionMergedCommitsQuery',
|
'DiffusionSvnMergedCommitsQuery' => 'DiffusionMergedCommitsQuery',
|
||||||
|
'DiffusionSvnRawDiffQuery' => 'DiffusionRawDiffQuery',
|
||||||
'DiffusionSvnRenameHistoryQuery' => 'DiffusionRenameHistoryQuery',
|
'DiffusionSvnRenameHistoryQuery' => 'DiffusionRenameHistoryQuery',
|
||||||
'DiffusionSvnRequest' => 'DiffusionRequest',
|
'DiffusionSvnRequest' => 'DiffusionRequest',
|
||||||
'DiffusionSvnTagListQuery' => 'DiffusionTagListQuery',
|
'DiffusionSvnTagListQuery' => 'DiffusionTagListQuery',
|
||||||
|
|
|
@ -34,6 +34,10 @@ final class DiffusionCommitController extends DiffusionController {
|
||||||
$request = $this->getRequest();
|
$request = $this->getRequest();
|
||||||
$user = $request->getUser();
|
$user = $request->getUser();
|
||||||
|
|
||||||
|
if ($request->getStr('diff')) {
|
||||||
|
return $this->buildRawDiffResponse($drequest);
|
||||||
|
}
|
||||||
|
|
||||||
$callsign = $drequest->getRepository()->getCallsign();
|
$callsign = $drequest->getRepository()->getCallsign();
|
||||||
|
|
||||||
$content = array();
|
$content = array();
|
||||||
|
@ -676,7 +680,8 @@ final class DiffusionCommitController extends DiffusionController {
|
||||||
private function renderHeadsupActionList(
|
private function renderHeadsupActionList(
|
||||||
PhabricatorRepositoryCommit $commit) {
|
PhabricatorRepositoryCommit $commit) {
|
||||||
|
|
||||||
$user = $this->getRequest()->getUser();
|
$request = $this->getRequest();
|
||||||
|
$user = $request->getUser();
|
||||||
|
|
||||||
$actions = array();
|
$actions = array();
|
||||||
|
|
||||||
|
@ -725,6 +730,12 @@ final class DiffusionCommitController extends DiffusionController {
|
||||||
$action->setClass('transcripts-herald');
|
$action->setClass('transcripts-herald');
|
||||||
$actions[] = $action;
|
$actions[] = $action;
|
||||||
|
|
||||||
|
$action = new AphrontHeadsupActionView();
|
||||||
|
$action->setName('Download Raw Diff');
|
||||||
|
$action->setURI($request->getRequestURI()->alter('diff', true));
|
||||||
|
$action->setClass('action-download');
|
||||||
|
$actions[] = $action;
|
||||||
|
|
||||||
$action_list = new AphrontHeadsupActionListView();
|
$action_list = new AphrontHeadsupActionListView();
|
||||||
$action_list->setActions($actions);
|
$action_list->setActions($actions);
|
||||||
|
|
||||||
|
@ -795,4 +806,29 @@ final class DiffusionCommitController extends DiffusionController {
|
||||||
return trim($stdout, "() \n");
|
return trim($stdout, "() \n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function buildRawDiffResponse(DiffusionRequest $drequest) {
|
||||||
|
$raw_query = DiffusionRawDiffQuery::newFromDiffusionRequest($drequest);
|
||||||
|
$raw_diff = $raw_query->loadRawDiff();
|
||||||
|
|
||||||
|
$hash = PhabricatorHash::digest($raw_diff);
|
||||||
|
|
||||||
|
$file = id(new PhabricatorFile())->loadOneWhere(
|
||||||
|
'contentHash = %s LIMIT 1',
|
||||||
|
$hash);
|
||||||
|
if (!$file) {
|
||||||
|
// We're just caching the data; this is always safe.
|
||||||
|
$unguarded = AphrontWriteGuard::beginScopedUnguardedWrites();
|
||||||
|
|
||||||
|
$file = PhabricatorFile::newFromFileData(
|
||||||
|
$raw_diff,
|
||||||
|
array(
|
||||||
|
'name' => $drequest->getCommit().'.diff',
|
||||||
|
));
|
||||||
|
|
||||||
|
unset($unguarded);
|
||||||
|
}
|
||||||
|
|
||||||
|
return id(new AphrontRedirectResponse())->setURI($file->getBestURI());
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,8 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_module('phabricator', 'aphront/response/redirect');
|
||||||
|
phutil_require_module('phabricator', 'aphront/writeguard');
|
||||||
phutil_require_module('phabricator', 'applications/audit/constants/action');
|
phutil_require_module('phabricator', 'applications/audit/constants/action');
|
||||||
phutil_require_module('phabricator', 'applications/audit/constants/commitstatus');
|
phutil_require_module('phabricator', 'applications/audit/constants/commitstatus');
|
||||||
phutil_require_module('phabricator', 'applications/audit/constants/status');
|
phutil_require_module('phabricator', 'applications/audit/constants/status');
|
||||||
|
@ -25,11 +27,13 @@ phutil_require_module('phabricator', 'applications/diffusion/query/parents/base'
|
||||||
phutil_require_module('phabricator', 'applications/diffusion/query/path');
|
phutil_require_module('phabricator', 'applications/diffusion/query/path');
|
||||||
phutil_require_module('phabricator', 'applications/diffusion/query/pathchange/base');
|
phutil_require_module('phabricator', 'applications/diffusion/query/pathchange/base');
|
||||||
phutil_require_module('phabricator', 'applications/diffusion/query/pathid/base');
|
phutil_require_module('phabricator', 'applications/diffusion/query/pathid/base');
|
||||||
|
phutil_require_module('phabricator', 'applications/diffusion/query/rawdiff/base');
|
||||||
phutil_require_module('phabricator', 'applications/diffusion/request/base');
|
phutil_require_module('phabricator', 'applications/diffusion/request/base');
|
||||||
phutil_require_module('phabricator', 'applications/diffusion/view/commentlist');
|
phutil_require_module('phabricator', 'applications/diffusion/view/commentlist');
|
||||||
phutil_require_module('phabricator', 'applications/diffusion/view/commitchangetable');
|
phutil_require_module('phabricator', 'applications/diffusion/view/commitchangetable');
|
||||||
phutil_require_module('phabricator', 'applications/diffusion/view/historytable');
|
phutil_require_module('phabricator', 'applications/diffusion/view/historytable');
|
||||||
phutil_require_module('phabricator', 'applications/draft/storage/draft');
|
phutil_require_module('phabricator', 'applications/draft/storage/draft');
|
||||||
|
phutil_require_module('phabricator', 'applications/files/storage/file');
|
||||||
phutil_require_module('phabricator', 'applications/flag/constants/color');
|
phutil_require_module('phabricator', 'applications/flag/constants/color');
|
||||||
phutil_require_module('phabricator', 'applications/flag/query/flag');
|
phutil_require_module('phabricator', 'applications/flag/query/flag');
|
||||||
phutil_require_module('phabricator', 'applications/markup/engine');
|
phutil_require_module('phabricator', 'applications/markup/engine');
|
||||||
|
@ -41,6 +45,7 @@ phutil_require_module('phabricator', 'infrastructure/edges/constants/config');
|
||||||
phutil_require_module('phabricator', 'infrastructure/edges/query/edge');
|
phutil_require_module('phabricator', 'infrastructure/edges/query/edge');
|
||||||
phutil_require_module('phabricator', 'infrastructure/env');
|
phutil_require_module('phabricator', 'infrastructure/env');
|
||||||
phutil_require_module('phabricator', 'infrastructure/javelin/api');
|
phutil_require_module('phabricator', 'infrastructure/javelin/api');
|
||||||
|
phutil_require_module('phabricator', 'infrastructure/util/hash');
|
||||||
phutil_require_module('phabricator', 'storage/queryfx');
|
phutil_require_module('phabricator', 'storage/queryfx');
|
||||||
phutil_require_module('phabricator', 'view/form/base');
|
phutil_require_module('phabricator', 'view/form/base');
|
||||||
phutil_require_module('phabricator', 'view/form/control/select');
|
phutil_require_module('phabricator', 'view/form/control/select');
|
||||||
|
|
|
@ -29,44 +29,8 @@ final class DiffusionGitDiffQuery extends DiffusionDiffQuery {
|
||||||
// TODO: This side effect is kind of skethcy.
|
// TODO: This side effect is kind of skethcy.
|
||||||
$drequest->setCommit($effective_commit);
|
$drequest->setCommit($effective_commit);
|
||||||
|
|
||||||
$options = array(
|
$raw_query = DiffusionRawDiffQuery::newFromDiffusionRequest($drequest);
|
||||||
'-M',
|
$raw_diff = $raw_query->loadRawDiff();
|
||||||
'-C',
|
|
||||||
'--no-ext-diff',
|
|
||||||
'--no-color',
|
|
||||||
'--src-prefix=a/',
|
|
||||||
'--dst-prefix=b/',
|
|
||||||
'-U65535',
|
|
||||||
);
|
|
||||||
$options = implode(' ', $options);
|
|
||||||
|
|
||||||
try {
|
|
||||||
list($raw_diff) = $repository->execxLocalCommand(
|
|
||||||
'diff %C %s^ %s -- %s',
|
|
||||||
$options,
|
|
||||||
$effective_commit,
|
|
||||||
$effective_commit,
|
|
||||||
$drequest->getPath());
|
|
||||||
} catch (CommandException $ex) {
|
|
||||||
// Check if this is the root commit by seeing if it has parents.
|
|
||||||
list($parents) = $repository->execxLocalCommand(
|
|
||||||
'log --format=%s %s --',
|
|
||||||
'%P', // "parents"
|
|
||||||
$effective_commit);
|
|
||||||
if (!strlen(trim($parents))) {
|
|
||||||
// No parents means we're looking at the root revision. Diff against
|
|
||||||
// the empty tree hash instead, since there is no parent so "^" does
|
|
||||||
// not work. See ArcanistGitAPI for more discussion.
|
|
||||||
list($raw_diff) = $repository->execxLocalCommand(
|
|
||||||
'diff %C %s %s -- %s',
|
|
||||||
$options,
|
|
||||||
ArcanistGitAPI::GIT_MAGIC_ROOT_COMMIT,
|
|
||||||
$effective_commit,
|
|
||||||
$drequest->getPath());
|
|
||||||
} else {
|
|
||||||
throw $ex;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$raw_diff) {
|
if (!$raw_diff) {
|
||||||
return null;
|
return null;
|
||||||
|
|
|
@ -7,10 +7,10 @@
|
||||||
|
|
||||||
|
|
||||||
phutil_require_module('arcanist', 'parser/diff');
|
phutil_require_module('arcanist', 'parser/diff');
|
||||||
phutil_require_module('arcanist', 'repository/api/git');
|
|
||||||
|
|
||||||
phutil_require_module('phabricator', 'applications/differential/storage/diff');
|
phutil_require_module('phabricator', 'applications/differential/storage/diff');
|
||||||
phutil_require_module('phabricator', 'applications/diffusion/query/diff/base');
|
phutil_require_module('phabricator', 'applications/diffusion/query/diff/base');
|
||||||
|
phutil_require_module('phabricator', 'applications/diffusion/query/rawdiff/base');
|
||||||
|
|
||||||
|
|
||||||
phutil_require_source('DiffusionGitDiffQuery.php');
|
phutil_require_source('DiffusionGitDiffQuery.php');
|
||||||
|
|
|
@ -29,13 +29,8 @@ final class DiffusionMercurialDiffQuery extends DiffusionDiffQuery {
|
||||||
// TODO: This side effect is kind of skethcy.
|
// TODO: This side effect is kind of skethcy.
|
||||||
$drequest->setCommit($effective_commit);
|
$drequest->setCommit($effective_commit);
|
||||||
|
|
||||||
$path = $drequest->getPath();
|
$query = DiffusionRawDiffQuery::newFromDiffusionRequest($drequest);
|
||||||
|
$raw_diff = $query->loadRawDiff();
|
||||||
list($raw_diff) = $repository->execxLocalCommand(
|
|
||||||
'diff -U %d --git --change %s -- %s',
|
|
||||||
65535,
|
|
||||||
$effective_commit,
|
|
||||||
$path);
|
|
||||||
|
|
||||||
$parser = new ArcanistDiffParser();
|
$parser = new ArcanistDiffParser();
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,7 @@ phutil_require_module('arcanist', 'parser/diff');
|
||||||
|
|
||||||
phutil_require_module('phabricator', 'applications/differential/storage/diff');
|
phutil_require_module('phabricator', 'applications/differential/storage/diff');
|
||||||
phutil_require_module('phabricator', 'applications/diffusion/query/diff/base');
|
phutil_require_module('phabricator', 'applications/diffusion/query/diff/base');
|
||||||
|
phutil_require_module('phabricator', 'applications/diffusion/query/rawdiff/base');
|
||||||
|
|
||||||
|
|
||||||
phutil_require_source('DiffusionMercurialDiffQuery.php');
|
phutil_require_source('DiffusionMercurialDiffQuery.php');
|
||||||
|
|
|
@ -0,0 +1,52 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2012 Facebook, Inc.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
abstract class DiffusionRawDiffQuery extends DiffusionQuery {
|
||||||
|
|
||||||
|
private $request;
|
||||||
|
private $timeout;
|
||||||
|
private $linesOfContext = 65535;
|
||||||
|
|
||||||
|
final public static function newFromDiffusionRequest(
|
||||||
|
DiffusionRequest $request) {
|
||||||
|
return parent::newQueryObject(__CLASS__, $request);
|
||||||
|
}
|
||||||
|
|
||||||
|
final public function loadRawDiff() {
|
||||||
|
return $this->executeQuery();
|
||||||
|
}
|
||||||
|
|
||||||
|
final public function setTimeout($timeout) {
|
||||||
|
$this->timeout = $timeout;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
final public function getTimeout() {
|
||||||
|
return $this->timeout;
|
||||||
|
}
|
||||||
|
|
||||||
|
final public function setLinesOfContext($lines_of_context) {
|
||||||
|
$this->linesOfContext = $lines_of_context;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
final public function getLinesOfContext() {
|
||||||
|
return $this->linesOfContext;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
12
src/applications/diffusion/query/rawdiff/base/__init__.php
Normal file
12
src/applications/diffusion/query/rawdiff/base/__init__.php
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is automatically generated. Lint this module to rebuild it.
|
||||||
|
* @generated
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_module('phabricator', 'applications/diffusion/query/base');
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_source('DiffusionRawDiffQuery.php');
|
|
@ -0,0 +1,85 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2012 Facebook, Inc.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
final class DiffusionGitRawDiffQuery extends DiffusionRawDiffQuery {
|
||||||
|
|
||||||
|
protected function executeQuery() {
|
||||||
|
$drequest = $this->getRequest();
|
||||||
|
$repository = $drequest->getRepository();
|
||||||
|
|
||||||
|
$commit = $drequest->getCommit();
|
||||||
|
|
||||||
|
$options = array(
|
||||||
|
'-M',
|
||||||
|
'-C',
|
||||||
|
'--no-ext-diff',
|
||||||
|
'--no-color',
|
||||||
|
'--src-prefix=a/',
|
||||||
|
'--dst-prefix=b/',
|
||||||
|
'-U'.(int)$this->getLinesOfContext(),
|
||||||
|
);
|
||||||
|
$options = implode(' ', $options);
|
||||||
|
|
||||||
|
// If there's no path, get the entire raw diff.
|
||||||
|
$path = nonempty($drequest->getPath(), '.');
|
||||||
|
|
||||||
|
$future = $repository->getLocalCommandFuture(
|
||||||
|
"diff %C %s^ %s -- %s",
|
||||||
|
$options,
|
||||||
|
$commit,
|
||||||
|
$commit,
|
||||||
|
$path);
|
||||||
|
|
||||||
|
if ($this->getTimeout()) {
|
||||||
|
$future->setTimeout($this->getTimeout());
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
list($raw_diff) = $future->resolvex();
|
||||||
|
} catch (CommandException $ex) {
|
||||||
|
// Check if this is the root commit by seeing if it has parents.
|
||||||
|
list($parents) = $repository->execxLocalCommand(
|
||||||
|
'log --format=%s %s --',
|
||||||
|
'%P', // "parents"
|
||||||
|
$effective_commit);
|
||||||
|
|
||||||
|
if (strlen(trim($parents))) {
|
||||||
|
throw $ex;
|
||||||
|
}
|
||||||
|
|
||||||
|
// No parents means we're looking at the root revision. Diff against
|
||||||
|
// the empty tree hash instead, since there is no parent so "^" does
|
||||||
|
// not work. See ArcanistGitAPI for more discussion.
|
||||||
|
$future = $repository->getLocalCommandFuture(
|
||||||
|
'diff %C %s %s -- %s',
|
||||||
|
$options,
|
||||||
|
ArcanistGitAPI::GIT_MAGIC_ROOT_COMMIT,
|
||||||
|
$commit,
|
||||||
|
$drequest->getPath());
|
||||||
|
|
||||||
|
if ($this->getTimeout()) {
|
||||||
|
$future->setTimeout($this->getTimeout());
|
||||||
|
}
|
||||||
|
|
||||||
|
list($raw_diff) = $future->resolvex();
|
||||||
|
}
|
||||||
|
|
||||||
|
return $raw_diff;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
16
src/applications/diffusion/query/rawdiff/git/__init__.php
Normal file
16
src/applications/diffusion/query/rawdiff/git/__init__.php
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is automatically generated. Lint this module to rebuild it.
|
||||||
|
* @generated
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_module('arcanist', 'repository/api/git');
|
||||||
|
|
||||||
|
phutil_require_module('phabricator', 'applications/diffusion/query/rawdiff/base');
|
||||||
|
|
||||||
|
phutil_require_module('phutil', 'utils');
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_source('DiffusionGitRawDiffQuery.php');
|
|
@ -0,0 +1,45 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2012 Facebook, Inc.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
final class DiffusionMercurialRawDiffQuery extends DiffusionRawDiffQuery {
|
||||||
|
|
||||||
|
protected function executeQuery() {
|
||||||
|
$drequest = $this->getRequest();
|
||||||
|
$repository = $drequest->getRepository();
|
||||||
|
|
||||||
|
$commit = $drequest->getCommit();
|
||||||
|
|
||||||
|
// If there's no path, get the entire raw diff.
|
||||||
|
$path = nonempty($drequest->getPath(), '.');
|
||||||
|
|
||||||
|
$future = $repository->getLocalCommandFuture(
|
||||||
|
'diff -U %d --git --change %s -- %s',
|
||||||
|
$this->getLinesOfContext(),
|
||||||
|
$commit,
|
||||||
|
$path);
|
||||||
|
|
||||||
|
if ($this->getTimeout()) {
|
||||||
|
$future->setTimeout($this->getTimeout());
|
||||||
|
}
|
||||||
|
|
||||||
|
list($raw_diff) = $future->resolvex();
|
||||||
|
|
||||||
|
return $raw_diff;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,14 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is automatically generated. Lint this module to rebuild it.
|
||||||
|
* @generated
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_module('phabricator', 'applications/diffusion/query/rawdiff/base');
|
||||||
|
|
||||||
|
phutil_require_module('phutil', 'utils');
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_source('DiffusionMercurialRawDiffQuery.php');
|
|
@ -0,0 +1,42 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2012 Facebook, Inc.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
final class DiffusionSvnRawDiffQuery extends DiffusionRawDiffQuery {
|
||||||
|
|
||||||
|
protected function executeQuery() {
|
||||||
|
$drequest = $this->getRequest();
|
||||||
|
$repository = $drequest->getRepository();
|
||||||
|
|
||||||
|
$commit = $drequest->getCommit();
|
||||||
|
|
||||||
|
$future = $repository->getRemoteCommandFuture(
|
||||||
|
'diff --diff-cmd diff -x -U%d -c %d %s%s@',
|
||||||
|
$this->getLinesOfContext(),
|
||||||
|
$commit,
|
||||||
|
$repository->getRemoteURI(),
|
||||||
|
$drequest->getPath());
|
||||||
|
|
||||||
|
if ($this->getTimeout()) {
|
||||||
|
$future->setTimeout($this->getTimeout());
|
||||||
|
}
|
||||||
|
|
||||||
|
list($raw_diff) = $future->resolvex();
|
||||||
|
return $raw_diff;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
12
src/applications/diffusion/query/rawdiff/svn/__init__.php
Normal file
12
src/applications/diffusion/query/rawdiff/svn/__init__.php
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is automatically generated. Lint this module to rebuild it.
|
||||||
|
* @generated
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_module('phabricator', 'applications/diffusion/query/rawdiff/base');
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_source('DiffusionSvnRawDiffQuery.php');
|
|
@ -54,6 +54,10 @@
|
||||||
background-image: url(/rsrc/image/icon/tango/upload.png);
|
background-image: url(/rsrc/image/icon/tango/upload.png);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.aphront-headsup-action-list .action-download {
|
||||||
|
background-image: url(/rsrc/image/icon/tango/go-down.png);
|
||||||
|
}
|
||||||
|
|
||||||
.aphront-headsup-action-list .transcripts-metamta {
|
.aphront-headsup-action-list .transcripts-metamta {
|
||||||
background-image: url(/rsrc/image/icon/tango/log.png);
|
background-image: url(/rsrc/image/icon/tango/log.png);
|
||||||
}
|
}
|
||||||
|
|
BIN
webroot/rsrc/image/icon/tango/go-down.png
Normal file
BIN
webroot/rsrc/image/icon/tango/go-down.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 683 B |
Loading…
Reference in a new issue