diff options
author | Georg Brandl <georg@python.org> | 2008-07-19 12:39:10 (GMT) |
---|---|---|
committer | Georg Brandl <georg@python.org> | 2008-07-19 12:39:10 (GMT) |
commit | 6b41a8e156d7c38947a082016ffb58de8d2485ce (patch) | |
tree | 8f95264aea4275f2d6a92bc3f76fbba2ba394f3b /Modules/_localemodule.c | |
parent | 1ad108db05b86b426b636edc0814be4f8e6ba0d5 (diff) | |
download | cpython-6b41a8e156d7c38947a082016ffb58de8d2485ce.zip cpython-6b41a8e156d7c38947a082016ffb58de8d2485ce.tar.gz cpython-6b41a8e156d7c38947a082016ffb58de8d2485ce.tar.bz2 |
#3302: fix segfaults when passing None for arguments that can't
be NULL for the C functions.
Diffstat (limited to 'Modules/_localemodule.c')
-rw-r--r-- | Modules/_localemodule.c | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/Modules/_localemodule.c b/Modules/_localemodule.c index 09e04ef..09c025f 100644 --- a/Modules/_localemodule.c +++ b/Modules/_localemodule.c @@ -586,7 +586,7 @@ static PyObject* PyIntl_gettext(PyObject* self, PyObject *args) { char *in; - if (!PyArg_ParseTuple(args, "z", &in)) + if (!PyArg_ParseTuple(args, "s", &in)) return 0; return PyString_FromString(gettext(in)); } @@ -599,7 +599,7 @@ static PyObject* PyIntl_dgettext(PyObject* self, PyObject *args) { char *domain, *in; - if (!PyArg_ParseTuple(args, "zz", &domain, &in)) + if (!PyArg_ParseTuple(args, "zs", &domain, &in)) return 0; return PyString_FromString(dgettext(domain, in)); } @@ -613,7 +613,7 @@ PyIntl_dcgettext(PyObject *self, PyObject *args) { char *domain, *msgid; int category; - if (!PyArg_ParseTuple(args, "zzi", &domain, &msgid, &category)) + if (!PyArg_ParseTuple(args, "zsi", &domain, &msgid, &category)) return 0; return PyString_FromString(dcgettext(domain,msgid,category)); } @@ -643,9 +643,13 @@ PyDoc_STRVAR(bindtextdomain__doc__, static PyObject* PyIntl_bindtextdomain(PyObject* self,PyObject*args) { - char *domain,*dirname; - if (!PyArg_ParseTuple(args, "zz", &domain, &dirname)) + char *domain, *dirname; + if (!PyArg_ParseTuple(args, "sz", &domain, &dirname)) return 0; + if (!strlen(domain)) { + PyErr_SetString(Error, "domain must be a non-empty string"); + return 0; + } dirname = bindtextdomain(domain, dirname); if (!dirname) { PyErr_SetFromErrno(PyExc_OSError); |