##// END OF EJS Templates
phabricator: try to fetch differential revisions in batch...
Jun Wu -
r33269:ead67493 default
parent child Browse files
Show More
@@ -358,14 +358,34 def querydrev(repo, params, stack=False)
358 358 order that the latter ones depend on the former ones. Otherwise, return a
359 359 list of a unique "Differential Revision dict".
360 360 """
361 prefetched = {} # {id or phid: drev}
362 def fetch(params):
363 """params -> single drev or None"""
364 key = (params.get(r'ids') or params.get(r'phids') or [None])[0]
365 if key in prefetched:
366 return prefetched[key]
367 # Otherwise, send the request. If we're fetching a stack, be smarter
368 # and fetch more ids in one batch, even if it could be unnecessary.
369 batchparams = params
370 if stack and len(params.get(r'ids', [])) == 1:
371 i = int(params[r'ids'][0])
372 # developer config: phabricator.batchsize
373 batchsize = repo.ui.configint('phabricator', 'batchsize', 12)
374 batchparams = {'ids': range(max(1, i - batchsize), i + 1)}
375 drevs = callconduit(repo, 'differential.query', batchparams)
376 # Fill prefetched with the result
377 for drev in drevs:
378 prefetched[drev[r'phid']] = drev
379 prefetched[int(drev[r'id'])] = drev
380 if key not in prefetched:
381 raise error.Abort(_('cannot get Differential Revision %r') % params)
382 return prefetched[key]
383
361 384 result = []
362 385 queue = [params]
363 386 while queue:
364 387 params = queue.pop()
365 drevs = callconduit(repo, 'differential.query', params)
366 if len(drevs) != 1:
367 raise error.Abort(_('cannot get Differential Revision %r') % params)
368 drev = drevs[0]
388 drev = fetch(params)
369 389 result.append(drev)
370 390 if stack:
371 391 auxiliary = drev.get(r'auxiliary', {})
General Comments 0
You need to be logged in to leave comments. Login now