You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@sling.apache.org by "Konrad Windszus (JIRA)" <ji...@apache.org> on 2017/03/29 13:30:42 UTC

[jira] [Updated] (SLING-4547) JcrResourceBundle does not support multiple base names

     [ https://issues.apache.org/jira/browse/SLING-4547?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Konrad Windszus updated SLING-4547:
-----------------------------------
    Fix Version/s: i18n 2.5.10

> JcrResourceBundle does not support multiple base names
> ------------------------------------------------------
>
>                 Key: SLING-4547
>                 URL: https://issues.apache.org/jira/browse/SLING-4547
>             Project: Sling
>          Issue Type: Bug
>          Components: i18n
>    Affects Versions: i18n 2.5.8
>            Reporter: Andrei Pilets
>            Assignee: Konrad Windszus
>             Fix For: i18n 2.5.10
>
>
> The sling:basename property may be multi-valued, that is the messages of a mix:language nodes may belong to multiple base names and thus ResourceBundle instances, as stated at https://sling.apache.org/documentation/bundles/internationalization-support-i18n.html. 
> The latest codebase does not work in that way.
> JcrResourceBundle#loadPotentialLanguageRoots():
> if (baseName == null || baseName.equals(properties.get(PROP_BASENAME, ""))) {
>          paths.add(bundle.getPath());
> }
> In case if property sling:basename have multiple values, only the first base name is considered, others are skipped.
> The correct implementation would be to use properties.get(PROP_BASENAME) - method version without default value parameter, which would return array. You would need to iterate over its items and check equality.



--
This message was sent by Atlassian JIRA
(v6.3.15#6346)