changeset: 95693:c969413584cf user: R David Murray date: Thu Apr 16 12:15:09 2015 -0400 files: Doc/whatsnew/3.5.rst Lib/test/test_tools/test_i18n.py Misc/ACKS Misc/NEWS Tools/i18n/pygettext.py description: #18128: use standard +NNNN timezone format in POT-Creation-Date header. Patch by Michael McFadden, with a few small style tweaks. diff -r 5612dc5e6af9 -r c969413584cf Doc/whatsnew/3.5.rst --- a/Doc/whatsnew/3.5.rst Thu Apr 16 17:29:11 2015 +0200 +++ b/Doc/whatsnew/3.5.rst Thu Apr 16 12:15:09 2015 -0400 @@ -814,6 +814,10 @@ * The :mod:`socket` module now exports the CAN_RAW_FD_FRAMES constant on linux 3.6 and greater. +* The `pygettext.py` Tool now uses the standard +NNNN format for timezones in + the POT-Creation-Date header. + + Changes in the C API -------------------- diff -r 5612dc5e6af9 -r c969413584cf Lib/test/test_tools/test_i18n.py --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/Lib/test/test_tools/test_i18n.py Thu Apr 16 12:15:09 2015 -0400 @@ -0,0 +1,68 @@ +"""Tests to cover the Tools/i18n package""" + +import os +import unittest + +from test.script_helper import assert_python_ok +from test.test_tools import toolsdir +from test.support import temp_cwd + +class Test_pygettext(unittest.TestCase): + """Tests for the pygettext.py tool""" + + script = os.path.join(toolsdir,'i18n', 'pygettext.py') + + def get_header(self, data): + """ utility: return the header of a .po file as a dictionary """ + headers = {} + for line in data.split('\n'): + if not line or line.startswith(('#', 'msgid','msgstr')): + continue + line = line.strip('"') + key, val = line.split(':',1) + headers[key] = val.strip() + return headers + + def test_header(self): + """Make sure the required fields are in the header, according to: + http://www.gnu.org/software/gettext/manual/gettext.html#Header-Entry + """ + with temp_cwd(None) as cwd: + assert_python_ok(self.script) + with open('messages.pot') as fp: + data = fp.read() + header = self.get_header(data) + + self.assertIn("Project-Id-Version", header) + self.assertIn("POT-Creation-Date", header) + self.assertIn("PO-Revision-Date", header) + self.assertIn("Last-Translator", header) + self.assertIn("Language-Team", header) + self.assertIn("MIME-Version", header) + self.assertIn("Content-Type", header) + self.assertIn("Content-Transfer-Encoding", header) + self.assertIn("Generated-By", header) + + # not clear if these should be required in POT (template) files + #self.assertIn("Report-Msgid-Bugs-To", header) + #self.assertIn("Language", header) + + #"Plural-Forms" is optional + + + def test_POT_Creation_Date(self): + """ Match the date format from xgettext for POT-Creation-Date """ + from datetime import datetime + with temp_cwd(None) as cwd: + assert_python_ok(self.script) + with open('messages.pot') as fp: + data = fp.read() + header = self.get_header(data) + creationDate = header['POT-Creation-Date'] + + # peel off the escaped newline at the end of string + if creationDate.endswith('\\n'): + creationDate = creationDate[:-len('\\n')] + + # This will raise if the date format does not exactly match. + datetime.strptime(creationDate, '%Y-%m-%d %H:%M%z') diff -r 5612dc5e6af9 -r c969413584cf Misc/ACKS --- a/Misc/ACKS Thu Apr 16 17:29:11 2015 +0200 +++ b/Misc/ACKS Thu Apr 16 12:15:09 2015 -0400 @@ -911,6 +911,7 @@ Rebecca McCreary Kirk McDonald Chris McDonough +Michael McFadden Greg McFarlane Alan McIntyre Jessica McKellar diff -r 5612dc5e6af9 -r c969413584cf Misc/NEWS --- a/Misc/NEWS Thu Apr 16 17:29:11 2015 +0200 +++ b/Misc/NEWS Thu Apr 16 12:15:09 2015 -0400 @@ -187,6 +187,9 @@ Tools/Demos ----------- +- Issue #18128: pygettext now uses standard +NNNN format in the + POT-Creation-Date header. + - Issue #23935: Argument Clinic's understanding of format units accepting bytes, bytearrays, and buffers is now consistent with both the documentation and the implementation. diff -r 5612dc5e6af9 -r c969413584cf Tools/i18n/pygettext.py --- a/Tools/i18n/pygettext.py Thu Apr 16 17:29:11 2015 +0200 +++ b/Tools/i18n/pygettext.py Thu Apr 16 12:15:09 2015 -0400 @@ -441,9 +441,7 @@ def write(self, fp): options = self.__options - timestamp = time.strftime('%Y-%m-%d %H:%M+%Z') - # The time stamp in the header doesn't have the same format as that - # generated by xgettext... + timestamp = time.strftime('%Y-%m-%d %H:%M%z') encoding = fp.encoding if fp.encoding else 'UTF-8' print(pot_header % {'time': timestamp, 'version': __version__, 'charset': encoding,