Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a0089619 authored by Raph Levien's avatar Raph Levien
Browse files

Allow soft hyphens in languages without patterns

This patch sets up an "empty" hyphenator, which it uses by default
for locales in which there is no hyphenation pattern data. This has
the effect of enabling soft hyphens (U+00AD), which were otherwise
disabled, because the "no-hyphen" code path didn't consider them.

Bug: 19605972
Change-Id: I4dcb95cee8edc48495f7c38736f5abf26fa04935
parent 9c450936
Loading
Loading
Loading
Loading
+13 −11
Original line number Diff line number Diff line
@@ -45,6 +45,8 @@ public class Hyphenator {
    @GuardedBy("sLock")
    final static HashMap<Locale, Hyphenator> sMap = new HashMap<Locale, Hyphenator>();

    final static Hyphenator sEmptyHyphenator = new Hyphenator(StaticLayout.nLoadHyphenator(""));

    final private long mNativePtr;

    private Hyphenator(long nativePtr) {
@@ -53,19 +55,19 @@ public class Hyphenator {

    public static long get(@Nullable Locale locale) {
        synchronized (sLock) {
            if (sMap.containsKey(locale)) {
            Hyphenator result = sMap.get(locale);
                return (result == null) ? 0 : result.mNativePtr;
            if (result != null) {
                return result.mNativePtr;
            }

            // TODO: Convert this a proper locale-fallback system

            // Fall back to language-only, if available
            Locale languageOnlyLocale = new Locale(locale.getLanguage());
            if (sMap.containsKey(languageOnlyLocale)) {
                Hyphenator result = sMap.get(languageOnlyLocale);
            result = sMap.get(languageOnlyLocale);
            if (result != null) {
                sMap.put(locale, result);
                return (result == null) ? 0 : result.mNativePtr;
                return result.mNativePtr;
            }

            // Fall back to script-only, if available
@@ -75,16 +77,16 @@ public class Hyphenator {
                        .setLanguage("und")
                        .setScript(script)
                        .build();
                if (sMap.containsKey(scriptOnlyLocale)) {
                    Hyphenator result = sMap.get(scriptOnlyLocale);
                result = sMap.get(scriptOnlyLocale);
                if (result != null) {
                    sMap.put(locale, result);
                    return (result == null) ? 0 : result.mNativePtr;
                    return result.mNativePtr;
                }
            }

            sMap.put(locale, null); // To remember we found nothing.
            sMap.put(locale, sEmptyHyphenator);  // To remember we found nothing.
        }
        return 0;
        return sEmptyHyphenator.mNativePtr;
    }

    private static Hyphenator loadHyphenator(String languageTag) {