am 1b7c1cd5: Merge "Add PersionalizationDictionaryRegister"

* commit '1b7c1cd513c53e1d1f07a328405c71509a0ecb6c':
  Add PersionalizationDictionaryRegister
This commit is contained in:
Satoshi Kataoka 2013-08-11 23:27:47 -07:00 committed by Android Git Automerger
commit 39acbaeeaa
5 changed files with 61 additions and 9 deletions

View file

@ -74,6 +74,7 @@ import com.android.inputmethod.keyboard.MainKeyboardView;
import com.android.inputmethod.latin.SuggestedWords.SuggestedWordInfo; import com.android.inputmethod.latin.SuggestedWords.SuggestedWordInfo;
import com.android.inputmethod.latin.define.ProductionFlag; import com.android.inputmethod.latin.define.ProductionFlag;
import com.android.inputmethod.latin.personalization.PersonalizationDictionaryHelper; import com.android.inputmethod.latin.personalization.PersonalizationDictionaryHelper;
import com.android.inputmethod.latin.personalization.PersonalizationDictionarySessionRegister;
import com.android.inputmethod.latin.personalization.PersonalizationPredictionDictionary; import com.android.inputmethod.latin.personalization.PersonalizationPredictionDictionary;
import com.android.inputmethod.latin.personalization.UserHistoryPredictionDictionary; import com.android.inputmethod.latin.personalization.UserHistoryPredictionDictionary;
import com.android.inputmethod.latin.settings.Settings; import com.android.inputmethod.latin.settings.Settings;
@ -470,6 +471,7 @@ public class LatinIME extends InputMethodService implements KeyboardActionListen
KeyboardSwitcher.init(this); KeyboardSwitcher.init(this);
AudioAndHapticFeedbackManager.init(this); AudioAndHapticFeedbackManager.init(this);
AccessibilityUtils.init(this); AccessibilityUtils.init(this);
PersonalizationDictionarySessionRegister.init(this);
super.onCreate(); super.onCreate();
@ -650,6 +652,7 @@ public class LatinIME extends InputMethodService implements KeyboardActionListen
mOptionsDialog.dismiss(); mOptionsDialog.dismiss();
} }
} }
PersonalizationDictionarySessionRegister.onConfigurationChanged(this, conf);
super.onConfigurationChanged(conf); super.onConfigurationChanged(conf);
} }

View file

@ -402,7 +402,11 @@ public abstract class DynamicPredictionDictionaryBase extends ExpandableDictiona
} }
public void registerUpdateSession(PersonalizationDictionaryUpdateSession session) { public void registerUpdateSession(PersonalizationDictionaryUpdateSession session) {
session.setDictionary(this); session.setPredictionDictionary(mLocale, this);
mSessions.add(session); mSessions.add(session);
} }
public void unRegisterUpdateSession(PersonalizationDictionaryUpdateSession session) {
mSessions.remove(session);
}
} }

View file

@ -59,9 +59,8 @@ public class PersonalizationDictionaryHelper {
} }
} }
public static void public static void registerPersonalizationDictionaryUpdateSession(final Context context,
registerPersonalizationDictionaryUpdateSession(final Context context, final PersonalizationDictionaryUpdateSession session) {
final PersonalizationDictionaryUpdateSession session) {
final PersonalizationPredictionDictionary dictionary = final PersonalizationPredictionDictionary dictionary =
getPersonalizationPredictionDictionary(context, getPersonalizationPredictionDictionary(context,
context.getResources().getConfiguration().locale.toString(), context.getResources().getConfiguration().locale.toString(),

View file

@ -0,0 +1,28 @@
/*
* Copyright (C) 2013 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.inputmethod.latin.personalization;
import android.content.Context;
import android.content.res.Configuration;
public class PersonalizationDictionarySessionRegister {
public static void init(Context context) {
}
public static void onConfigurationChanged(final Context context, final Configuration conf) {
}
}

View file

@ -43,18 +43,36 @@ public abstract class PersonalizationDictionaryUpdateSession {
} }
// TODO: Use a dynamic binary dictionary instead // TODO: Use a dynamic binary dictionary instead
public WeakReference<DynamicPredictionDictionaryBase> mDictionary; public WeakReference<DynamicPredictionDictionaryBase> mPredictionDictionary;
public String mLocale;
public abstract void onDictionaryReady(); public abstract void onDictionaryReady();
public void setDictionary(DynamicPredictionDictionaryBase dictionary) { public void setPredictionDictionary(String locale, DynamicPredictionDictionaryBase dictionary) {
mDictionary = new WeakReference<DynamicPredictionDictionaryBase>(dictionary); mPredictionDictionary = new WeakReference<DynamicPredictionDictionaryBase>(dictionary);
mLocale = locale;
}
protected DynamicPredictionDictionaryBase getPredictionDictionary() {
return mPredictionDictionary == null ? null : mPredictionDictionary.get();
}
private void unsetPredictionDictionary() {
final DynamicPredictionDictionaryBase dictionary = getPredictionDictionary();
if (dictionary == null) {
return;
}
dictionary.unRegisterUpdateSession(this);
}
public void closeSession() {
unsetPredictionDictionary();
} }
public void addToPersonalizationDictionary( public void addToPersonalizationDictionary(
final ArrayList<PersonalizationLanguageModelParam> lmParams) { final ArrayList<PersonalizationLanguageModelParam> lmParams) {
final DynamicPredictionDictionaryBase dictionary = mDictionary == null final DynamicPredictionDictionaryBase dictionary = getPredictionDictionary();
? null : mDictionary.get();
if (dictionary == null) { if (dictionary == null) {
return; return;
} }