mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Fixed #6505 - Copy plural forms from Django translation files for newly created translation files. Thanks to Ramiro Morales for the initial patch.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@12445 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -11,6 +11,7 @@ from django.core.management.base import CommandError, BaseCommand | |||||||
| from django.utils.text import get_text_list | from django.utils.text import get_text_list | ||||||
|  |  | ||||||
| pythonize_re = re.compile(r'(?:^|\n)\s*//') | pythonize_re = re.compile(r'(?:^|\n)\s*//') | ||||||
|  | plural_forms_re = re.compile(r'^(?P<value>"Plural-Forms.+?\\n")\s*$', re.MULTILINE | re.DOTALL) | ||||||
|  |  | ||||||
| def handle_extensions(extensions=('html',)): | def handle_extensions(extensions=('html',)): | ||||||
|     """ |     """ | ||||||
| @@ -82,6 +83,37 @@ def find_files(root, ignore_patterns, verbosity, symlinks=False): | |||||||
|     all_files.sort() |     all_files.sort() | ||||||
|     return all_files |     return all_files | ||||||
|  |  | ||||||
|  | def copy_plural_forms(msgs, locale, domain, verbosity): | ||||||
|  |     """ | ||||||
|  |     Copies plural forms header contents from a Django catalog of locale to | ||||||
|  |     the msgs string, inserting it at the right place. msgs should be the | ||||||
|  |     contents of a newly created .po file. | ||||||
|  |     """ | ||||||
|  |     import django | ||||||
|  |     django_dir = os.path.normpath(os.path.join(os.path.dirname(django.__file__))) | ||||||
|  |     if domain == 'djangojs': | ||||||
|  |         domains = ('djangojs', 'django') | ||||||
|  |     else: | ||||||
|  |         domains = ('django',) | ||||||
|  |     for domain in domains: | ||||||
|  |         django_po = os.path.join(django_dir, 'conf', 'locale', locale, 'LC_MESSAGES', '%s.po' % domain) | ||||||
|  |         if os.path.exists(django_po): | ||||||
|  |             m = plural_forms_re.search(open(django_po, 'rU').read()) | ||||||
|  |             if m: | ||||||
|  |                 if verbosity > 1: | ||||||
|  |                     sys.stderr.write("copying plural forms: %s\n" % m.group('value')) | ||||||
|  |                 lines = [] | ||||||
|  |                 seen = False | ||||||
|  |                 for line in msgs.split('\n'): | ||||||
|  |                     if not line and not seen: | ||||||
|  |                         line = '%s\n' % m.group('value') | ||||||
|  |                         seen = True | ||||||
|  |                     lines.append(line) | ||||||
|  |                 msgs = '\n'.join(lines) | ||||||
|  |                 break | ||||||
|  |     return msgs | ||||||
|  |  | ||||||
|  |  | ||||||
| def make_messages(locale=None, domain='django', verbosity='1', all=False, | def make_messages(locale=None, domain='django', verbosity='1', all=False, | ||||||
|         extensions=None, symlinks=False, ignore_patterns=[]): |         extensions=None, symlinks=False, ignore_patterns=[]): | ||||||
|     """ |     """ | ||||||
| @@ -97,8 +129,10 @@ def make_messages(locale=None, domain='django', verbosity='1', all=False, | |||||||
|  |  | ||||||
|     from django.utils.translation import templatize |     from django.utils.translation import templatize | ||||||
|  |  | ||||||
|  |     invoked_for_django = False | ||||||
|     if os.path.isdir(os.path.join('conf', 'locale')): |     if os.path.isdir(os.path.join('conf', 'locale')): | ||||||
|         localedir = os.path.abspath(os.path.join('conf', 'locale')) |         localedir = os.path.abspath(os.path.join('conf', 'locale')) | ||||||
|  |         invoked_for_django = True | ||||||
|     elif os.path.isdir('locale'): |     elif os.path.isdir('locale'): | ||||||
|         localedir = os.path.abspath('locale') |         localedir = os.path.abspath('locale') | ||||||
|     else: |     else: | ||||||
| @@ -208,6 +242,8 @@ def make_messages(locale=None, domain='django', verbosity='1', all=False, | |||||||
|                 msgs, errors = _popen('msgmerge -q "%s" "%s"' % (pofile, potfile)) |                 msgs, errors = _popen('msgmerge -q "%s" "%s"' % (pofile, potfile)) | ||||||
|                 if errors: |                 if errors: | ||||||
|                     raise CommandError("errors happened while running msgmerge\n%s" % errors) |                     raise CommandError("errors happened while running msgmerge\n%s" % errors) | ||||||
|  |             elif not invoked_for_django: | ||||||
|  |                 msgs = copy_plural_forms(msgs, locale, domain, verbosity) | ||||||
|             open(pofile, 'wb').write(msgs) |             open(pofile, 'wb').write(msgs) | ||||||
|             os.unlink(potfile) |             os.unlink(potfile) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,6 +8,8 @@ LOCALE='de' | |||||||
|  |  | ||||||
| class ExtractorTests(TestCase): | class ExtractorTests(TestCase): | ||||||
|  |  | ||||||
|  |     PO_FILE='locale/%s/LC_MESSAGES/django.po' % LOCALE | ||||||
|  |  | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
|         self._cwd = os.getcwd() |         self._cwd = os.getcwd() | ||||||
|         self.test_dir = os.path.abspath(os.path.dirname(__file__)) |         self.test_dir = os.path.abspath(os.path.dirname(__file__)) | ||||||
| @@ -47,8 +49,6 @@ class JavascriptExtractorTests(ExtractorTests): | |||||||
|  |  | ||||||
| class IgnoredExtractorTests(ExtractorTests): | class IgnoredExtractorTests(ExtractorTests): | ||||||
|  |  | ||||||
|     PO_FILE='locale/%s/LC_MESSAGES/django.po' % LOCALE |  | ||||||
|  |  | ||||||
|     def test_ignore_option(self): |     def test_ignore_option(self): | ||||||
|         os.chdir(self.test_dir) |         os.chdir(self.test_dir) | ||||||
|         management.call_command('makemessages', locale=LOCALE, verbosity=0, ignore_patterns=['ignore_dir/*']) |         management.call_command('makemessages', locale=LOCALE, verbosity=0, ignore_patterns=['ignore_dir/*']) | ||||||
| @@ -60,8 +60,6 @@ class IgnoredExtractorTests(ExtractorTests): | |||||||
|  |  | ||||||
| class SymlinkExtractorTests(ExtractorTests): | class SymlinkExtractorTests(ExtractorTests): | ||||||
|  |  | ||||||
|     PO_FILE='locale/%s/LC_MESSAGES/django.po' % LOCALE |  | ||||||
|  |  | ||||||
|     def setUp(self): |     def setUp(self): | ||||||
|         self._cwd = os.getcwd() |         self._cwd = os.getcwd() | ||||||
|         self.test_dir = os.path.abspath(os.path.dirname(__file__)) |         self.test_dir = os.path.abspath(os.path.dirname(__file__)) | ||||||
| @@ -88,3 +86,13 @@ class SymlinkExtractorTests(ExtractorTests): | |||||||
|             po_contents = open(self.PO_FILE, 'r').read() |             po_contents = open(self.PO_FILE, 'r').read() | ||||||
|             self.assertMsgId('This literal should be included.', po_contents) |             self.assertMsgId('This literal should be included.', po_contents) | ||||||
|             self.assert_('templates_symlinked/test.html' in po_contents) |             self.assert_('templates_symlinked/test.html' in po_contents) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class CopyPluralFormsExtractorTests(ExtractorTests): | ||||||
|  |  | ||||||
|  |     def test_copy_plural_forms(self): | ||||||
|  |         os.chdir(self.test_dir) | ||||||
|  |         management.call_command('makemessages', locale=LOCALE, verbosity=0) | ||||||
|  |         self.assert_(os.path.exists(self.PO_FILE)) | ||||||
|  |         po_contents = open(self.PO_FILE, 'r').read() | ||||||
|  |         self.assert_('Plural-Forms: nplurals=2; plural=(n != 1)' in po_contents) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user