am 96f0ae5e: [ML6] Have asyncReloadMainDictionary support multiple locales

* commit '96f0ae5e68a865d390e3623eebe0fda30c3a62a8':
  [ML6] Have asyncReloadMainDictionary support multiple locales
main
Jean Chalard 2014-09-11 10:44:50 +00:00 committed by Android Git Automerger
commit decce7ff27
1 changed files with 14 additions and 11 deletions

View File

@ -309,7 +309,7 @@ public class DictionaryFacilitator {
mDictionaryGroup = newDictionaryGroup; mDictionaryGroup = newDictionaryGroup;
mIsUserDictEnabled = UserBinaryDictionary.isEnabled(context); mIsUserDictEnabled = UserBinaryDictionary.isEnabled(context);
if (null == newDictionaryGroup.getDict(Dictionary.TYPE_MAIN)) { if (null == newDictionaryGroup.getDict(Dictionary.TYPE_MAIN)) {
asyncReloadMainDictionary(context, newLocaleToUse, listener); asyncReloadUninitializedMainDictionaries(context, newLocales, listener);
} }
} }
if (listener != null) { if (listener != null) {
@ -327,21 +327,24 @@ public class DictionaryFacilitator {
} }
} }
private void asyncReloadMainDictionary(final Context context, final Locale locale, private void asyncReloadUninitializedMainDictionaries(final Context context,
final DictionaryInitializationListener listener) { final Locale[] locales, final DictionaryInitializationListener listener) {
final CountDownLatch latchForWaitingLoadingMainDictionary = new CountDownLatch(1); final CountDownLatch latchForWaitingLoadingMainDictionary = new CountDownLatch(1);
mLatchForWaitingLoadingMainDictionary = latchForWaitingLoadingMainDictionary; mLatchForWaitingLoadingMainDictionary = latchForWaitingLoadingMainDictionary;
ExecutorUtils.getExecutor("InitializeBinaryDictionary").execute(new Runnable() { ExecutorUtils.getExecutor("InitializeBinaryDictionary").execute(new Runnable() {
@Override @Override
public void run() { public void run() {
final Dictionary mainDict = for (final Locale locale : locales) {
DictionaryFactory.createMainDictionaryFromManager(context, locale); final DictionaryGroup dictionaryGroup = mDictionaryGroup;
synchronized (mLock) { final Dictionary mainDict =
if (locale.equals(mDictionaryGroup.mLocale)) { DictionaryFactory.createMainDictionaryFromManager(context, locale);
mDictionaryGroup.setMainDict(mainDict); synchronized (mLock) {
} else { if (locale.equals(dictionaryGroup.mLocale)) {
// Dictionary facilitator has been reset for another locale. dictionaryGroup.setMainDict(mainDict);
mainDict.close(); } else {
// Dictionary facilitator has been reset for another locale.
mainDict.close();
}
} }
} }
if (listener != null) { if (listener != null) {