Comments
Patch
@@ -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)
@@ -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