ikiwiki/doc/bugs/some_strings_are_not_intern...

48 lines
2.1 KiB
Markdown

A lot of strings in ikiwiki are hardcoded and not taken for locales resources through gettext. This is bad because ikiwiki is thus difficult to spread for non-english users.
I mean that, for instance in CGI.pm, line like:
`my @buttons=("Save Page", "Preview", "Cancel");`
should be written as
`my @buttons=(gettext("Save Page"), gettext("Preview"), gettext("Cancel"));`
> Yes, these need to be fixed. But note that the localised texts come back
> into ikiwiki and are used in various places, including plugins.
> Including, possibly, third-party plugins. So localising the buttons would
> seem to require converting from the translations back into the C locale
> when the form is posted. --[[Joey]]
>> Wouldn't it be more easy to change all calls to the corrects ones (including in plugins) ?
>> For instance in the same file (CGI.pm): `elsif ($form->submitted eq gettext("Save Page")) {`.
>> That way no conversion to the C locale is needed.
>> gettext use should just be publicized in documentation (at least in [[plugins/write]]). --[[bbb]]
>>> It would be easy, but it could break third-party plugins that hardcode
>>> the english strings. It's also probably less efficient to run gettext
>>> over and over. --[[Joey]]
In standards templates things seems wrongly written too. For instance in page.tmpl line like:
`<li><a href="<TMPL_VAR EDITURL>" rel="nofollow">Edit</a></li>`
should be written as
`<li><a href="<TMPL_VAR EDITURL>" rel="nofollow"><TMPL_VAR EDITURL_TEXT</a></li>`
with EDITURL_TEXT variable initialized in Render.pm through a gettext call.
Am I wrong ?
> No, that's not a sane way to localise the templates. The templates can be
> translated by making a copy and modifying it, or by using a tool to
> generate .mo files from the templates, and generate translated templates
> from .po files. (See [[todo/l10n]] for one attempt.) But pushing the
> localisation of random strings in the templates through the ikiwiki
> program defeats the purpose of having templates at all. --[[Joey]]
If not I can spend some time preparing patches for such corrections if it can help.
-- [[/users/bbb]]