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

Commit f5becbcd authored by satok's avatar satok Committed by Android Git Automerger
Browse files

am f1e13f1f: DO NOT MERGE: Clear cache of the user dictionary when a word is added

* commit 'f1e13f1f':
  DO NOT MERGE: Clear cache of the user dictionary when a word is added
parents 70fb1d1a f1e13f1f
Loading
Loading
Loading
Loading
+23 −0
Original line number Diff line number Diff line
@@ -16,9 +16,12 @@

package com.android.inputmethod.latin.spellcheck;

import android.content.ContentResolver;
import android.content.Intent;
import android.content.SharedPreferences;
import android.database.ContentObserver;
import android.preference.PreferenceManager;
import android.provider.UserDictionary.Words;
import android.service.textservice.SpellCheckerService;
import android.text.TextUtils;
import android.util.Log;
@@ -490,6 +493,7 @@ public class AndroidSpellCheckerService extends SpellCheckerService
        private final AndroidSpellCheckerService mService;

        private final SuggestionsCache mSuggestionsCache = new SuggestionsCache();
        private final ContentObserver mObserver;

        private static class SuggestionsParams {
            public final String[] mSuggestions;
@@ -516,10 +520,23 @@ public class AndroidSpellCheckerService extends SpellCheckerService
                }
                mUnigramSuggestionsInfoCache.put(query, new SuggestionsParams(suggestions, flags));
            }

            public void clearCache() {
                mUnigramSuggestionsInfoCache.evictAll();
            }
        }

        AndroidSpellCheckerSession(final AndroidSpellCheckerService service) {
            mService = service;
            final ContentResolver cres = service.getContentResolver();

            mObserver = new ContentObserver(null) {
                @Override
                public void onChange(boolean self) {
                    mSuggestionsCache.clearCache();
                }
            };
            cres.registerContentObserver(Words.CONTENT_URI, true, mObserver);
        }

        @Override
@@ -530,6 +547,12 @@ public class AndroidSpellCheckerService extends SpellCheckerService
            mScript = getScriptFromLocale(mLocale);
        }

        @Override
        public void onClose() {
            final ContentResolver cres = mService.getContentResolver();
            cres.unregisterContentObserver(mObserver);
        }

        /*
         * Returns whether the code point is a letter that makes sense for the specified
         * locale for this spell checker.