summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog4
-rw-r--r--psycopg/adapter_mxdatetime.c25
2 files changed, 16 insertions, 13 deletions
diff --git a/ChangeLog b/ChangeLog
index ae30cbd..2ad85ce 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,9 @@
2007-01-16 Federico Di Gregorio <fog@initd.org>
+ * psycopg/adapt_mxdatetime.c: fixed #137 by accessing the 'date' and
+ 'time' attributes of the mx.DateTime instance: they are always in ISO
+ format.
+
* psycopg/typecast_datetime.c: fixed problem with year > 9999.
2006-10-29 Federico Di Gregorio <fog@initd.org>
diff --git a/psycopg/adapter_mxdatetime.c b/psycopg/adapter_mxdatetime.c
index 3fcd238..f437435 100644
--- a/psycopg/adapter_mxdatetime.c
+++ b/psycopg/adapter_mxdatetime.c
@@ -43,23 +43,22 @@ static PyObject *
mxdatetime_str(mxdatetimeObject *self)
{
PyObject *str = NULL, *res = NULL;
-
+ PyObject *supa, *supb;
+
switch (self->type) {
case PSYCO_MXDATETIME_DATE:
+ str = PyObject_GetAttrString(self->wrapped, "date");
+ break;
+
case PSYCO_MXDATETIME_TIMESTAMP:
- str = PyObject_Str(self->wrapped);
-
- /* given the limitation of the mx.DateTime module that uses the same
- type for both date and timestamp values we need to do some black
- magic and make sure we're not using an adapt()ed timestamp as a
- simple date */
- if (strncmp(&(PyString_AsString(str)[11]), "00:00:00.000", 12) == 0) {
- PyObject *tmp =
- PyString_FromStringAndSize(PyString_AsString(str), 10);
- Py_DECREF(str);
- str = tmp;
- }
+ /* here we build the right ISO string from date and time */
+ supa = PyObject_GetAttrString(self->wrapped, "date");
+ supb = PyObject_GetAttrString(self->wrapped, "time");
+ str = PyString_FromFormat("%sT%s",
+ PyString_AsString(supa), PyString_AsString(supb));
+ Py_XDECREF(supa);
+ Py_XDECREF(supb);
break;
case PSYCO_MXDATETIME_TIME: