am eead5492: am 769cecf7: Close spell-checking dictionaries in a background thread

* commit 'eead5492615f0b05ef85ca1f88d3a41ce3f8d496':
  Close spell-checking dictionaries in a background thread
This commit is contained in:
Jean Chalard 2012-06-06 21:52:46 -07:00 committed by Android Git Automerger
commit c8a120f970

View file

@ -372,6 +372,9 @@ public class AndroidSpellCheckerService extends SpellCheckerService
mUserDictionaries = Collections.synchronizedMap(new TreeMap<String, Dictionary>()); mUserDictionaries = Collections.synchronizedMap(new TreeMap<String, Dictionary>());
final Map<String, Dictionary> oldWhitelistDictionaries = mWhitelistDictionaries; final Map<String, Dictionary> oldWhitelistDictionaries = mWhitelistDictionaries;
mWhitelistDictionaries = Collections.synchronizedMap(new TreeMap<String, Dictionary>()); mWhitelistDictionaries = Collections.synchronizedMap(new TreeMap<String, Dictionary>());
new Thread("spellchecker_close_dicts") {
@Override
public void run() {
for (DictionaryPool pool : oldPools.values()) { for (DictionaryPool pool : oldPools.values()) {
pool.close(); pool.close();
} }
@ -387,13 +390,15 @@ public class AndroidSpellCheckerService extends SpellCheckerService
// or several pools, but it is shielded against multiple closing and it's // or several pools, but it is shielded against multiple closing and it's
// safe to call it several times. // safe to call it several times.
final Dictionary dictToClose = mContactsDictionary; final Dictionary dictToClose = mContactsDictionary;
// TODO: revert to the concrete type when USE_BINARY_CONTACTS_DICTIONARY is no // TODO: revert to the concrete type when USE_BINARY_CONTACTS_DICTIONARY
// longer needed // is no longer needed
mContactsDictionary = null; mContactsDictionary = null;
dictToClose.close(); dictToClose.close();
} }
} }
} }
}.start();
}
private DictionaryPool getDictionaryPool(final String locale) { private DictionaryPool getDictionaryPool(final String locale) {
DictionaryPool pool = mDictionaryPools.get(locale); DictionaryPool pool = mDictionaryPools.get(locale);