# HG changeset patch # User Jun Wu # Date 2017-07-18 06:14:06 # Node ID 75fdaf851e8379e882e3bc6cf4495b5149266f84 # Parent aa6c290a77fa91c3dc7d30da3367a47a1c1c41e9 phabricator: change "readpatch" to be more flexible Previously, `readpatch` and `querydrev` take a same `params` and `stack` parameters. This patch changes `readpatch` so it takes the output of `querydrev`, not the input of `querydrev`. This makes the code more flexible and cleaner. Differential Revision: https://phab.mercurial-scm.org/D124 diff --git a/contrib/phabricator.py b/contrib/phabricator.py --- a/contrib/phabricator.py +++ b/contrib/phabricator.py @@ -635,15 +635,12 @@ def getdiffmeta(diff): meta[r'parent'] = commit[r'parents'][0] return meta or {} -def readpatch(repo, params, write, stack=False): +def readpatch(repo, drevs, write): """generate plain-text patch readable by 'hg import' - write is usually ui.write. params is passed to "differential.query". If - stack is True, also write dependent patches. + write is usually ui.write. drevs is what "querydrev" returns, results of + "differential.query". """ - # Differential Revisions - drevs = querydrev(repo, params, stack) - # Prefetch hg:meta property for all diffs diffids = sorted(set(max(int(v) for v in drev[r'diffs']) for drev in drevs)) diffs = callconduit(repo, 'differential.querydiffs', {'ids': diffids}) @@ -683,4 +680,5 @@ def phabread(ui, repo, revid, **opts): revid = int(revid.split('/')[-1].replace('D', '')) except ValueError: raise error.Abort(_('invalid Revision ID: %s') % revid) - readpatch(repo, {'ids': [revid]}, ui.write, opts.get('stack')) + drevs = querydrev(repo, {'ids': [revid]}, opts.get('stack')) + readpatch(repo, drevs, ui.write)