diff options
author | Sebastian Thiel <byronimo@gmail.com> | 2016-04-14 07:41:58 +0200 |
---|---|---|
committer | Sebastian Thiel <byronimo@gmail.com> | 2016-04-14 07:41:58 +0200 |
commit | 20a338ff049e7febe97411a6dc418a02ec11eefa (patch) | |
tree | 23227b6e4f39981a1099519b3187d37f06bd02c3 /git/compat.py | |
parent | 978eb5bd4751acf9d53c8b6626dc3f7832a20ccf (diff) | |
parent | f533a68cb5295f912da05e061a0b9bca05b3f0c8 (diff) | |
download | gitpython-20a338ff049e7febe97411a6dc418a02ec11eefa.tar.gz |
Merge pull request #409 from nvie/add-incremental-blame-support
Add incremental blame support
Diffstat (limited to 'git/compat.py')
-rw-r--r-- | git/compat.py | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/git/compat.py b/git/compat.py index 1ea2119e..146bfd4b 100644 --- a/git/compat.py +++ b/git/compat.py @@ -8,6 +8,7 @@ # flake8: noqa import sys +import six from gitdb.utils.compat import ( PY3, @@ -46,6 +47,20 @@ else: def mviter(d): return d.itervalues() +PRE_PY27 = sys.version_info < (2, 7) + + +def safe_decode(s): + """Safely decodes a binary string to unicode""" + if isinstance(s, six.text_type): + return s + elif isinstance(s, six.binary_type): + if PRE_PY27: + return s.decode(defenc) # we're screwed + else: + return s.decode(defenc, errors='replace') + raise TypeError('Expected bytes or text, but got %r' % (s,)) + def with_metaclass(meta, *bases): """copied from https://github.com/Byron/bcore/blob/master/src/python/butility/future.py#L15""" |