]> granicus.if.org Git - python/commitdiff
Issue #14157: Fix time.strptime failing without a year on February 29th.
authorAntoine Pitrou <solipsis@pitrou.net>
Thu, 10 May 2012 18:17:46 +0000 (20:17 +0200)
committerAntoine Pitrou <solipsis@pitrou.net>
Thu, 10 May 2012 18:17:46 +0000 (20:17 +0200)
Patch by Hynek Schlawack.

Lib/_strptime.py
Lib/test/test_strptime.py
Misc/NEWS

index 0ea4c431112c439605c46df1a0f4513b450bb980..0106e914ae4d303d1e06fc0c899e77411631cb00 100644 (file)
@@ -339,7 +339,7 @@ def _strptime(data_string, format="%a %b %d %H:%M:%S %Y"):
         raise ValueError("unconverted data remains: %s" %
                           data_string[found.end():])
 
-    year = 1900
+    year = None
     month = day = 1
     hour = minute = second = fraction = 0
     tz = -1
@@ -444,6 +444,10 @@ def _strptime(data_string, format="%a %b %d %H:%M:%S %Y"):
                     else:
                         tz = value
                         break
+    if year is None and month == 2 and day == 29:
+        year = 1904  # 1904 is first leap year of 20th century
+    elif year is None:
+        year = 1900
     # If we know the week of the year and what day of that week, we can figure
     # out the Julian day of the year.
     if julian == -1 and week_of_year != -1 and weekday != -1:
index 98d759b9f1186af6a707782594dc3e568841e811..7245671a4c1c0eb40bff0fcf79cef2a1a1b0a580 100644 (file)
@@ -378,6 +378,9 @@ class StrptimeTests(unittest.TestCase):
         need_escaping = ".^$*+?{}\[]|)("
         self.assertTrue(_strptime._strptime_time(need_escaping, need_escaping))
 
+    def test_feb29_on_leap_year_without_year(self):
+        time.strptime("Feb 29", "%b %d")
+
 class Strptime12AMPMTests(unittest.TestCase):
     """Test a _strptime regression in '%I %p' at 12 noon (12 PM)"""
 
index c4901b02a78cc0f8a08c7f963f73ebf2c6283465..42fc741933053ef42c00cc9733ac1e4c7d5dfbab 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -63,6 +63,9 @@ Core and Builtins
 Library
 -------
 
+- Issue #14157: Fix time.strptime failing without a year on February 29th.
+  Patch by Hynek Schlawack.
+
 - Issue #14768: os.path.expanduser('~/a') doesn't works correctly when HOME is '/'.
 
 - Issue #14741: Fix missing support for Ellipsis ('...') in parser module.