diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2016-07-23 20:50:09 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2016-07-23 20:50:09 +0000 | 
| commit | f3fbd1c0586ff6ec7895991e6c28f61a503c36a8 (patch) | |
| tree | 48d008fd3df8c0e73271a4b18474e0aac6dbfe33 /packages/Python/lldbsuite/support/encoded_file.py | |
| parent | 2fc5d2d1dfaf623ce4e24cd8590565902f8c557c (diff) | |
Notes
Diffstat (limited to 'packages/Python/lldbsuite/support/encoded_file.py')
| -rw-r--r-- | packages/Python/lldbsuite/support/encoded_file.py | 48 | 
1 files changed, 48 insertions, 0 deletions
diff --git a/packages/Python/lldbsuite/support/encoded_file.py b/packages/Python/lldbsuite/support/encoded_file.py new file mode 100644 index 000000000000..7581564f7e3a --- /dev/null +++ b/packages/Python/lldbsuite/support/encoded_file.py @@ -0,0 +1,48 @@ +""" +                     The LLVM Compiler Infrastructure + +This file is distributed under the University of Illinois Open Source +License. See LICENSE.TXT for details. + +Prepares language bindings for LLDB build process.  Run with --help +to see a description of the supported command line arguments. +""" + +# Python modules: +import io + +# Third party modules +import six + +def _encoded_read(old_read, encoding): +    def impl(size): +        result = old_read(size) +        # If this is Python 2 then we need to convert the resulting `unicode` back +        # into a `str` before returning +        if six.PY2: +            result = result.encode(encoding) +        return result +    return impl + +def _encoded_write(old_write, encoding): +    def impl(s): +        # If we were asked to write a `str` (in Py2) or a `bytes` (in Py3) decode it +        # as unicode before attempting to write. +        if isinstance(s, six.binary_type): +            s = s.decode(encoding) +        return old_write(s) +    return impl + +''' +Create a Text I/O file object that can be written to with either unicode strings or byte strings +under Python 2 and Python 3, and automatically encodes and decodes as necessary to return the +native string type for the current Python version +''' +def open(file, encoding, mode='r', buffering=-1, errors=None, newline=None, closefd=True): +    wrapped_file = io.open(file, mode=mode, buffering=buffering, encoding=encoding, +                           errors=errors, newline=newline, closefd=closefd) +    new_read = _encoded_read(getattr(wrapped_file, 'read'), encoding) +    new_write = _encoded_write(getattr(wrapped_file, 'write'), encoding) +    setattr(wrapped_file, 'read', new_read) +    setattr(wrapped_file, 'write', new_write) +    return wrapped_file  | 
