safehasattr: pass attribute name as string instead of bytes
authorPierre-Yves David <pierre-yves.david@octobus.net>
Thu, 02 Feb 2023 17:23:55 +0100
changeset 50571 dbd57239acb8
parent 50570 b0c938f4141a
child 50572 35e420abaef3
safehasattr: pass attribute name as string instead of bytes This is a step toward replacing `util.safehasattr` usage with plain `hasattr`. The builtin function behave poorly in Python2 but this was fixed in Python3. These change are done one by one as they tend to have a small odd to trigger puzzling breackage.
mercurial/dispatch.py
--- a/mercurial/dispatch.py	Thu Feb 02 17:23:46 2023 +0100
+++ b/mercurial/dispatch.py	Thu Feb 02 17:23:55 2023 +0100
@@ -708,7 +708,7 @@
         }
         if name not in adefaults:
             raise AttributeError(name)
-        if self.badalias or util.safehasattr(self, b'shell'):
+        if self.badalias or util.safehasattr(self, 'shell'):
             return adefaults[name]
         return getattr(self.fn, name)