Source code for wolframclient.serializers.utils

from __future__ import absolute_import, print_function, unicode_literals

import decimal
import re

from wolframclient.utils.encoding import force_bytes

# replacement method borrowed from json


ESCAPE = re.compile(r'[\x00-\x1f\\"\b\f\n\r\t]')
ESCAPE_DCT = {
    "\\": "\\\\",
    '"': '\\"',
    "\b": "\\b",
    "\f": "\\f",
    "\n": "\\n",
    "\r": "\\r",
    "\t": "\\t",
}
for i in range(0x20):
    ESCAPE_DCT.setdefault(chr(i), "\\u{:04x}".format(i))
    # ESCAPE_DCT.setdefault(chr(i), '\\u%04x' % (i,))
del i


[docs] def replace(match): return ESCAPE_DCT[match.group(0)]
[docs] def py_encode_text(s): yield b'"' yield force_bytes(ESCAPE.sub(replace, s), encoding="iso-8859-1") yield b'"'
[docs] def py_encode_decimal(number, prec=decimal.getcontext().prec): return "{:f}``{:d}".format(number, prec).encode("utf-8")
[docs] def safe_len(obj): try: return len(obj) except TypeError: return