Patch by Ero Carrera to get rid of PyString in timemodule.c.

This commit is contained in:
Guido van Rossum 2007-08-24 03:51:52 +00:00
parent 28bbe4252e
commit eda12ecc5f
1 changed files with 10 additions and 3 deletions

View File

@ -377,13 +377,17 @@ time_strftime(PyObject *self, PyObject *args)
PyObject *tup = NULL;
struct tm buf;
const char *fmt;
PyObject *format;
size_t fmtlen, buflen;
char *outbuf = 0;
size_t i;
memset((void *) &buf, '\0', sizeof(buf));
if (!PyArg_ParseTuple(args, "s|O:strftime", &fmt, &tup))
/* Will always expect a unicode string to be passed as format.
Given that there's no str type anymore in py3k this seems safe.
*/
if (!PyArg_ParseTuple(args, "U|O:strftime", &format, &tup))
return NULL;
if (tup == NULL) {
@ -458,6 +462,9 @@ time_strftime(PyObject *self, PyObject *args)
return NULL;
}
/* Convert the unicode string to an ascii one */
fmt = PyUnicode_AsString(format);
fmtlen = strlen(fmt);
/* I hate these functions that presume you know how big the output
@ -535,7 +542,7 @@ time_asctime(PyObject *self, PyObject *args)
p = asctime(&buf);
if (p[24] == '\n')
p[24] = '\0';
return PyString_FromString(p);
return PyUnicode_FromString(p);
}
PyDoc_STRVAR(asctime_doc,
@ -571,7 +578,7 @@ time_ctime(PyObject *self, PyObject *args)
}
if (p[24] == '\n')
p[24] = '\0';
return PyString_FromString(p);
return PyUnicode_FromString(p);
}
PyDoc_STRVAR(ctime_doc,