ioslocalizationinternationalizationmessageformatcldr

Explicit Plural string using iOS Stringsdict files


I am getting started learning iOS Stringsdict files and found some existing code on a project which used the following syntax:

<key>zero</key>
<string>You no message.</string>

As per the CLDR, zero is an invalid plural in English and we expect to use explicit plural rules (=0 when using ICU MessageFormat)

I tried to find how to use explicit plural rules in iOS Stringsdict files and could not find any way to achieve this. Can someone confirm if this is supported or not?


Example of solutions (I cannot test them but maybe someone can?)

<key>0</key>
<string>You no message.</string>

Or

<key>=0</key>
<string>You no message.</string>

Extra reference on explicit plural rules part of the CLDR implementation of ICU MessageFormat:

https://formatjs.io/guides/message-syntax/#plural-format

=value This is used to match a specific value regardless of the plural categories of the current locale.


Solution

  • Short Answer

    .stringsdict files have no way to support explicit plural rules (other than a custom Apple implementation of zero which is detailed below)

    Detailed Answer

    Normal CLDR implementation:

    If "zero" is present, the value is used for mapping the argument value zero regardless of what CLDR rule specifies for the numeric value.

    Source: Foundation Release Notes for OS X v10.9

    Custom (Apple) CLDR implementation:

    You have 0 emails.

    You can write:

    You have no emails.

    Complimentary details:

    Conclusion

    Tip #1: If you need to use Latvian, you should probably avoid using zero for negative forms, and use code instead, with strings outside of the stringsdict file

    Tip #2: Make sure that your translation process supports this behavior correctly!