diff options
author | Victor Stinner <victor.stinner@haypocalc.com> | 2011-11-21 21:52:58 (GMT) |
---|---|---|
committer | Victor Stinner <victor.stinner@haypocalc.com> | 2011-11-21 21:52:58 (GMT) |
commit | 42bf77537e612737c7e7e2495c3c481e92391a42 (patch) | |
tree | 860ee37c9a22144d4f9712d8f4b8f2d9288304d9 /Modules | |
parent | 6dd381eb62278f75de7ba01626813de84cd248e7 (diff) | |
download | cpython-42bf77537e612737c7e7e2495c3c481e92391a42.zip cpython-42bf77537e612737c7e7e2495c3c481e92391a42.tar.gz cpython-42bf77537e612737c7e7e2495c3c481e92391a42.tar.bz2 |
Rewrite PyUnicode_EncodeDecimal() to use the new Unicode API
Add tests for PyUnicode_EncodeDecimal() and
PyUnicode_TransformDecimalToASCII().
Diffstat (limited to 'Modules')
-rw-r--r-- | Modules/_testcapimodule.c | 51 |
1 files changed, 49 insertions, 2 deletions
diff --git a/Modules/_testcapimodule.c b/Modules/_testcapimodule.c index 3a6dcd6..962f10b 100644 --- a/Modules/_testcapimodule.c +++ b/Modules/_testcapimodule.c @@ -1500,6 +1500,51 @@ unicode_aswidecharstring(PyObject *self, PyObject *args) } static PyObject * +unicode_encodedecimal(PyObject *self, PyObject *args) +{ + Py_UNICODE *unicode; + Py_ssize_t length; + char *errors = NULL; + PyObject *decimal; + Py_ssize_t decimal_length, new_length; + int res; + + if (!PyArg_ParseTuple(args, "u#|s", &unicode, &length, &errors)) + return NULL; + + decimal_length = length * 7; /* len('€') */ + decimal = PyBytes_FromStringAndSize(NULL, decimal_length); + if (decimal == NULL) + return NULL; + + res = PyUnicode_EncodeDecimal(unicode, length, + PyBytes_AS_STRING(decimal), + errors); + if (res < 0) { + Py_DECREF(decimal); + return NULL; + } + + new_length = strlen(PyBytes_AS_STRING(decimal)); + assert(new_length <= decimal_length); + res = _PyBytes_Resize(&decimal, new_length); + if (res < 0) + return NULL; + + return decimal; +} + +static PyObject * +unicode_transformdecimaltoascii(PyObject *self, PyObject *args) +{ + Py_UNICODE *unicode; + Py_ssize_t length; + if (!PyArg_ParseTuple(args, "u#|s", &unicode, &length)) + return NULL; + return PyUnicode_TransformDecimalToASCII(unicode, length); +} + +static PyObject * getargs_w_star(PyObject *self, PyObject *args) { Py_buffer buffer; @@ -2384,8 +2429,10 @@ static PyMethodDef TestMethods[] = { {"test_u_code", (PyCFunction)test_u_code, METH_NOARGS}, {"test_Z_code", (PyCFunction)test_Z_code, METH_NOARGS}, {"test_widechar", (PyCFunction)test_widechar, METH_NOARGS}, - {"unicode_aswidechar", unicode_aswidechar, METH_VARARGS}, - {"unicode_aswidecharstring",unicode_aswidecharstring, METH_VARARGS}, + {"unicode_aswidechar", unicode_aswidechar, METH_VARARGS}, + {"unicode_aswidecharstring",unicode_aswidecharstring, METH_VARARGS}, + {"unicode_encodedecimal", unicode_encodedecimal, METH_VARARGS}, + {"unicode_transformdecimaltoascii", unicode_transformdecimaltoascii, METH_VARARGS}, #ifdef WITH_THREAD {"_test_thread_state", test_thread_state, METH_VARARGS}, {"_pending_threadfunc", pending_threadfunc, METH_VARARGS}, |