From 95246f2063cefa2438db90076e10b138c8cd3efc Mon Sep 17 00:00:00 2001 From: Danesh M Date: Wed, 27 Jan 2016 16:11:09 -0800 Subject: SetupWizard : Use MccTable for mcc -> locale lookup Some sims such as T-Mobile return incorrect languages for their PL(Preferred languages). Lookup the locale via the MccTable instead, and fallback to trusting the sim. Change-Id: I612d4952355ce4a42b35579e1f9aa879417c4cd4 --- .../cyanogenmod/setupwizard/setup/WelcomePage.java | 34 ++++++++++++++++++---- 1 file changed, 28 insertions(+), 6 deletions(-) (limited to 'src/com') diff --git a/src/com/cyanogenmod/setupwizard/setup/WelcomePage.java b/src/com/cyanogenmod/setupwizard/setup/WelcomePage.java index 248420e..568f8f2 100644 --- a/src/com/cyanogenmod/setupwizard/setup/WelcomePage.java +++ b/src/com/cyanogenmod/setupwizard/setup/WelcomePage.java @@ -30,6 +30,8 @@ import android.content.res.Resources; import android.os.AsyncTask; import android.os.Bundle; import android.os.Handler; +import android.telephony.SubscriptionInfo; +import android.telephony.SubscriptionManager; import android.telephony.TelephonyManager; import android.util.Log; import android.view.View; @@ -37,6 +39,7 @@ import android.widget.ArrayAdapter; import android.widget.NumberPicker; import android.widget.Toast; +import com.android.internal.telephony.MccTable; import com.cyanogenmod.setupwizard.R; import com.cyanogenmod.setupwizard.SetupWizardApp; import com.cyanogenmod.setupwizard.cmstats.SetupStats; @@ -44,6 +47,7 @@ import com.cyanogenmod.setupwizard.ui.LocalePicker; import com.cyanogenmod.setupwizard.ui.SetupPageFragment; import com.cyanogenmod.setupwizard.util.SetupWizardUtils; +import java.util.List; import java.util.Locale; public class WelcomePage extends SetupPage { @@ -285,16 +289,34 @@ public class WelcomePage extends SetupPage { private class FetchUpdateSimLocaleTask extends AsyncTask { @Override protected Locale doInBackground(Void... params) { + Locale locale = null; Activity activity = getActivity(); if (activity != null) { - TelephonyManager telephonyManager = (TelephonyManager) activity. - getSystemService(Context.TELEPHONY_SERVICE); - String locale = telephonyManager.getLocaleFromDefaultSim(); - if (locale != null) { - return Locale.forLanguageTag(locale); + final SubscriptionManager subscriptionManager = + SubscriptionManager.from(activity); + List activeSubs = + subscriptionManager.getActiveSubscriptionInfoList(); + if (activeSubs == null || activeSubs.isEmpty()) { + return null; + } + + // Fetch locale for active sim's MCC + int mcc = activeSubs.get(0).getMcc(); + locale = MccTable.getLocaleFromMcc(activity, mcc, null); + + // If that fails, fall back to preferred languages reported + // by the sim + if (locale == null) { + TelephonyManager telephonyManager = (TelephonyManager) activity. + getSystemService(Context.TELEPHONY_SERVICE); + String localeString = telephonyManager.getLocaleFromDefaultSim(); + if (localeString != null) { + locale = Locale.forLanguageTag(localeString); + + } } } - return null; + return locale; } @Override -- cgit v1.1