diff options
author | Jorim Jaggi <jjaggi@google.com> | 2015-01-14 15:16:12 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2015-01-14 15:16:12 +0000 |
commit | c1691e3f8b148bc0a986fa7d4c4bfaee56c6442c (patch) | |
tree | 5724f03d5a5b82cef54045ddf59eb60bc4238ab8 | |
parent | 2d26435f0e8a46f3653fb6f25dbfd92d90b8d80e (diff) | |
parent | 86e1788db46cdbcc65331dd8d0b9e23241a534fe (diff) | |
download | frameworks_base-c1691e3f8b148bc0a986fa7d4c4bfaee56c6442c.zip frameworks_base-c1691e3f8b148bc0a986fa7d4c4bfaee56c6442c.tar.gz frameworks_base-c1691e3f8b148bc0a986fa7d4c4bfaee56c6442c.tar.bz2 |
am 86e1788d: Merge "Only notify SIM state changes when it has actually changed" into lmp-mr1-dev
* commit '86e1788db46cdbcc65331dd8d0b9e23241a534fe':
Only notify SIM state changes when it has actually changed
-rw-r--r-- | packages/Keyguard/src/com/android/keyguard/KeyguardUpdateMonitor.java | 29 |
1 files changed, 23 insertions, 6 deletions
diff --git a/packages/Keyguard/src/com/android/keyguard/KeyguardUpdateMonitor.java b/packages/Keyguard/src/com/android/keyguard/KeyguardUpdateMonitor.java index 48f2e42..64fb24b 100644 --- a/packages/Keyguard/src/com/android/keyguard/KeyguardUpdateMonitor.java +++ b/packages/Keyguard/src/com/android/keyguard/KeyguardUpdateMonitor.java @@ -274,12 +274,16 @@ public class KeyguardUpdateMonitor implements TrustManager.TrustListener { // Hack level over 9000: Because the subscription id is not yet valid when we see the // first update in handleSimStateChange, we need to force refresh all all SIM states // so the subscription id for them is consistent. + ArrayList<SubscriptionInfo> changedSubscriptions = new ArrayList<>(); for (int i = 0; i < subscriptionInfos.size(); i++) { SubscriptionInfo info = subscriptionInfos.get(i); - refreshSimState(info.getSubscriptionId(), info.getSimSlotIndex()); + boolean changed = refreshSimState(info.getSubscriptionId(), info.getSimSlotIndex()); + if (changed) { + changedSubscriptions.add(info); + } } - for (int i = 0; i < subscriptionInfos.size(); i++) { - SimData data = mSimDatas.get(mSubscriptionInfo.get(i).getSubscriptionId()); + for (int i = 0; i < changedSubscriptions.size(); i++) { + SimData data = mSimDatas.get(changedSubscriptions.get(i).getSubscriptionId()); for (int j = 0; j < mCallbacks.size(); j++) { KeyguardUpdateMonitorCallback cb = mCallbacks.get(j).get(); if (cb != null) { @@ -1242,7 +1246,10 @@ public class KeyguardUpdateMonitor implements TrustManager.TrustListener { } } - private void refreshSimState(int subId, int slotId) { + /** + * @return true if and only if the state has changed for the specified {@code slotId} + */ + private boolean refreshSimState(int subId, int slotId) { // This is awful. It exists because there are two APIs for getting the SIM status // that don't return the complete set of values and have different types. In Keyguard we @@ -1256,8 +1263,18 @@ public class KeyguardUpdateMonitor implements TrustManager.TrustListener { } catch(IllegalArgumentException ex) { Log.w(TAG, "Unknown sim state: " + simState); state = State.UNKNOWN; - } - mSimDatas.put(subId, new SimData(state, slotId, subId)); + } + SimData data = mSimDatas.get(subId); + final boolean changed; + if (data == null) { + data = new SimData(state, slotId, subId); + mSimDatas.put(subId, data); + changed = true; // no data yet; force update + } else { + changed = data.simState != state; + data.simState = state; + } + return changed; } public static boolean isSimPinSecure(IccCardConstants.State state) { |