]> gitweb.fperrin.net Git - Dictionary.git/commitdiff
Cache Transliterators.
authorReimar Döffinger <Reimar.Doeffinger@gmx.de>
Sat, 29 Oct 2016 20:45:32 +0000 (22:45 +0200)
committerReimar Döffinger <Reimar.Doeffinger@gmx.de>
Sat, 29 Oct 2016 20:45:32 +0000 (22:45 +0200)
Since Android is too stupid to do it by itself.
Improves performance of searching through all dictionaries
by more than 8x.

src/com/hughes/android/dictionary/engine/Index.java
src/com/hughes/android/dictionary/engine/TransliteratorManager.java

index 069cca798219be68e046be0bccd0115843c6dd92..665f42d0437e818e9c69bf2eb1151c4657c1f626 100644 (file)
@@ -106,8 +106,7 @@ public final class Index implements RAFSerializable<Index> {
      */
     public synchronized Transliterator normalizer() {
         if (normalizer == null) {
-            normalizer = Transliterator
-                    .createFromRules("", normalizerRules, Transliterator.FORWARD);
+            normalizer = TransliteratorManager.get(normalizerRules);
         }
         return normalizer;
     }
index c3bfe8ae4832f6dd1823cddd99286c0f1eb4e2f0..cc8500f695b87b70213b405808c05617ed4fc3c8 100644 (file)
@@ -14,6 +14,8 @@
 
 package com.hughes.android.dictionary.engine;
 
+import android.support.v4.util.LruCache;
+
 import com.ibm.icu.text.Transliterator;
 
 import java.util.ArrayList;
@@ -23,10 +25,20 @@ public class TransliteratorManager {
 
     private static boolean starting = false;
     private static boolean ready = false;
+    private static LruCache<String, Transliterator> cache = new LruCache<String, Transliterator>(4);
 
     // Whom to notify when we're all set up and ready to go.
     private static List<Callback> callbacks = new ArrayList<TransliteratorManager.Callback>();
 
+    public static synchronized Transliterator get(String rules) {
+        Transliterator result = cache.get(rules);
+        if (result == null) {
+            result = Transliterator.createFromRules("", rules, Transliterator.FORWARD);
+            cache.put(rules, result);
+        }
+        return result;
+    }
+
     public static synchronized boolean init(final Callback callback) {
         if (ready) {
             return true;
@@ -45,12 +57,7 @@ public class TransliteratorManager {
         @Override
         public void run() {
             System.out.println("Starting Transliterator load.");
-            final String transliterated =
-                    Transliterator
-                            .createFromRules(
-                                    "",
-                                    Language.en.getDefaultNormalizerRules(),
-                                    Transliterator.FORWARD).transliterate("Îñţérñåţîöñåļîžåţîờñ");
+            final String transliterated = get(Language.en.getDefaultNormalizerRules()).transliterate("Îñţérñåţîöñåļîžåţîờñ");
             if (!"internationalization".equals(transliterated)) {
                 System.out.println("Wrong transliteration: " + transliterated);
             }