# HG changeset patch # User Pierre-Yves David # Date 1675355242 -3600 # Node ID 6be6406a298830bfc690e36f22da8b74a8c7afe8 # Parent 3b642b384b14914ec86504cc0571231493f59dd4 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. diff -r 3b642b384b14 -r 6be6406a2988 mercurial/hgweb/server.py --- a/mercurial/hgweb/server.py Thu Feb 02 17:27:06 2023 +0100 +++ b/mercurial/hgweb/server.py Thu Feb 02 17:27:22 2023 +0100 @@ -100,7 +100,7 @@ def log_request(self, code='-', size='-'): xheaders = [] - if util.safehasattr(self, b'headers'): + if util.safehasattr(self, 'headers'): xheaders = [ h for h in self.headers.items() if h[0].startswith('x-') ]