/* * Copyright (C) 2017 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.dialer.smartdial.map; import android.content.Context; import android.support.annotation.VisibleForTesting; import android.support.v4.util.SimpleArrayMap; import com.android.dialer.i18n.LocaleUtils; import com.google.common.base.Optional; /** * A utility class that combines the functionality of two implementations of {@link SmartDialMap} so * that we support smart dial for dual alphabets. * *
Of the two implementations of {@link SmartDialMap}, the default one always takes precedence. * The second one is consulted only when the default one is unable to provide a valid result. * *
Note that the second implementation can be absent if it is not defined for the system's 1st
 * language preference.
 */
@SuppressWarnings("Guava")
public class CompositeSmartDialMap {
  private static final SmartDialMap DEFAULT_MAP = LatinSmartDialMap.getInstance();
  // A map in which each key is an ISO 639-2 language code and the corresponding value is a
  // SmartDialMap
  private static final SimpleArrayMap The provided character is expected to be a normalized character. See {@link
   * SmartDialMap#normalizeCharacter(char)} for details.
   */
  public static boolean isValidDialpadCharacter(Context context, char ch) {
    if (DEFAULT_MAP.isValidDialpadCharacter(ch)) {
      return true;
    }
    Optional The provided character is expected to be a normalized character. See {@link
   * SmartDialMap#normalizeCharacter(char)} for details.
   */
  public static boolean isValidDialpadAlphabeticChar(Context context, char ch) {
    if (DEFAULT_MAP.isValidDialpadAlphabeticChar(ch)) {
      return true;
    }
    Optional The provided character is expected to be a normalized character. See {@link
   * SmartDialMap#normalizeCharacter(char)} for details.
   *
   *  If the provided character can't be mapped to a key on the dialpad, return -1.
   */
  public static byte getDialpadIndex(Context context, char ch) {
    Optional The provided character is expected to be a normalized character. See {@link
   * SmartDialMap#normalizeCharacter(char)} for details.
   *
   *  If the provided character can't be mapped to a key on the dialpad, return the character.
   */
  public static char getDialpadNumericCharacter(Context context, char ch) {
    Optional If the provided character can't be mapped to a key on the dialpad, return the character.
   */
  public static char normalizeCharacter(Context context, char ch) {
    Optional