Kaydet (Commit) d1f9942a authored tarafından Victor Stinner's avatar Victor Stinner

Issue #18408: Fix cjkcodecs decoders, add a new MBERR_EXCEPTION constant to

notify exceptions raised by the _PyUnicodeWriter API
üst 85c761d3
...@@ -130,7 +130,7 @@ static const struct dbcs_map *mapping_list; ...@@ -130,7 +130,7 @@ static const struct dbcs_map *mapping_list;
#define OUTCHAR(c) \ #define OUTCHAR(c) \
do { \ do { \
if (_PyUnicodeWriter_WriteChar(writer, (c)) < 0) \ if (_PyUnicodeWriter_WriteChar(writer, (c)) < 0) \
return MBERR_TOOSMALL; \ return MBERR_EXCEPTION; \
} while (0) } while (0)
#define OUTCHAR2(c1, c2) \ #define OUTCHAR2(c1, c2) \
...@@ -138,7 +138,7 @@ static const struct dbcs_map *mapping_list; ...@@ -138,7 +138,7 @@ static const struct dbcs_map *mapping_list;
Py_UCS4 _c1 = (c1); \ Py_UCS4 _c1 = (c1); \
Py_UCS4 _c2 = (c2); \ Py_UCS4 _c2 = (c2); \
if (_PyUnicodeWriter_Prepare(writer, 2, Py_MAX(_c1, c2)) < 0) \ if (_PyUnicodeWriter_Prepare(writer, 2, Py_MAX(_c1, c2)) < 0) \
return MBERR_TOOSMALL; \ return MBERR_EXCEPTION; \
PyUnicode_WRITE(writer->kind, writer->data, writer->pos, _c1); \ PyUnicode_WRITE(writer->kind, writer->data, writer->pos, _c1); \
PyUnicode_WRITE(writer->kind, writer->data, writer->pos + 1, _c2); \ PyUnicode_WRITE(writer->kind, writer->data, writer->pos + 1, _c2); \
writer->pos += 2; \ writer->pos += 2; \
......
...@@ -384,6 +384,8 @@ multibytecodec_decerror(MultibyteCodec *codec, ...@@ -384,6 +384,8 @@ multibytecodec_decerror(MultibyteCodec *codec,
PyErr_SetString(PyExc_RuntimeError, PyErr_SetString(PyExc_RuntimeError,
"internal codec error"); "internal codec error");
return -1; return -1;
case MBERR_EXCEPTION:
return -1;
default: default:
PyErr_SetString(PyExc_RuntimeError, PyErr_SetString(PyExc_RuntimeError,
"unknown runtime error"); "unknown runtime error");
......
...@@ -112,6 +112,7 @@ typedef struct { ...@@ -112,6 +112,7 @@ typedef struct {
#define MBERR_TOOSMALL (-1) /* insufficient output buffer space */ #define MBERR_TOOSMALL (-1) /* insufficient output buffer space */
#define MBERR_TOOFEW (-2) /* incomplete input buffer */ #define MBERR_TOOFEW (-2) /* incomplete input buffer */
#define MBERR_INTERNAL (-3) /* internal runtime error */ #define MBERR_INTERNAL (-3) /* internal runtime error */
#define MBERR_EXCEPTION (-4) /* an exception has been raised */
#define ERROR_STRICT (PyObject *)(1) #define ERROR_STRICT (PyObject *)(1)
#define ERROR_IGNORE (PyObject *)(2) #define ERROR_IGNORE (PyObject *)(2)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment