diff --git a/mercurial/pycompat.py b/mercurial/pycompat.py --- a/mercurial/pycompat.py +++ b/mercurial/pycompat.py @@ -243,6 +243,8 @@ if ispy3: def open(name, mode='r', buffering=-1, encoding=None): return builtins.open(name, sysstr(mode), buffering, encoding) + safehasattr = _wrapattrfunc(builtins.hasattr) + def _getoptbwrapper(orig, args, shortlist, namelist): """ Takes bytes arguments, converts them to unicode, pass them to @@ -326,6 +328,11 @@ else: def getdoc(obj): return getattr(obj, '__doc__', None) + _notset = object() + + def safehasattr(thing, attr): + return getattr(thing, attr, _notset) is not _notset + def _getoptbwrapper(orig, args, shortlist, namelist): return orig(args, shortlist, namelist) diff --git a/mercurial/util.py b/mercurial/util.py --- a/mercurial/util.py +++ b/mercurial/util.py @@ -67,6 +67,7 @@ empty = pycompat.empty httplib = pycompat.httplib pickle = pycompat.pickle queue = pycompat.queue +safehasattr = pycompat.safehasattr socketserver = pycompat.socketserver stderr = pycompat.stderr stdin = pycompat.stdin @@ -177,9 +178,6 @@ except AttributeError: _notset = object() -def safehasattr(thing, attr): - return getattr(thing, attr, _notset) is not _notset - def _rapply(f, xs): if xs is None: # assume None means non-value of optional data