1 #-------------------------------------------------------------------------------
2 # elftools: common/py3compat.py
4 # Python 2/3 compatibility code
6 # Eli Bendersky (eliben@gmail.com)
7 # This code is in the public domain
8 #-------------------------------------------------------------------------------
10 PY3
= sys
.version_info
[0] == 3
12 Python 2 is no longer supported by pyelftools; if you need to use Python 2,
13 please download an older pyelftools version (such as version 0.29).
19 from pathlib
import Path
21 StringIO
= io
.StringIO
24 # Functions for acting on bytestrings and strings. In Python 2 and 3,
25 # strings and bytes are the same and chr/ord can be used to convert between
26 # numeric byte values and their string representations. In Python 3, bytes
27 # and strings are different types and bytes hold numeric values when
30 def bytes2hex(b
, sep
=''):
33 return sep
.join(map('{:02x}'.format
, b
))
35 def bytes2str(b
): return b
.decode('latin-1')
36 def str2bytes(s
): return s
.encode('latin-1')
37 def int2byte(i
): return bytes((i
,))
38 def byte2int(b
): return b
41 """Return an iterator over the elements of a bytes object.
43 For example, for b'abc' yields b'a', b'b' and then b'c'.
45 for i
in range(len(b
)):
53 return Path(s
).as_posix()
60 StringIO
= BytesIO
= cStringIO
.StringIO
62 def bytes2hex(b
, sep
=''):
66 return sep
.join(res
[i
:i
+2] for i
in range(0, len(res
), 2))
68 def bytes2str(b
): return b
69 def str2bytes(s
): return s
75 from itertools
import ifilter
80 return posixpath
.join(*os
.path
.split(s
))
84 """Return an iterator over the keys of a dictionary."""
85 return getattr(d
, 'keys' if PY3
else 'iterkeys')()
88 """Return an iterator over the values of a dictionary."""
89 return getattr(d
, 'values' if PY3
else 'itervalues')()
92 """Return an iterator over the items of a dictionary."""
93 return getattr(d
, 'items' if PY3
else 'iteritems')()
96 from collections
.abc
import Mapping
# python >= 3.3
98 from collections
import Mapping
# python < 3.3