aboutsummaryrefslogtreecommitdiffstats
path: root/java/src/com/android/inputmethod/latin/spellcheck/AndroidSpellCheckerService.java
diff options
context:
space:
mode:
authorsatok <satok@google.com>2012-09-20 12:27:14 +0900
committersatok <satok@google.com>2012-09-20 12:27:14 +0900
commitf1e13f1fb10db4152b2617093d827c66615ee16d (patch)
tree4d431d5c4a171775e0197f52f393370e77829352 /java/src/com/android/inputmethod/latin/spellcheck/AndroidSpellCheckerService.java
parent86ade47236f8aac94b7e4378c034e32805d6755b (diff)
downloadlatinime-f1e13f1fb10db4152b2617093d827c66615ee16d.tar.gz
latinime-f1e13f1fb10db4152b2617093d827c66615ee16d.tar.xz
latinime-f1e13f1fb10db4152b2617093d827c66615ee16d.zip
DO NOT MERGE: Clear cache of the user dictionary when a word is added
This is a backport of Iec2793de3fff7bf15f68f Change-Id: If16d1c48edf084d892da722fb288e467f211b08e
Diffstat (limited to 'java/src/com/android/inputmethod/latin/spellcheck/AndroidSpellCheckerService.java')
-rw-r--r--java/src/com/android/inputmethod/latin/spellcheck/AndroidSpellCheckerService.java23
1 files changed, 23 insertions, 0 deletions
diff --git a/java/src/com/android/inputmethod/latin/spellcheck/AndroidSpellCheckerService.java b/java/src/com/android/inputmethod/latin/spellcheck/AndroidSpellCheckerService.java
index 88efc5a85..ba974ff7f 100644
--- a/java/src/com/android/inputmethod/latin/spellcheck/AndroidSpellCheckerService.java
+++ b/java/src/com/android/inputmethod/latin/spellcheck/AndroidSpellCheckerService.java
@@ -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.