Merge "Use oslo.utils encodeutils for encode/decode functions"
This commit is contained in:
		| @@ -28,6 +28,7 @@ import types | |||||||
|  |  | ||||||
| import enum | import enum | ||||||
| from oslo_serialization import jsonutils | from oslo_serialization import jsonutils | ||||||
|  | from oslo_utils import encodeutils | ||||||
| from oslo_utils import importutils | from oslo_utils import importutils | ||||||
| from oslo_utils import netutils | from oslo_utils import netutils | ||||||
| from oslo_utils import reflection | from oslo_utils import reflection | ||||||
| @@ -216,30 +217,28 @@ def fix_newlines(text, replacement=os.linesep): | |||||||
|     return replacement.join(text.splitlines()) |     return replacement.join(text.splitlines()) | ||||||
|  |  | ||||||
|  |  | ||||||
| def binary_encode(text, encoding='utf-8'): | def binary_encode(text, encoding='utf-8', errors='strict'): | ||||||
|     """Converts a string of into a binary type using given encoding. |     """Encodes a text string into a binary string using given encoding. | ||||||
|  |  | ||||||
|     Does nothing if text not unicode string. |     Does nothing if data is already a binary string (raises on unknown types). | ||||||
|     """ |     """ | ||||||
|     if isinstance(text, six.binary_type): |     if isinstance(text, six.binary_type): | ||||||
|         return text |         return text | ||||||
|     elif isinstance(text, six.text_type): |  | ||||||
|         return text.encode(encoding) |  | ||||||
|     else: |     else: | ||||||
|         raise TypeError("Expected binary or string type not '%s'" % type(text)) |         return encodeutils.safe_encode(text, encoding=encoding, | ||||||
|  |                                        errors=errors) | ||||||
|  |  | ||||||
|  |  | ||||||
| def binary_decode(data, encoding='utf-8'): | def binary_decode(data, encoding='utf-8', errors='strict'): | ||||||
|     """Converts a binary type into a text type using given encoding. |     """Decodes a binary string into a text string using given encoding. | ||||||
|  |  | ||||||
|     Does nothing if data is already unicode string. |     Does nothing if data is already a text string (raises on unknown types). | ||||||
|     """ |     """ | ||||||
|     if isinstance(data, six.binary_type): |     if isinstance(data, six.text_type): | ||||||
|         return data.decode(encoding) |  | ||||||
|     elif isinstance(data, six.text_type): |  | ||||||
|         return data |         return data | ||||||
|     else: |     else: | ||||||
|         raise TypeError("Expected binary or string type not '%s'" % type(data)) |         return encodeutils.safe_decode(data, incoming=encoding, | ||||||
|  |                                        errors=errors) | ||||||
|  |  | ||||||
|  |  | ||||||
| def decode_json(raw_data, root_types=(dict,)): | def decode_json(raw_data, root_types=(dict,)): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Jenkins
					Jenkins