Opened 16 years ago
Closed 15 years ago
#7050 closed (fixed)
make-messages should be able to ignore apps that have their own locale directory
Reported by: | Italo Maia | Owned by: | Marc Garcia |
---|---|---|---|
Component: | Internationalization | Version: | dev |
Severity: | Keywords: | ||
Cc: | flosch, Jannis Leidel | Triage Stage: | Accepted |
Has patch: | yes | Needs documentation: | yes |
Needs tests: | no | Patch needs improvement: | yes |
Easy pickings: | no | UI/UX: | no |
Description
Just as the title says. I like to place my apps and apps avaiable on the net inside my project,
so, this functionality would be the most welcomed!
Attachments (2)
Change History (14)
comment:1 by , 16 years ago
comment:2 by , 16 years ago
Keywords: | make messages removed |
---|---|
Summary: | make-messages should be able to ignore projects that have their own locale → make-messages should be able to ignore apps that have their own locale directory |
Triage Stage: | Unreviewed → Accepted |
Good idea. This should be the default behaviour.
In fact, ideally, if an application has a locale/
directory and make-messages is run from the top-level project directory, the strings in that app should update the app's own locale/
directory, rather than the project's directory. That will make it easy to update all the strings under a single directory and not accidentally forget any.
comment:3 by , 16 years ago
#7916 was a duplicate and contained a patch implementing the feature described by the OP.
comment:4 by , 16 years ago
Although I'm not completely in line with Marc's thinking in #7916, it does point out one problem with the approach I suggested: updating third-party apps may not actually be possible (e.g. they're installed in a read-only directory) or not desired (because they're not our responsibility). The second case is of more concern, since it might involve writing to a file we don't want to. How to control this without making things too complicated needs some thought (or maybe we just don't worry too much, since it can always be cleaned up afterwards in both cases).
By the way, the main concern I have with the #7916 approach (update the main file unless a file exists for that language in the app) is that it seems to lead to maintenance problems down the road and is violating the separation of responsibilities. If an app says "I am doing translations", then that app should be responsible for its own translations , all those translations in one place (not having some of them in another file), and encouraging people to translate the app, rather than putting the translation into their project-level file. However, from the perspective of "I just want the strings translated", I can understand Marc's approach (i'm not saying I think it's the ideal solution, but I understand the wish to just get the thing translated). I want to think about this a bit more and will definitely keep the other patch in mind.
Anybody else with a good idea should pipe up (here or on django-i18n if it looks like it's getting complicated).
comment:5 by , 16 years ago
If I'm understanding well, what you think my second patch does, it isn't exactly like that. The patch doesn't translate missing strings from an incomplete language on a application. It just translates languages that doesn't exist in the application. Of course it would be better (more organized) to translate none or all language inside the application, but if it isn't possible or desired, then IMHO the best is including that language in the project catalog.
A "real" example could make it clearer. I install transdb application in my project as external, and transdb is translated to english and catalan but not spanish. My project will be available in english, catalan and spanish, so what I need is to translate my own code, and also translate transdb to spanish. I did it, but after some weeks transdb author hasn't updated his project with my translation. I prefer not to modify transdb code, because I update it often and I don't want conflicts (should never happen). So the best would be include as well as my own code translation, translations from transdb in spanish catalog. For cases where it's possible to add translations directly to applications (making translations reusable) the patch will work well too.
Btw, thanks ramiro, I couldn't found this one before opening new ticket.
comment:6 by , 16 years ago
Cc: | added |
---|
comment:7 by , 16 years ago
Cc: | added |
---|
comment:8 by , 15 years ago
Owner: | changed from | to
---|---|
Status: | new → assigned |
comment:9 by , 15 years ago
Has patch: | set |
---|---|
Patch needs improvement: | set |
Just uploaded patches on ticket 7916, that is a duplicate of this one.
comment:10 by , 15 years ago
Needs documentation: | set |
---|
Probably it's worth mentioning the new behavior on http://docs.djangoproject.com/en/dev/topics/i18n/#message-files
comment:11 by , 15 years ago
Note that I created a thread on django-i18n to discuss about this ticket
http://groups.google.com/group/Django-I18N/browse_thread/thread/e24ccc3bfc0c8ac3
comment:12 by , 15 years ago
Resolution: | → fixed |
---|---|
Status: | assigned → closed |
whoops, i meant apps...ignore apps.