Mercurial > evolve
view hgext3rd/topic/compat.py @ 3678:d725fe3e3989
topic: handle wireproto module change from b4d85bc122bd
This module have been scattered in other place, so we need to detect and handle
this for 4.6+
author | Pierre-Yves David <pierre-yves.david@octobus.net> |
---|---|
date | Thu, 19 Apr 2018 10:50:24 +0200 |
parents | c912eaf29eec |
children | c0d5e0929f8b |
line wrap: on
line source
# Copyright 2017 FUJIWARA Katsunori <foozy@lares.dti.ne.jp> # # This software may be used and distributed according to the terms of the # GNU General Public License version 2 or any later version. """ Compatibility module """ from __future__ import absolute_import import functools from mercurial import ( obsolete, scmutil, util, ) getmarkers = None successorssets = None try: from mercurial import obsutil getmarkers = getattr(obsutil, 'getmarkers', None) successorssets = getattr(obsutil, 'successorssets', None) except ImportError: pass if getmarkers is None: getmarkers = obsolete.getmarkers if successorssets is None: successorssets = obsolete.successorssets # Wrap obsolete.creatmarkers and make it accept but ignore "operation" argument # for hg < 4.3 originalcreatemarkers = obsolete.createmarkers while isinstance(originalcreatemarkers, functools.partial): originalcreatemarkers = originalcreatemarkers.func if originalcreatemarkers.__code__.co_argcount < 6: def createmarkers(repo, relations, flag=0, date=None, metadata=None, operation=None): return obsolete.createmarkers(repo, relations, flag, date, metadata) else: def createmarkers(*args, **kwargs): return obsolete.createmarkers(*args, **kwargs) def startpager(ui, cmd): """function to start a pager in case ui.pager() exists""" try: ui.pager(cmd) except AttributeError: pass def cleanupnodes(repo, replacements, operation, moves=None): # create obsmarkers and move bookmarks # XXX we should be creating marker as we go instead of only at the end, # this makes the operations more modulars if util.safehasattr(scmutil, 'cleanupnodes'): scmutil.cleanupnodes(repo, replacements, 'changetopics', moves=moves) else: relations = [(repo[o], tuple(repo[n] for n in new)) for (o, new) in replacements.iteritems()] createmarkers(repo, relations, operation=operation)