diff --git a/mercurial/utils/stringutil.py b/mercurial/utils/stringutil.py --- a/mercurial/utils/stringutil.py +++ b/mercurial/utils/stringutil.py @@ -25,8 +25,12 @@ def pprint(o): """Pretty print an object.""" - if isinstance(o, (bytes, bytearray)): + if isinstance(o, bytes): return "b'%s'" % escapestr(o) + elif isinstance(o, bytearray): + # codecs.escape_encode() can't handle bytearray, so escapestr fails + # without coercion. + return "bytearray['%s']" % escapestr(bytes(o)) elif isinstance(o, list): return '[%s]' % (b', '.join(pprint(a) for a in o)) elif isinstance(o, dict): @@ -34,6 +38,10 @@ '%s: %s' % (pprint(k), pprint(v)) for k, v in sorted(o.items()))) elif isinstance(o, bool): return b'True' if o else b'False' + elif isinstance(o, int): + return '%d' % o + elif isinstance(o, float): + return '%f' % o else: raise error.ProgrammingError('do not know how to format %r' % o)