You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

_iotype.py 2.6KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. ###############################################################################
  2. #
  3. # The MIT License (MIT)
  4. #
  5. # Copyright (c) Crossbar.io Technologies GmbH
  6. #
  7. # Permission is hereby granted, free of charge, to any person obtaining a copy
  8. # of this software and associated documentation files (the "Software"), to deal
  9. # in the Software without restriction, including without limitation the rights
  10. # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  11. # copies of the Software, and to permit persons to whom the Software is
  12. # furnished to do so, subject to the following conditions:
  13. #
  14. # The above copyright notice and this permission notice shall be included in
  15. # all copies or substantial portions of the Software.
  16. #
  17. # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  18. # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  19. # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  20. # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  21. # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  22. # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  23. # THE SOFTWARE.
  24. #
  25. ###############################################################################
  26. from __future__ import absolute_import, division
  27. from six import PY3, PY2
  28. if PY3:
  29. unicode = str
  30. else:
  31. unicode = unicode
  32. def guess_stream_needs_encoding(fileobj, default=True):
  33. """
  34. Guess the type (bytes/unicode) of this stream, and return whether or not it
  35. requires text to be encoded before written into it.
  36. """
  37. # XXX: Unicode
  38. # On Python 2, stdout is bytes. However, we can't wrap it in a
  39. # TextIOWrapper, as it's not from IOBase, so it doesn't have .seekable.
  40. # It does, however, have a mode, and we can cheese it base on that.
  41. # On Python 3, stdout is a TextIOWrapper, and so we can safely write
  42. # str to it, and it will encode it correctly for the target terminal or
  43. # whatever.
  44. # If it's a io.BytesIO or StringIO, then it won't have a mode, but it
  45. # is a read/write stream, so we can get its type by reading 0 bytes and
  46. # checking the type.
  47. try:
  48. # If it's a r/w stream, this will give us the type of it
  49. t = type(fileobj.read(0))
  50. if t is bytes:
  51. return True
  52. elif t is unicode:
  53. return False
  54. except Exception:
  55. pass
  56. try:
  57. mode = fileobj.mode
  58. if PY2 and mode == "w":
  59. mode = "wb"
  60. if "b" in mode:
  61. return True
  62. else:
  63. return False
  64. except Exception:
  65. pass
  66. return default