compat: make override of createmarkers work on wrapped function
If createmarkers() has been wrapped using functools.partial(), the
__code__ attribute won't exist. Fix by unwrapping partial functions. I
tried to find another attribute to use as proxy for the
"__code__.co_argcount < 6", but there were no new functions or similar
added in that commit.
# Copyright 2017 Octobus <contact@octobus.net>## 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"""importinspectimportfunctoolsfrommercurialimport(copies,context,hg,mdiff,obsolete,revset,util,wireproto,)frommercurial.hgwebimporthgweb_mod# hg < 4.2 compattry:frommercurialimportvfsasvfsmodvfsmod.vfsexceptImportError:frommercurialimportscmutilasvfsmodtry:frommercurialimportobsutilobsutil.closestpredecessorsexceptImportError:obsutil=None# hg < 4.6 compat (c8e2d6ed1f9e)try:frommercurialimportlogcmdutilchangesetdisplayer=logcmdutil.changesetdisplayerchangesetprinter=logcmdutil.changesetprinterdisplaygraph=logcmdutil.displaygraphexcept(AttributeError,ImportError):frommercurialimportcmdutilchangesetdisplayer=cmdutil.show_changesetchangesetprinter=cmdutil.changeset_printerdisplaygraph=cmdutil.displaygraphfrom.import(exthelper,)eh=exthelper.exthelper()# Wrap obsolete.creatmarkers and make it accept but ignore "operation" argument# for hg < 4.3createmarkers=obsolete.createmarkersoriginalcreatemarkers=createmarkerswhileisinstance(originalcreatemarkers,functools.partial):originalcreatemarkers=originalcreatemarkers.funciforiginalcreatemarkers.__code__.co_argcount<6:defcreatemarkers(repo,relations,flag=0,date=None,metadata=None,operation=None):returnobsolete.createmarkers(repo,relations,flag,date,metadata)ifnotutil.safehasattr(hg,'_copycache'):# exact copy of relevantmarkers as in Mercurial-176d1a0ce385# this fixes relevant markers computation for version < hg-4.3@eh.wrapfunction(obsolete.obsstore,'relevantmarkers')defrelevantmarkers(orig,self,nodes):"""return a set of all obsolescence markers relevant to a set of nodes. "relevant" to a set of nodes mean: - marker that use this changeset as successor - prune marker of direct children on this changeset - recursive application of the two rules on precursors of these markers It is a set so you cannot rely on order. Backport of mercurial changeset 176d1a0ce385 for version < 4.3 """pendingnodes=set(nodes)seenmarkers=set()seennodes=set(pendingnodes)precursorsmarkers=self.predecessorssuccsmarkers=self.successorschildren=self.childrenwhilependingnodes:direct=set()forcurrentinpendingnodes:direct.update(precursorsmarkers.get(current,()))pruned=[mforminchildren.get(current,())ifnotm[1]]direct.update(pruned)pruned=[mforminsuccsmarkers.get(current,())ifnotm[1]]direct.update(pruned)direct-=seenmarkerspendingnodes=set([m[0]formindirect])seenmarkers|=directpendingnodes-=seennodesseennodes|=pendingnodesreturnseenmarkers# successors set move from mercurial.obsolete to mercurial.obsutil in 4.3defsuccessorssets(*args,**kwargs):func=getattr(obsutil,'successorssets',None)iffuncisNone:func=obsolete.successorssetsreturnfunc(*args,**kwargs)# allprecursors set move from mercurial.obsolete to mercurial.obsutil in 4.3# allprecursors was renamed into allpredecessors in 4.4defallprecursors(*args,**kwargs):func=getattr(obsutil,'allpredecessors',None)iffuncisNone:func=getattr(obsutil,'allprecursors',None)iffuncisNone:func=obsolete.allprecursorsreturnfunc(*args,**kwargs)# compatibility layer for mercurial < 4.3defbookmarkapplychanges(repo,tr,changes):"""Apply a list of changes to bookmarks """bookmarks=repo._bookmarksifutil.safehasattr(bookmarks,'applychanges'):returnbookmarks.applychanges(repo,tr,changes)forname,nodeinchanges:ifnodeisNone:delbookmarks[name]else:bookmarks[name]=nodebookmarks.recordchange(tr)defisobsnotesupported():# hack to know obsnote is supported. The patches for obsnote support was# pushed before the obsfateprinter patches, so this will serve as a good# checkifnotobsutil:returnFalsereturnutil.safehasattr(obsutil,'obsfateprinter')# Evolution renaming compatTROUBLES={}ifnotutil.safehasattr(context.basectx,'orphan'):TROUBLES['ORPHAN']='unstable'context.basectx.orphan=context.basectx.unstableelse:TROUBLES['ORPHAN']='orphan'ifnotutil.safehasattr(context.basectx,'contentdivergent'):TROUBLES['CONTENTDIVERGENT']='divergent'context.basectx.contentdivergent=context.basectx.divergentelse:TROUBLES['CONTENTDIVERGENT']='content-divergent'ifnotutil.safehasattr(context.basectx,'phasedivergent'):TROUBLES['PHASEDIVERGENT']='bumped'context.basectx.phasedivergent=context.basectx.bumpedelse:TROUBLES['PHASEDIVERGENT']='phase-divergent'ifnotutil.safehasattr(context.basectx,'isunstable'):context.basectx.isunstable=context.basectx.troubledifnotutil.safehasattr(revset,'orphan'):@eh.revset('orphan')defoprhanrevset(*args,**kwargs):returnrevset.unstable(*args,**kwargs)ifnotutil.safehasattr(revset,'contentdivergent'):@eh.revset('contentdivergent')defcontentdivergentrevset(*args,**kwargs):returnrevset.divergent(*args,**kwargs)ifnotutil.safehasattr(revset,'phasedivergent'):@eh.revset('phasedivergent')defphasedivergentrevset(*args,**kwargs):returnrevset.bumped(*args,**kwargs)ifnotutil.safehasattr(context.basectx,'instabilities'):definstabilities(self):"""return the list of instabilities affecting this changeset. Instabilities are returned as strings. possible values are: - orphan, - phase-divergent, - content-divergent. """instabilities=[]ifself.orphan():instabilities.append('orphan')ifself.phasedivergent():instabilities.append('phase-divergent')ifself.contentdivergent():instabilities.append('content-divergent')returninstabilitiescontext.basectx.instabilities=instabilities# XXX: Better detection of property cacheif'predecessors'notindir(obsolete.obsstore):@propertydefpredecessors(self):returnself.precursorsobsolete.obsstore.predecessors=predecessorsifnotutil.safehasattr(obsolete,'_computeorphanset'):obsolete._computeorphanset=obsolete.cachefor('orphan')(obsolete._computeunstableset)ifnotutil.safehasattr(obsolete,'_computecontentdivergentset'):obsolete._computecontentdivergentset=obsolete.cachefor('contentdivergent')(obsolete._computedivergentset)ifnotutil.safehasattr(obsolete,'_computephasedivergentset'):obsolete._computephasedivergentset=obsolete.cachefor('phasedivergent')(obsolete._computebumpedset)defstartpager(ui,cmd):"""function to start a pager in case ui.pager() exists"""ifutil.safehasattr(ui,'pager'):ui.pager(cmd)defduplicatecopies(repo,wctx,rev,fromrev,skiprev=None):# cannot use anything else until 4.3 support is dropped.assertwctx.rev()isNoneifcopies.duplicatecopies.__code__.co_argcount<5:# pre 4.4 duplicatecopies compatcopies.duplicatecopies(repo,rev,fromrev,skiprev=skiprev)else:copies.duplicatecopies(repo,wctx,rev,fromrev,skiprev=skiprev)defmemfilectx(repo,ctx,fctx,flags,copied,path):# XXX Would it be better at the module level?varnames=context.memfilectx.__init__.__code__.co_varnamesctxmandatory=varnames[2]=="changectx"ifctxmandatory:mctx=context.memfilectx(repo,ctx,fctx.path(),fctx.data(),islink='l'inflags,isexec='x'inflags,copied=copied.get(path))else:mctx=context.memfilectx(repo,fctx.path(),fctx.data(),islink='l'inflags,isexec='x'inflags,copied=copied.get(path))returnmctxdefgetcachevfs(repo):cachevfs=getattr(repo,'cachevfs',None)ifcachevfsisNone:cachevfs=vfsmod.vfs(repo.vfs.join('cache'))cachevfs.createmode=repo.store.createmodereturncachevfsdefstrdiff(a,b,fn1,fn2):""" A version of mdiff.unidiff for comparing two strings """args=[a,'',b,'',fn1,fn2]# hg < 4.6 compat 8b6dd3922f70argspec=inspect.getargspec(mdiff.unidiff)if'binary'inargspec.args:args.append(False)returnmdiff.unidiff(*args)# date relatedtry:importmercurial.utils.dateutilmakedate=mercurial.utils.dateutil.makedateparsedate=mercurial.utils.dateutil.parsedateexceptImportErrorase:importmercurial.utilmakedate=mercurial.util.makedateparsedate=mercurial.util.parsedatedefwireprotocommand(exthelper,name,args='',permission='pull'):if3<=len(wireproto.wireprotocommand.func_defaults):returnwireproto.wireprotocommand(name,args,permission=permission)else:# <= hg-4.5 permission must be registered in dictionnarydefdecorator(func):@eh.extsetupdefinstall(ui):hgweb_mod.perms[name]=permissionwireproto.commands[name]=(func,args)returndecorator