mirror of
https://github.com/python/cpython.git
synced 2025-07-24 11:44:31 +00:00
bpo-33812: Corrected astimezone for naive datetimes. (GH-7578)
A datetime object d is aware if d.tzinfo is not None and d.tzinfo.utcoffset(d) does not return None. If d.tzinfo is None, or if d.tzinfo is not None but d.tzinfo.utcoffset(d) returns None, d is naive. This commit ensures that instances with non-None d.tzinfo, but d.tzinfo.utcoffset(d) returning None are treated as naive. In addition, C acceleration code will raise TypeError if d.tzinfo.utcoffset(d) returns an object with the type other than timedelta. * Updated the documentation. Assume that the term "naive" is defined elsewhere and remove the not entirely correct clarification. Thanks, Tim.
This commit is contained in:
parent
af4b0130d4
commit
877b23202b
5 changed files with 36 additions and 14 deletions
|
@ -5576,6 +5576,7 @@ datetime_astimezone(PyDateTime_DateTime *self, PyObject *args, PyObject *kw)
|
|||
return NULL;
|
||||
|
||||
if (!HASTZINFO(self) || self->tzinfo == Py_None) {
|
||||
naive:
|
||||
self_tzinfo = local_timezone_from_local(self);
|
||||
if (self_tzinfo == NULL)
|
||||
return NULL;
|
||||
|
@ -5596,6 +5597,16 @@ datetime_astimezone(PyDateTime_DateTime *self, PyObject *args, PyObject *kw)
|
|||
Py_DECREF(self_tzinfo);
|
||||
if (offset == NULL)
|
||||
return NULL;
|
||||
else if(offset == Py_None) {
|
||||
Py_DECREF(offset);
|
||||
goto naive;
|
||||
}
|
||||
else if (!PyDelta_Check(offset)) {
|
||||
Py_DECREF(offset);
|
||||
PyErr_Format(PyExc_TypeError, "utcoffset() returned %.200s,"
|
||||
" expected timedelta or None", Py_TYPE(offset)->tp_name);
|
||||
return NULL;
|
||||
}
|
||||
/* result = self - offset */
|
||||
result = (PyDateTime_DateTime *)add_datetime_timedelta(self,
|
||||
(PyDateTime_Delta *)offset, -1);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue