am 3727a3fd
: Merge "Clean up public helper methods of SettingsValues"
* commit '3727a3fd6137c3552dc299f60b1f1df41cb47059': Clean up public helper methods of SettingsValues
This commit is contained in:
commit
b84ca27070
9 changed files with 214 additions and 220 deletions
|
@ -36,6 +36,7 @@ import com.android.inputmethod.latin.LatinIME;
|
||||||
import com.android.inputmethod.latin.LatinImeLogger;
|
import com.android.inputmethod.latin.LatinImeLogger;
|
||||||
import com.android.inputmethod.latin.R;
|
import com.android.inputmethod.latin.R;
|
||||||
import com.android.inputmethod.latin.RichInputMethodManager;
|
import com.android.inputmethod.latin.RichInputMethodManager;
|
||||||
|
import com.android.inputmethod.latin.Settings;
|
||||||
import com.android.inputmethod.latin.SettingsValues;
|
import com.android.inputmethod.latin.SettingsValues;
|
||||||
import com.android.inputmethod.latin.SubtypeSwitcher;
|
import com.android.inputmethod.latin.SubtypeSwitcher;
|
||||||
import com.android.inputmethod.latin.WordComposer;
|
import com.android.inputmethod.latin.WordComposer;
|
||||||
|
@ -181,8 +182,8 @@ public final class KeyboardSwitcher implements KeyboardState.SwitchActions {
|
||||||
keyboardView.setKeyboard(keyboard);
|
keyboardView.setKeyboard(keyboard);
|
||||||
mCurrentInputView.setKeyboardGeometry(keyboard.mTopPadding);
|
mCurrentInputView.setKeyboardGeometry(keyboard.mTopPadding);
|
||||||
keyboardView.setKeyPreviewPopupEnabled(
|
keyboardView.setKeyPreviewPopupEnabled(
|
||||||
SettingsValues.isKeyPreviewPopupEnabled(mPrefs, mResources),
|
Settings.readKeyPreviewPopupEnabled(mPrefs, mResources),
|
||||||
SettingsValues.getKeyPreviewPopupDismissDelay(mPrefs, mResources));
|
Settings.readKeyPreviewPopupDismissDelay(mPrefs, mResources));
|
||||||
keyboardView.updateAutoCorrectionState(mIsAutoCorrectionActive);
|
keyboardView.updateAutoCorrectionState(mIsAutoCorrectionActive);
|
||||||
keyboardView.updateShortcutKey(mSubtypeSwitcher.isShortcutImeReady());
|
keyboardView.updateShortcutKey(mSubtypeSwitcher.isShortcutImeReady());
|
||||||
final boolean subtypeChanged = (oldKeyboard == null)
|
final boolean subtypeChanged = (oldKeyboard == null)
|
||||||
|
|
|
@ -400,7 +400,7 @@ public final class AdditionalSubtypeSettings extends PreferenceFragment {
|
||||||
mKeyboardLayoutSetAdapter = new KeyboardLayoutSetAdapter(context);
|
mKeyboardLayoutSetAdapter = new KeyboardLayoutSetAdapter(context);
|
||||||
|
|
||||||
final String prefSubtypes =
|
final String prefSubtypes =
|
||||||
SettingsValues.getPrefAdditionalSubtypes(mPrefs, getResources());
|
Settings.readPrefAdditionalSubtypes(mPrefs, getResources());
|
||||||
setPrefSubtypes(prefSubtypes, context);
|
setPrefSubtypes(prefSubtypes, context);
|
||||||
|
|
||||||
mIsAddingNewSubtype = (savedInstanceState != null)
|
mIsAddingNewSubtype = (savedInstanceState != null)
|
||||||
|
@ -564,19 +564,13 @@ public final class AdditionalSubtypeSettings extends PreferenceFragment {
|
||||||
@Override
|
@Override
|
||||||
public void onPause() {
|
public void onPause() {
|
||||||
super.onPause();
|
super.onPause();
|
||||||
final String oldSubtypes = SettingsValues.getPrefAdditionalSubtypes(mPrefs, getResources());
|
final String oldSubtypes = Settings.readPrefAdditionalSubtypes(mPrefs, getResources());
|
||||||
final InputMethodSubtype[] subtypes = getSubtypes();
|
final InputMethodSubtype[] subtypes = getSubtypes();
|
||||||
final String prefSubtypes = AdditionalSubtype.createPrefSubtypes(subtypes);
|
final String prefSubtypes = AdditionalSubtype.createPrefSubtypes(subtypes);
|
||||||
if (prefSubtypes.equals(oldSubtypes)) {
|
if (prefSubtypes.equals(oldSubtypes)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
Settings.writePrefAdditionalSubtypes(mPrefs, prefSubtypes);
|
||||||
final SharedPreferences.Editor editor = mPrefs.edit();
|
|
||||||
try {
|
|
||||||
editor.putString(Settings.PREF_CUSTOM_INPUT_STYLES, prefSubtypes);
|
|
||||||
} finally {
|
|
||||||
editor.apply();
|
|
||||||
}
|
|
||||||
mRichImm.setAdditionalInputMethodSubtypes(subtypes);
|
mRichImm.setAdditionalInputMethodSubtypes(subtypes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -102,7 +102,7 @@ public final class AudioAndHapticFeedbackManager {
|
||||||
sound = AudioManager.FX_KEYPRESS_STANDARD;
|
sound = AudioManager.FX_KEYPRESS_STANDARD;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
mAudioManager.playSoundEffect(sound, mSettingsValues.mFxVolume);
|
mAudioManager.playSoundEffect(sound, mSettingsValues.mKeypressSoundVolume);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1083,7 +1083,7 @@ public final class LatinIME extends InputMethodService implements KeyboardAction
|
||||||
public boolean onEvaluateFullscreenMode() {
|
public boolean onEvaluateFullscreenMode() {
|
||||||
// Reread resource value here, because this method is called by framework anytime as needed.
|
// Reread resource value here, because this method is called by framework anytime as needed.
|
||||||
final boolean isFullscreenModeAllowed =
|
final boolean isFullscreenModeAllowed =
|
||||||
SettingsValues.isFullscreenModeAllowed(getResources());
|
Settings.readUseFullscreenMode(getResources());
|
||||||
if (super.onEvaluateFullscreenMode() && isFullscreenModeAllowed) {
|
if (super.onEvaluateFullscreenMode() && isFullscreenModeAllowed) {
|
||||||
// TODO: Remove this hack. Actually we should not really assume NO_EXTRACT_UI
|
// TODO: Remove this hack. Actually we should not really assume NO_EXTRACT_UI
|
||||||
// implies NO_FULLSCREEN. However, the framework mistakenly does. i.e. NO_EXTRACT_UI
|
// implies NO_FULLSCREEN. However, the framework mistakenly does. i.e. NO_EXTRACT_UI
|
||||||
|
|
|
@ -75,7 +75,7 @@ public final class RichInputMethodManager {
|
||||||
|
|
||||||
// Initialize additional subtypes.
|
// Initialize additional subtypes.
|
||||||
SubtypeLocale.init(context);
|
SubtypeLocale.init(context);
|
||||||
final String prefAdditionalSubtypes = SettingsValues.getPrefAdditionalSubtypes(
|
final String prefAdditionalSubtypes = Settings.readPrefAdditionalSubtypes(
|
||||||
prefs, context.getResources());
|
prefs, context.getResources());
|
||||||
final InputMethodSubtype[] additionalSubtypes =
|
final InputMethodSubtype[] additionalSubtypes =
|
||||||
AdditionalSubtype.createAdditionalSubtypesArray(prefAdditionalSubtypes);
|
AdditionalSubtype.createAdditionalSubtypesArray(prefAdditionalSubtypes);
|
||||||
|
|
|
@ -23,6 +23,7 @@ import android.preference.PreferenceManager;
|
||||||
|
|
||||||
import com.android.inputmethod.latin.LocaleUtils.RunInLocale;
|
import com.android.inputmethod.latin.LocaleUtils.RunInLocale;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|
||||||
public final class Settings implements SharedPreferences.OnSharedPreferenceChangeListener {
|
public final class Settings implements SharedPreferences.OnSharedPreferenceChangeListener {
|
||||||
|
@ -66,6 +67,11 @@ public final class Settings implements SharedPreferences.OnSharedPreferenceChang
|
||||||
public static final String PREF_SELECTED_LANGUAGES = "selected_languages";
|
public static final String PREF_SELECTED_LANGUAGES = "selected_languages";
|
||||||
public static final String PREF_DEBUG_SETTINGS = "debug_settings";
|
public static final String PREF_DEBUG_SETTINGS = "debug_settings";
|
||||||
|
|
||||||
|
// This preference key is deprecated. Use {@link #PREF_SHOW_LANGUAGE_SWITCH_KEY} instead.
|
||||||
|
// This is being used only for the backward compatibility.
|
||||||
|
private static final String PREF_SUPPRESS_LANGUAGE_SWITCH_KEY =
|
||||||
|
"pref_suppress_language_switch_key";
|
||||||
|
|
||||||
private Resources mRes;
|
private Resources mRes;
|
||||||
private SharedPreferences mPrefs;
|
private SharedPreferences mPrefs;
|
||||||
private Locale mCurrentLocale;
|
private Locale mCurrentLocale;
|
||||||
|
@ -116,4 +122,94 @@ public final class Settings implements SharedPreferences.OnSharedPreferenceChang
|
||||||
public SettingsValues getCurrent() {
|
public SettingsValues getCurrent() {
|
||||||
return mSettingsValues;
|
return mSettingsValues;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Accessed from the settings interface, hence public
|
||||||
|
public static boolean readKeyPreviewPopupEnabled(final SharedPreferences prefs,
|
||||||
|
final Resources res) {
|
||||||
|
final boolean showPopupOption = res.getBoolean(
|
||||||
|
R.bool.config_enable_show_popup_on_keypress_option);
|
||||||
|
if (!showPopupOption) return res.getBoolean(R.bool.config_default_popup_preview);
|
||||||
|
return prefs.getBoolean(PREF_POPUP_ON,
|
||||||
|
res.getBoolean(R.bool.config_default_popup_preview));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static int readKeyPreviewPopupDismissDelay(final SharedPreferences prefs,
|
||||||
|
final Resources res) {
|
||||||
|
// TODO: use mKeyPreviewPopupDismissDelayRawValue instead of reading it again here.
|
||||||
|
return Integer.parseInt(prefs.getString(PREF_KEY_PREVIEW_POPUP_DISMISS_DELAY,
|
||||||
|
Integer.toString(res.getInteger(
|
||||||
|
R.integer.config_key_preview_linger_timeout))));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean readShowsLanguageSwitchKey(final SharedPreferences prefs) {
|
||||||
|
if (prefs.contains(PREF_SUPPRESS_LANGUAGE_SWITCH_KEY)) {
|
||||||
|
final boolean suppressLanguageSwitchKey = prefs.getBoolean(
|
||||||
|
PREF_SUPPRESS_LANGUAGE_SWITCH_KEY, false);
|
||||||
|
final SharedPreferences.Editor editor = prefs.edit();
|
||||||
|
editor.remove(PREF_SUPPRESS_LANGUAGE_SWITCH_KEY);
|
||||||
|
editor.putBoolean(PREF_SHOW_LANGUAGE_SWITCH_KEY, !suppressLanguageSwitchKey);
|
||||||
|
editor.apply();
|
||||||
|
}
|
||||||
|
return prefs.getBoolean(PREF_SHOW_LANGUAGE_SWITCH_KEY, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String readPrefAdditionalSubtypes(final SharedPreferences prefs,
|
||||||
|
final Resources res) {
|
||||||
|
final String predefinedPrefSubtypes = AdditionalSubtype.createPrefSubtypes(
|
||||||
|
res.getStringArray(R.array.predefined_subtypes));
|
||||||
|
return prefs.getString(PREF_CUSTOM_INPUT_STYLES, predefinedPrefSubtypes);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void writePrefAdditionalSubtypes(final SharedPreferences prefs,
|
||||||
|
final String prefSubtypes) {
|
||||||
|
prefs.edit().putString(Settings.PREF_CUSTOM_INPUT_STYLES, prefSubtypes).apply();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static float readKeypressSoundVolume(final SharedPreferences prefs,
|
||||||
|
final Resources res) {
|
||||||
|
final float volume = prefs.getFloat(PREF_KEYPRESS_SOUND_VOLUME, -1.0f);
|
||||||
|
if (volume >= 0) {
|
||||||
|
return volume;
|
||||||
|
}
|
||||||
|
return Float.parseFloat(
|
||||||
|
ResourceUtils.getDeviceOverrideValue(res, R.array.keypress_volumes));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static int readVibrationDuration(final SharedPreferences prefs,
|
||||||
|
final Resources res) {
|
||||||
|
final int ms = prefs.getInt(PREF_VIBRATION_DURATION_SETTINGS, -1);
|
||||||
|
if (ms >= 0) {
|
||||||
|
return ms;
|
||||||
|
}
|
||||||
|
return Integer.parseInt(
|
||||||
|
ResourceUtils.getDeviceOverrideValue(res, R.array.keypress_vibration_durations));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean readUsabilityStudyMode(final SharedPreferences prefs) {
|
||||||
|
// TODO: use mUsabilityStudyMode instead of reading it again here
|
||||||
|
return prefs.getBoolean(DebugSettings.PREF_USABILITY_STUDY_MODE, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static long readLastUserHistoryWriteTime(final SharedPreferences prefs,
|
||||||
|
final String locale) {
|
||||||
|
final String str = prefs.getString(PREF_LAST_USER_DICTIONARY_WRITE_TIME, "");
|
||||||
|
final HashMap<String, Long> map = LocaleUtils.localeAndTimeStrToHashMap(str);
|
||||||
|
if (map.containsKey(locale)) {
|
||||||
|
return map.get(locale);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void writeLastUserHistoryWriteTime(final SharedPreferences prefs,
|
||||||
|
final String locale) {
|
||||||
|
final String oldStr = prefs.getString(PREF_LAST_USER_DICTIONARY_WRITE_TIME, "");
|
||||||
|
final HashMap<String, Long> map = LocaleUtils.localeAndTimeStrToHashMap(oldStr);
|
||||||
|
map.put(locale, System.currentTimeMillis());
|
||||||
|
final String newStr = LocaleUtils.localeAndTimeHashMapToStr(map);
|
||||||
|
prefs.edit().putString(PREF_LAST_USER_DICTIONARY_WRITE_TIME, newStr).apply();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean readUseFullscreenMode(final Resources res) {
|
||||||
|
return res.getBoolean(R.bool.config_use_fullscreen_mode);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -145,11 +145,11 @@ public final class SettingsFragment extends InputMethodSettingsFragment
|
||||||
mKeyPreviewPopupDismissDelay.setValue(popupDismissDelayDefaultValue);
|
mKeyPreviewPopupDismissDelay.setValue(popupDismissDelayDefaultValue);
|
||||||
}
|
}
|
||||||
mKeyPreviewPopupDismissDelay.setEnabled(
|
mKeyPreviewPopupDismissDelay.setEnabled(
|
||||||
SettingsValues.isKeyPreviewPopupEnabled(prefs, res));
|
Settings.readKeyPreviewPopupEnabled(prefs, res));
|
||||||
}
|
}
|
||||||
|
|
||||||
setPreferenceEnabled(Settings.PREF_INCLUDE_OTHER_IMES_IN_LANGUAGE_SWITCH_LIST,
|
setPreferenceEnabled(Settings.PREF_INCLUDE_OTHER_IMES_IN_LANGUAGE_SWITCH_LIST,
|
||||||
SettingsValues.showsLanguageSwitchKey(prefs));
|
Settings.readShowsLanguageSwitchKey(prefs));
|
||||||
|
|
||||||
final PreferenceScreen dictionaryLink =
|
final PreferenceScreen dictionaryLink =
|
||||||
(PreferenceScreen) findPreference(Settings.PREF_CONFIGURE_DICTIONARIES_KEY);
|
(PreferenceScreen) findPreference(Settings.PREF_CONFIGURE_DICTIONARIES_KEY);
|
||||||
|
@ -180,7 +180,7 @@ public final class SettingsFragment extends InputMethodSettingsFragment
|
||||||
});
|
});
|
||||||
mKeypressVibrationDurationSettingsPref.setSummary(
|
mKeypressVibrationDurationSettingsPref.setSummary(
|
||||||
res.getString(R.string.settings_keypress_vibration_duration,
|
res.getString(R.string.settings_keypress_vibration_duration,
|
||||||
SettingsValues.getCurrentVibrationDuration(prefs, res)));
|
Settings.readVibrationDuration(prefs, res)));
|
||||||
}
|
}
|
||||||
|
|
||||||
mKeypressSoundVolumeSettingsPref =
|
mKeypressSoundVolumeSettingsPref =
|
||||||
|
@ -229,7 +229,7 @@ public final class SettingsFragment extends InputMethodSettingsFragment
|
||||||
prefs.getBoolean(Settings.PREF_POPUP_ON, true));
|
prefs.getBoolean(Settings.PREF_POPUP_ON, true));
|
||||||
} else if (key.equals(Settings.PREF_SHOW_LANGUAGE_SWITCH_KEY)) {
|
} else if (key.equals(Settings.PREF_SHOW_LANGUAGE_SWITCH_KEY)) {
|
||||||
setPreferenceEnabled(Settings.PREF_INCLUDE_OTHER_IMES_IN_LANGUAGE_SWITCH_LIST,
|
setPreferenceEnabled(Settings.PREF_INCLUDE_OTHER_IMES_IN_LANGUAGE_SWITCH_LIST,
|
||||||
SettingsValues.showsLanguageSwitchKey(prefs));
|
Settings.readShowsLanguageSwitchKey(prefs));
|
||||||
} else if (key.equals(Settings.PREF_GESTURE_INPUT)) {
|
} else if (key.equals(Settings.PREF_GESTURE_INPUT)) {
|
||||||
final boolean gestureInputEnabledByConfig = getResources().getBoolean(
|
final boolean gestureInputEnabledByConfig = getResources().getBoolean(
|
||||||
R.bool.config_gesture_input_enabled_by_build_config);
|
R.bool.config_gesture_input_enabled_by_build_config);
|
||||||
|
@ -261,7 +261,7 @@ public final class SettingsFragment extends InputMethodSettingsFragment
|
||||||
(PreferenceScreen)findPreference(Settings.PREF_CUSTOM_INPUT_STYLES);
|
(PreferenceScreen)findPreference(Settings.PREF_CUSTOM_INPUT_STYLES);
|
||||||
final SharedPreferences prefs = getPreferenceManager().getSharedPreferences();
|
final SharedPreferences prefs = getPreferenceManager().getSharedPreferences();
|
||||||
final Resources res = getResources();
|
final Resources res = getResources();
|
||||||
final String prefSubtype = SettingsValues.getPrefAdditionalSubtypes(prefs, res);
|
final String prefSubtype = Settings.readPrefAdditionalSubtypes(prefs, res);
|
||||||
final InputMethodSubtype[] subtypes =
|
final InputMethodSubtype[] subtypes =
|
||||||
AdditionalSubtype.createAdditionalSubtypesArray(prefSubtype);
|
AdditionalSubtype.createAdditionalSubtypesArray(prefSubtype);
|
||||||
final StringBuilder styles = new StringBuilder();
|
final StringBuilder styles = new StringBuilder();
|
||||||
|
@ -323,7 +323,7 @@ public final class SettingsFragment extends InputMethodSettingsFragment
|
||||||
AudioAndHapticFeedbackManager.getInstance().vibrate(ms);
|
AudioAndHapticFeedbackManager.getInstance().vibrate(ms);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
final int currentMs = SettingsValues.getCurrentVibrationDuration(sp, getResources());
|
final int currentMs = Settings.readVibrationDuration(sp, getResources());
|
||||||
final SeekBarDialog.Builder builder = new SeekBarDialog.Builder(context);
|
final SeekBarDialog.Builder builder = new SeekBarDialog.Builder(context);
|
||||||
builder.setTitle(R.string.prefs_keypress_vibration_duration_settings)
|
builder.setTitle(R.string.prefs_keypress_vibration_duration_settings)
|
||||||
.setListener(listener)
|
.setListener(listener)
|
||||||
|
@ -339,7 +339,7 @@ public final class SettingsFragment extends InputMethodSettingsFragment
|
||||||
|
|
||||||
private static int getCurrentKeyPressSoundVolumePercent(final SharedPreferences sp,
|
private static int getCurrentKeyPressSoundVolumePercent(final SharedPreferences sp,
|
||||||
final Resources res) {
|
final Resources res) {
|
||||||
return (int)(SettingsValues.getCurrentKeypressSoundVolume(sp, res) * PERCENT_FLOAT);
|
return (int)(Settings.readKeypressSoundVolume(sp, res) * PERCENT_FLOAT);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void showKeypressSoundVolumeSettingDialog() {
|
private void showKeypressSoundVolumeSettingDialog() {
|
||||||
|
|
|
@ -27,7 +27,6 @@ import com.android.inputmethod.latin.SuggestedWords.SuggestedWordInfo;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.HashMap;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* When you call the constructor of this class, you may want to change the current system locale by
|
* When you call the constructor of this class, you may want to change the current system locale by
|
||||||
|
@ -36,19 +35,6 @@ import java.util.HashMap;
|
||||||
public final class SettingsValues {
|
public final class SettingsValues {
|
||||||
private static final String TAG = SettingsValues.class.getSimpleName();
|
private static final String TAG = SettingsValues.class.getSimpleName();
|
||||||
|
|
||||||
private static final int SUGGESTION_VISIBILITY_SHOW_VALUE
|
|
||||||
= R.string.prefs_suggestion_visibility_show_value;
|
|
||||||
private static final int SUGGESTION_VISIBILITY_SHOW_ONLY_PORTRAIT_VALUE
|
|
||||||
= R.string.prefs_suggestion_visibility_show_only_portrait_value;
|
|
||||||
private static final int SUGGESTION_VISIBILITY_HIDE_VALUE
|
|
||||||
= R.string.prefs_suggestion_visibility_hide_value;
|
|
||||||
|
|
||||||
private static final int[] SUGGESTION_VISIBILITY_VALUE_ARRAY = new int[] {
|
|
||||||
SUGGESTION_VISIBILITY_SHOW_VALUE,
|
|
||||||
SUGGESTION_VISIBILITY_SHOW_ONLY_PORTRAIT_VALUE,
|
|
||||||
SUGGESTION_VISIBILITY_HIDE_VALUE
|
|
||||||
};
|
|
||||||
|
|
||||||
// From resources:
|
// From resources:
|
||||||
public final int mDelayUpdateOldSuggestions;
|
public final int mDelayUpdateOldSuggestions;
|
||||||
public final String mWeakSpaceStrippers;
|
public final String mWeakSpaceStrippers;
|
||||||
|
@ -86,7 +72,7 @@ public final class SettingsValues {
|
||||||
|
|
||||||
// Deduced settings
|
// Deduced settings
|
||||||
public final int mKeypressVibrationDuration;
|
public final int mKeypressVibrationDuration;
|
||||||
public final float mFxVolume;
|
public final float mKeypressSoundVolume;
|
||||||
public final int mKeyPreviewPopupDismissDelay;
|
public final int mKeyPreviewPopupDismissDelay;
|
||||||
private final boolean mAutoCorrectEnabled;
|
private final boolean mAutoCorrectEnabled;
|
||||||
public final float mAutoCorrectionThreshold;
|
public final float mAutoCorrectionThreshold;
|
||||||
|
@ -129,10 +115,10 @@ public final class SettingsValues {
|
||||||
|
|
||||||
// Get the settings preferences
|
// Get the settings preferences
|
||||||
mAutoCap = prefs.getBoolean(Settings.PREF_AUTO_CAP, true);
|
mAutoCap = prefs.getBoolean(Settings.PREF_AUTO_CAP, true);
|
||||||
mVibrateOn = isVibrateOn(prefs, res);
|
mVibrateOn = readVibrationEnabled(prefs, res);
|
||||||
mSoundOn = prefs.getBoolean(Settings.PREF_SOUND_ON,
|
mSoundOn = prefs.getBoolean(Settings.PREF_SOUND_ON,
|
||||||
res.getBoolean(R.bool.config_default_sound_enabled));
|
res.getBoolean(R.bool.config_default_sound_enabled));
|
||||||
mKeyPreviewPopupOn = isKeyPreviewPopupEnabled(prefs, res);
|
mKeyPreviewPopupOn = Settings.readKeyPreviewPopupEnabled(prefs, res);
|
||||||
final String voiceModeMain = res.getString(R.string.voice_mode_main);
|
final String voiceModeMain = res.getString(R.string.voice_mode_main);
|
||||||
final String voiceModeOff = res.getString(R.string.voice_mode_off);
|
final String voiceModeOff = res.getString(R.string.voice_mode_off);
|
||||||
mVoiceMode = prefs.getString(Settings.PREF_VOICE_MODE, voiceModeMain);
|
mVoiceMode = prefs.getString(Settings.PREF_VOICE_MODE, voiceModeMain);
|
||||||
|
@ -140,23 +126,23 @@ public final class SettingsValues {
|
||||||
res.getString(R.string.auto_correction_threshold_mode_index_modest));
|
res.getString(R.string.auto_correction_threshold_mode_index_modest));
|
||||||
mShowSuggestionsSetting = prefs.getString(Settings.PREF_SHOW_SUGGESTIONS_SETTING,
|
mShowSuggestionsSetting = prefs.getString(Settings.PREF_SHOW_SUGGESTIONS_SETTING,
|
||||||
res.getString(R.string.prefs_suggestion_visibility_default_value));
|
res.getString(R.string.prefs_suggestion_visibility_default_value));
|
||||||
mUsabilityStudyMode = getUsabilityStudyMode(prefs);
|
mUsabilityStudyMode = Settings.readUsabilityStudyMode(prefs);
|
||||||
mIncludesOtherImesInLanguageSwitchList = prefs.getBoolean(
|
mIncludesOtherImesInLanguageSwitchList = prefs.getBoolean(
|
||||||
Settings.PREF_INCLUDE_OTHER_IMES_IN_LANGUAGE_SWITCH_LIST, false);
|
Settings.PREF_INCLUDE_OTHER_IMES_IN_LANGUAGE_SWITCH_LIST, false);
|
||||||
mShowsLanguageSwitchKey = showsLanguageSwitchKey(prefs);
|
mShowsLanguageSwitchKey = Settings.readShowsLanguageSwitchKey(prefs);
|
||||||
mKeyPreviewPopupDismissDelayRawValue = prefs.getString(
|
mKeyPreviewPopupDismissDelayRawValue = prefs.getString(
|
||||||
Settings.PREF_KEY_PREVIEW_POPUP_DISMISS_DELAY,
|
Settings.PREF_KEY_PREVIEW_POPUP_DISMISS_DELAY,
|
||||||
Integer.toString(res.getInteger(R.integer.config_key_preview_linger_timeout)));
|
Integer.toString(res.getInteger(R.integer.config_key_preview_linger_timeout)));
|
||||||
mUseContactsDict = prefs.getBoolean(Settings.PREF_KEY_USE_CONTACTS_DICT, true);
|
mUseContactsDict = prefs.getBoolean(Settings.PREF_KEY_USE_CONTACTS_DICT, true);
|
||||||
mUseDoubleSpacePeriod = prefs.getBoolean(Settings.PREF_KEY_USE_DOUBLE_SPACE_PERIOD, true);
|
mUseDoubleSpacePeriod = prefs.getBoolean(Settings.PREF_KEY_USE_DOUBLE_SPACE_PERIOD, true);
|
||||||
mAutoCorrectEnabled = isAutoCorrectEnabled(res, mAutoCorrectionThresholdRawValue);
|
mAutoCorrectEnabled = readAutoCorrectEnabled(res, mAutoCorrectionThresholdRawValue);
|
||||||
mBigramPredictionEnabled = isBigramPredictionEnabled(prefs, res);
|
mBigramPredictionEnabled = readBigramPredictionEnabled(prefs, res);
|
||||||
|
|
||||||
// Compute other readable settings
|
// Compute other readable settings
|
||||||
mKeypressVibrationDuration = getCurrentVibrationDuration(prefs, res);
|
mKeypressVibrationDuration = Settings.readVibrationDuration(prefs, res);
|
||||||
mFxVolume = getCurrentKeypressSoundVolume(prefs, res);
|
mKeypressSoundVolume = Settings.readKeypressSoundVolume(prefs, res);
|
||||||
mKeyPreviewPopupDismissDelay = getKeyPreviewPopupDismissDelay(prefs, res);
|
mKeyPreviewPopupDismissDelay = Settings.readKeyPreviewPopupDismissDelay(prefs, res);
|
||||||
mAutoCorrectionThreshold = getAutoCorrectionThreshold(res,
|
mAutoCorrectionThreshold = readAutoCorrectionThreshold(res,
|
||||||
mAutoCorrectionThresholdRawValue);
|
mAutoCorrectionThresholdRawValue);
|
||||||
mVoiceKeyEnabled = mVoiceMode != null && !mVoiceMode.equals(voiceModeOff);
|
mVoiceKeyEnabled = mVoiceMode != null && !mVoiceMode.equals(voiceModeOff);
|
||||||
mVoiceKeyOnMain = mVoiceMode != null && mVoiceMode.equals(voiceModeMain);
|
mVoiceKeyOnMain = mVoiceMode != null && mVoiceMode.equals(voiceModeMain);
|
||||||
|
@ -171,52 +157,6 @@ public final class SettingsValues {
|
||||||
mSuggestionVisibility = createSuggestionVisibility(res);
|
mSuggestionVisibility = createSuggestionVisibility(res);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Helper functions to create member values.
|
|
||||||
private static SuggestedWords createSuggestPuncList(final String[] puncs) {
|
|
||||||
final ArrayList<SuggestedWordInfo> puncList = CollectionUtils.newArrayList();
|
|
||||||
if (puncs != null) {
|
|
||||||
for (final String puncSpec : puncs) {
|
|
||||||
puncList.add(new SuggestedWordInfo(KeySpecParser.getLabel(puncSpec),
|
|
||||||
SuggestedWordInfo.MAX_SCORE, SuggestedWordInfo.KIND_HARDCODED,
|
|
||||||
Dictionary.TYPE_HARDCODED));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return new SuggestedWords(puncList,
|
|
||||||
false /* typedWordValid */,
|
|
||||||
false /* hasAutoCorrectionCandidate */,
|
|
||||||
true /* isPunctuationSuggestions */,
|
|
||||||
false /* isObsoleteSuggestions */,
|
|
||||||
false /* isPrediction */);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static String createWordSeparators(final String weakSpaceStrippers,
|
|
||||||
final String weakSpaceSwappers, final String symbolsExcludedFromWordSeparators,
|
|
||||||
final Resources res) {
|
|
||||||
String wordSeparators = weakSpaceStrippers + weakSpaceSwappers
|
|
||||||
+ res.getString(R.string.phantom_space_promoting_symbols);
|
|
||||||
for (int i = symbolsExcludedFromWordSeparators.length() - 1; i >= 0; --i) {
|
|
||||||
wordSeparators = wordSeparators.replace(
|
|
||||||
symbolsExcludedFromWordSeparators.substring(i, i + 1), "");
|
|
||||||
}
|
|
||||||
return wordSeparators;
|
|
||||||
}
|
|
||||||
|
|
||||||
private int createSuggestionVisibility(final Resources res) {
|
|
||||||
final String suggestionVisiblityStr = mShowSuggestionsSetting;
|
|
||||||
for (int visibility : SUGGESTION_VISIBILITY_VALUE_ARRAY) {
|
|
||||||
if (suggestionVisiblityStr.equals(res.getString(visibility))) {
|
|
||||||
return visibility;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
throw new RuntimeException("Bug: visibility string is not configured correctly");
|
|
||||||
}
|
|
||||||
|
|
||||||
private static boolean isVibrateOn(final SharedPreferences prefs, final Resources res) {
|
|
||||||
final boolean hasVibrator = AudioAndHapticFeedbackManager.getInstance().hasVibrator();
|
|
||||||
return hasVibrator && prefs.getBoolean(Settings.PREF_VIBRATE_ON,
|
|
||||||
res.getBoolean(R.bool.config_default_vibration_enabled));
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isApplicationSpecifiedCompletionsOn() {
|
public boolean isApplicationSpecifiedCompletionsOn() {
|
||||||
return mInputAttributes.mApplicationSpecifiedCompletionOn;
|
return mInputAttributes.mApplicationSpecifiedCompletionOn;
|
||||||
}
|
}
|
||||||
|
@ -262,41 +202,106 @@ public final class SettingsValues {
|
||||||
return mInputAttributes.mShouldInsertSpacesAutomatically;
|
return mInputAttributes.mShouldInsertSpacesAutomatically;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean isAutoCorrectEnabled(final Resources res,
|
public boolean isVoiceKeyEnabled(final EditorInfo editorInfo) {
|
||||||
|
final boolean shortcutImeEnabled = SubtypeSwitcher.getInstance().isShortcutImeEnabled();
|
||||||
|
final int inputType = (editorInfo != null) ? editorInfo.inputType : 0;
|
||||||
|
return shortcutImeEnabled && mVoiceKeyEnabled
|
||||||
|
&& !InputTypeUtils.isPasswordInputType(inputType);
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isVoiceKeyOnMain() {
|
||||||
|
return mVoiceKeyOnMain;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isLanguageSwitchKeyEnabled() {
|
||||||
|
if (!mShowsLanguageSwitchKey) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
final RichInputMethodManager imm = RichInputMethodManager.getInstance();
|
||||||
|
if (mIncludesOtherImesInLanguageSwitchList) {
|
||||||
|
return imm.hasMultipleEnabledIMEsOrSubtypes(false /* include aux subtypes */);
|
||||||
|
} else {
|
||||||
|
return imm.hasMultipleEnabledSubtypesInThisIme(false /* include aux subtypes */);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isSameInputType(final EditorInfo editorInfo) {
|
||||||
|
return mInputAttributes.isSameInputType(editorInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Helper functions to create member values.
|
||||||
|
private static SuggestedWords createSuggestPuncList(final String[] puncs) {
|
||||||
|
final ArrayList<SuggestedWordInfo> puncList = CollectionUtils.newArrayList();
|
||||||
|
if (puncs != null) {
|
||||||
|
for (final String puncSpec : puncs) {
|
||||||
|
puncList.add(new SuggestedWordInfo(KeySpecParser.getLabel(puncSpec),
|
||||||
|
SuggestedWordInfo.MAX_SCORE, SuggestedWordInfo.KIND_HARDCODED,
|
||||||
|
Dictionary.TYPE_HARDCODED));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new SuggestedWords(puncList,
|
||||||
|
false /* typedWordValid */,
|
||||||
|
false /* hasAutoCorrectionCandidate */,
|
||||||
|
true /* isPunctuationSuggestions */,
|
||||||
|
false /* isObsoleteSuggestions */,
|
||||||
|
false /* isPrediction */);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String createWordSeparators(final String weakSpaceStrippers,
|
||||||
|
final String weakSpaceSwappers, final String symbolsExcludedFromWordSeparators,
|
||||||
|
final Resources res) {
|
||||||
|
String wordSeparators = weakSpaceStrippers + weakSpaceSwappers
|
||||||
|
+ res.getString(R.string.phantom_space_promoting_symbols);
|
||||||
|
for (int i = symbolsExcludedFromWordSeparators.length() - 1; i >= 0; --i) {
|
||||||
|
wordSeparators = wordSeparators.replace(
|
||||||
|
symbolsExcludedFromWordSeparators.substring(i, i + 1), "");
|
||||||
|
}
|
||||||
|
return wordSeparators;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final int SUGGESTION_VISIBILITY_SHOW_VALUE =
|
||||||
|
R.string.prefs_suggestion_visibility_show_value;
|
||||||
|
private static final int SUGGESTION_VISIBILITY_SHOW_ONLY_PORTRAIT_VALUE =
|
||||||
|
R.string.prefs_suggestion_visibility_show_only_portrait_value;
|
||||||
|
private static final int SUGGESTION_VISIBILITY_HIDE_VALUE =
|
||||||
|
R.string.prefs_suggestion_visibility_hide_value;
|
||||||
|
private static final int[] SUGGESTION_VISIBILITY_VALUE_ARRAY = new int[] {
|
||||||
|
SUGGESTION_VISIBILITY_SHOW_VALUE,
|
||||||
|
SUGGESTION_VISIBILITY_SHOW_ONLY_PORTRAIT_VALUE,
|
||||||
|
SUGGESTION_VISIBILITY_HIDE_VALUE
|
||||||
|
};
|
||||||
|
|
||||||
|
private int createSuggestionVisibility(final Resources res) {
|
||||||
|
final String suggestionVisiblityStr = mShowSuggestionsSetting;
|
||||||
|
for (int visibility : SUGGESTION_VISIBILITY_VALUE_ARRAY) {
|
||||||
|
if (suggestionVisiblityStr.equals(res.getString(visibility))) {
|
||||||
|
return visibility;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
throw new RuntimeException("Bug: visibility string is not configured correctly");
|
||||||
|
}
|
||||||
|
|
||||||
|
private static boolean readVibrationEnabled(final SharedPreferences prefs,
|
||||||
|
final Resources res) {
|
||||||
|
final boolean hasVibrator = AudioAndHapticFeedbackManager.getInstance().hasVibrator();
|
||||||
|
return hasVibrator && prefs.getBoolean(Settings.PREF_VIBRATE_ON,
|
||||||
|
res.getBoolean(R.bool.config_default_vibration_enabled));
|
||||||
|
}
|
||||||
|
|
||||||
|
private static boolean readAutoCorrectEnabled(final Resources res,
|
||||||
final String currentAutoCorrectionSetting) {
|
final String currentAutoCorrectionSetting) {
|
||||||
final String autoCorrectionOff = res.getString(
|
final String autoCorrectionOff = res.getString(
|
||||||
R.string.auto_correction_threshold_mode_index_off);
|
R.string.auto_correction_threshold_mode_index_off);
|
||||||
return !currentAutoCorrectionSetting.equals(autoCorrectionOff);
|
return !currentAutoCorrectionSetting.equals(autoCorrectionOff);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: Clean up and move public helper methods to Settings class.
|
private static boolean readBigramPredictionEnabled(final SharedPreferences prefs,
|
||||||
// Public to access from KeyboardSwitcher. Should it have access to some
|
|
||||||
// process-global instance instead?
|
|
||||||
public static boolean isKeyPreviewPopupEnabled(final SharedPreferences prefs,
|
|
||||||
final Resources res) {
|
|
||||||
final boolean showPopupOption = res.getBoolean(
|
|
||||||
R.bool.config_enable_show_popup_on_keypress_option);
|
|
||||||
if (!showPopupOption) return res.getBoolean(R.bool.config_default_popup_preview);
|
|
||||||
return prefs.getBoolean(Settings.PREF_POPUP_ON,
|
|
||||||
res.getBoolean(R.bool.config_default_popup_preview));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Likewise
|
|
||||||
public static int getKeyPreviewPopupDismissDelay(final SharedPreferences prefs,
|
|
||||||
final Resources res) {
|
|
||||||
// TODO: use mKeyPreviewPopupDismissDelayRawValue instead of reading it again here.
|
|
||||||
return Integer.parseInt(prefs.getString(Settings.PREF_KEY_PREVIEW_POPUP_DISMISS_DELAY,
|
|
||||||
Integer.toString(res.getInteger(
|
|
||||||
R.integer.config_key_preview_linger_timeout))));
|
|
||||||
}
|
|
||||||
|
|
||||||
private static boolean isBigramPredictionEnabled(final SharedPreferences prefs,
|
|
||||||
final Resources res) {
|
final Resources res) {
|
||||||
return prefs.getBoolean(Settings.PREF_BIGRAM_PREDICTIONS, res.getBoolean(
|
return prefs.getBoolean(Settings.PREF_BIGRAM_PREDICTIONS, res.getBoolean(
|
||||||
R.bool.config_default_next_word_prediction));
|
R.bool.config_default_next_word_prediction));
|
||||||
}
|
}
|
||||||
|
|
||||||
private static float getAutoCorrectionThreshold(final Resources res,
|
private static float readAutoCorrectionThreshold(final Resources res,
|
||||||
final String currentAutoCorrectionSetting) {
|
final String currentAutoCorrectionSetting) {
|
||||||
final String[] autoCorrectionThresholdValues = res.getStringArray(
|
final String[] autoCorrectionThresholdValues = res.getStringArray(
|
||||||
R.array.auto_correction_threshold_values);
|
R.array.auto_correction_threshold_values);
|
||||||
|
@ -318,106 +323,4 @@ public final class SettingsValues {
|
||||||
}
|
}
|
||||||
return autoCorrectionThreshold;
|
return autoCorrectionThreshold;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isVoiceKeyEnabled(final EditorInfo editorInfo) {
|
|
||||||
final boolean shortcutImeEnabled = SubtypeSwitcher.getInstance().isShortcutImeEnabled();
|
|
||||||
final int inputType = (editorInfo != null) ? editorInfo.inputType : 0;
|
|
||||||
return shortcutImeEnabled && mVoiceKeyEnabled
|
|
||||||
&& !InputTypeUtils.isPasswordInputType(inputType);
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isVoiceKeyOnMain() {
|
|
||||||
return mVoiceKeyOnMain;
|
|
||||||
}
|
|
||||||
|
|
||||||
// This preference key is deprecated. Use {@link #PREF_SHOW_LANGUAGE_SWITCH_KEY} instead.
|
|
||||||
// This is being used only for the backward compatibility.
|
|
||||||
private static final String PREF_SUPPRESS_LANGUAGE_SWITCH_KEY =
|
|
||||||
"pref_suppress_language_switch_key";
|
|
||||||
|
|
||||||
public static boolean showsLanguageSwitchKey(final SharedPreferences prefs) {
|
|
||||||
if (prefs.contains(PREF_SUPPRESS_LANGUAGE_SWITCH_KEY)) {
|
|
||||||
final boolean suppressLanguageSwitchKey = prefs.getBoolean(
|
|
||||||
PREF_SUPPRESS_LANGUAGE_SWITCH_KEY, false);
|
|
||||||
final SharedPreferences.Editor editor = prefs.edit();
|
|
||||||
editor.remove(PREF_SUPPRESS_LANGUAGE_SWITCH_KEY);
|
|
||||||
editor.putBoolean(Settings.PREF_SHOW_LANGUAGE_SWITCH_KEY, !suppressLanguageSwitchKey);
|
|
||||||
editor.apply();
|
|
||||||
}
|
|
||||||
return prefs.getBoolean(Settings.PREF_SHOW_LANGUAGE_SWITCH_KEY, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isLanguageSwitchKeyEnabled() {
|
|
||||||
if (!mShowsLanguageSwitchKey) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
final RichInputMethodManager imm = RichInputMethodManager.getInstance();
|
|
||||||
if (mIncludesOtherImesInLanguageSwitchList) {
|
|
||||||
return imm.hasMultipleEnabledIMEsOrSubtypes(false /* include aux subtypes */);
|
|
||||||
} else {
|
|
||||||
return imm.hasMultipleEnabledSubtypesInThisIme(false /* include aux subtypes */);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static boolean isFullscreenModeAllowed(final Resources res) {
|
|
||||||
return res.getBoolean(R.bool.config_use_fullscreen_mode);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getPrefAdditionalSubtypes(final SharedPreferences prefs,
|
|
||||||
final Resources res) {
|
|
||||||
final String predefinedPrefSubtypes = AdditionalSubtype.createPrefSubtypes(
|
|
||||||
res.getStringArray(R.array.predefined_subtypes));
|
|
||||||
return prefs.getString(Settings.PREF_CUSTOM_INPUT_STYLES, predefinedPrefSubtypes);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Accessed from the settings interface, hence public
|
|
||||||
public static float getCurrentKeypressSoundVolume(final SharedPreferences prefs,
|
|
||||||
final Resources res) {
|
|
||||||
final float volume = prefs.getFloat(Settings.PREF_KEYPRESS_SOUND_VOLUME, -1.0f);
|
|
||||||
if (volume >= 0) {
|
|
||||||
return volume;
|
|
||||||
}
|
|
||||||
return Float.parseFloat(
|
|
||||||
ResourceUtils.getDeviceOverrideValue(res, R.array.keypress_volumes));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Likewise
|
|
||||||
public static int getCurrentVibrationDuration(final SharedPreferences prefs,
|
|
||||||
final Resources res) {
|
|
||||||
final int ms = prefs.getInt(Settings.PREF_VIBRATION_DURATION_SETTINGS, -1);
|
|
||||||
if (ms >= 0) {
|
|
||||||
return ms;
|
|
||||||
}
|
|
||||||
return Integer.parseInt(
|
|
||||||
ResourceUtils.getDeviceOverrideValue(res, R.array.keypress_vibration_durations));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Likewise
|
|
||||||
public static boolean getUsabilityStudyMode(final SharedPreferences prefs) {
|
|
||||||
// TODO: use mUsabilityStudyMode instead of reading it again here
|
|
||||||
return prefs.getBoolean(DebugSettings.PREF_USABILITY_STUDY_MODE, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static long getLastUserHistoryWriteTime(final SharedPreferences prefs,
|
|
||||||
final String locale) {
|
|
||||||
final String str = prefs.getString(Settings.PREF_LAST_USER_DICTIONARY_WRITE_TIME, "");
|
|
||||||
final HashMap<String, Long> map = LocaleUtils.localeAndTimeStrToHashMap(str);
|
|
||||||
if (map.containsKey(locale)) {
|
|
||||||
return map.get(locale);
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void setLastUserHistoryWriteTime(final SharedPreferences prefs,
|
|
||||||
final String locale) {
|
|
||||||
final String oldStr = prefs.getString(Settings.PREF_LAST_USER_DICTIONARY_WRITE_TIME, "");
|
|
||||||
final HashMap<String, Long> map = LocaleUtils.localeAndTimeStrToHashMap(oldStr);
|
|
||||||
map.put(locale, System.currentTimeMillis());
|
|
||||||
final String newStr = LocaleUtils.localeAndTimeHashMapToStr(map);
|
|
||||||
prefs.edit().putString(Settings.PREF_LAST_USER_DICTIONARY_WRITE_TIME, newStr).apply();
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isSameInputType(final EditorInfo editorInfo) {
|
|
||||||
return mInputAttributes.isSameInputType(editorInfo);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -219,7 +219,7 @@ public final class UserHistoryDictionary extends ExpandableDictionary {
|
||||||
} catch (InterruptedException e) {
|
} catch (InterruptedException e) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
final long last = SettingsValues.getLastUserHistoryWriteTime(mPrefs, mLocale);
|
final long last = Settings.readLastUserHistoryWriteTime(mPrefs, mLocale);
|
||||||
final boolean initializing = last == 0;
|
final boolean initializing = last == 0;
|
||||||
final long now = System.currentTimeMillis();
|
final long now = System.currentTimeMillis();
|
||||||
profTotal = 0;
|
profTotal = 0;
|
||||||
|
@ -355,7 +355,7 @@ public final class UserHistoryDictionary extends ExpandableDictionary {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Save the timestamp after we finish writing the binary dictionary.
|
// Save the timestamp after we finish writing the binary dictionary.
|
||||||
SettingsValues.setLastUserHistoryWriteTime(mPrefs, mLocale);
|
Settings.writeLastUserHistoryWriteTime(mPrefs, mLocale);
|
||||||
if (PROFILE_SAVE_RESTORE) {
|
if (PROFILE_SAVE_RESTORE) {
|
||||||
final long diff = System.currentTimeMillis() - now;
|
final long diff = System.currentTimeMillis() - now;
|
||||||
Log.w(TAG, "PROF: Write User HistoryDictionary: " + mLocale + ", " + diff + "ms.");
|
Log.w(TAG, "PROF: Write User HistoryDictionary: " + mLocale + ", " + diff + "ms.");
|
||||||
|
|
Loading…
Reference in a new issue