classification
Title: support plurals in pygettext
Type: Stage: needs patch
Components: Documentation Versions: Python 2.7
process
Status: open Resolution:
Dependencies: 13447 Superseder:
Assigned To: Nosy List: eric.araujo, jhg
Priority: normal Keywords: patch

Created on 2010-04-23 01:09 by jhg, last changed 2012-01-16 16:36 by eric.araujo.

Files
File name Uploaded Description Edit
gettext.txt.patch jhg, 2010-04-23 01:09
pygettext.py.patch jhg, 2010-06-12 04:26
helloworld.py jhg, 2010-06-12 04:32
Messages (7)
msg103988 - (view) Author: jhg (jhg) Date: 2010-04-23 01:09
Wanting to figure out how to support multiple languages in my applications I read the gettext documentation and got to the part saying one should use pygettext.py to create .po files.

After copying that program from the python SVN repository I later found out that it cannot cope with plurals, i.e. ngettext(). xgettext can do that just fine. Since pygettext.py was not modified in 5 years I propose changing the documentation of gettext to encourage xgettext rather than pygettext.py.

My proposed changes are attached (edited as text file; I do not know how to convert it to a webpage and hence did not test that).
I used the 2.7b1 documentation, but the patch appears to apply just as well to the 3.1.2 documentation.
msg107559 - (view) Author: Éric Araujo (eric.araujo) * (Python committer) Date: 2010-06-11 16:36
Does the fixing of #5464 solve your problem?
msg107597 - (view) Author: jhg (jhg) Date: 2010-06-11 22:55
It looks like msgfmt.py now parses 'msgid_plural' but pygettext.py does not produce these. It is still oblivious to plurals as produced by ngettext(). My originally proposed change to the documentation was to point people to the GNU xgettext/msgfmt tools rather than the pygettext.py/msgfmt.py pair because of this limitation.

This has not changed.
msg107599 - (view) Author: Éric Araujo (eric.araujo) * (Python committer) Date: 2010-06-11 22:57
What about the more ambitious approach, fixing pygettext?
msg107625 - (view) Author: jhg (jhg) Date: 2010-06-12 04:26
Since the GNU tools work fine I had no reason to look into pygettext.py.
Now I did it anyway...

I added ngettext to the default keywords.
Any function that is keyworded and supplied more than 2 keywords is treated like ngettext.
Also simple constructs like _("foo" + 10*"bar") are now possible.

Patch attached.
msg107626 - (view) Author: jhg (jhg) Date: 2010-06-12 04:32
A simple test case for the earlier changes.

run pygettext.py and msgfmt.py and move the .mo file to 
./locale/de/LC_MESSAGES/helloworld.mo 
to see that it prints the localized strings.
msg151387 - (view) Author: Éric Araujo (eric.araujo) * (Python committer) Date: 2012-01-16 16:36
Thank you for making a patch.  I’ve been busy and could not find time to look at it, but after I add a testing machinery for scripts like pygettext I will look into this.
History
Date User Action Args
2012-01-16 16:36:44eric.araujosetassignee: docs@python ->
dependencies: + Add tests for some scripts in Tools/scripts
title: proposal: encourage xgettext rather than pygettext.py in gettext docs -> support plurals in pygettext
nosy: - georg.brandl

messages: + msg151387
stage: needs patch
2010-10-29 10:07:21adminsetassignee: georg.brandl -> docs@python
2010-06-12 04:32:47jhgsetfiles: + helloworld.py

messages: + msg107626
2010-06-12 04:26:50jhgsetfiles: + pygettext.py.patch

messages: + msg107625
2010-06-11 22:57:49eric.araujosetmessages: + msg107599
2010-06-11 22:55:26jhgsetmessages: + msg107597
2010-06-11 16:36:41eric.araujosetnosy: + eric.araujo
messages: + msg107559
2010-04-23 01:10:05jhgcreate