From: Andrew McNamara Date: Mon, 10 Jan 2005 12:22:48 +0000 (+0000) Subject: Where a string is desired, test for PyBaseString_Type derived type, X-Git-Tag: v2.5a0~2142 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=37d2bdfa763a8dc8928d5576903d6c2d714e2201;p=thirdparty%2FPython%2Fcpython.git Where a string is desired, test for PyBaseString_Type derived type, rather than using PyString_Check/PyUnicode_Check. --- diff --git a/Modules/_csv.c b/Modules/_csv.c index ba49236defed..e7f60c178e83 100644 --- a/Modules/_csv.c +++ b/Modules/_csv.c @@ -39,6 +39,9 @@ module instead. #endif /* end 2.2 compatibility macros */ +#define IS_BASESTRING(o) \ + PyObject_TypeCheck(o, &PyBaseString_Type) + static PyObject *error_obj; /* CSV exception */ static PyObject *dialects; /* Dialect registry */ @@ -230,11 +233,7 @@ _set_str(const char *name, PyObject **target, PyObject *src, const char *dflt) else { if (src == Py_None) *target = NULL; - else if (!PyString_Check(src) -#ifdef Py_USING_UNICODE - && !PyUnicode_Check(src) -#endif - ) { + else if (!IS_BASESTRING(src)) { PyErr_Format(PyExc_TypeError, "\"%s\" must be an string", name); return -1; @@ -298,11 +297,7 @@ dialect_instantiate(PyObject *dialect) { Py_INCREF(dialect); /* If dialect is a string, look it up in our registry */ - if (PyString_Check(dialect) -#ifdef Py_USING_UNICODE - || PyUnicode_Check(dialect) -#endif - ) { + if (IS_BASESTRING(dialect)) { PyObject * new_dia; new_dia = get_dialect_from_registry(dialect); Py_DECREF(dialect); @@ -1372,11 +1367,7 @@ csv_register_dialect(PyObject *module, PyObject *args) if (!PyArg_UnpackTuple(args, "", 2, 2, &name_obj, &dialect_obj)) return NULL; - if (!PyString_Check(name_obj) -#ifdef Py_USING_UNICODE -&& !PyUnicode_Check(name_obj) -#endif -) { + if (!IS_BASESTRING(name_obj)) { PyErr_SetString(PyExc_TypeError, "dialect name must be a string or unicode"); return NULL;