DO NOT MERGE: Clear cached locations when location providers disabled

Bug: 12118307

Change-Id: Iae668409be5c5bd715681624b2a54a4daa690932
This commit is contained in:
David Christie
2014-01-06 17:57:30 -08:00
parent 50cbfd554f
commit 8e0c7768c8

View File

@ -982,6 +982,10 @@ public class LocationManagerService extends ILocationManager.Stub implements Run
boolean shouldBeEnabled = isAllowedBySettingsLocked(name);
if (isEnabled && !shouldBeEnabled) {
updateProviderListenersLocked(name, false);
// If any provider has been disabled, clear all last locations for all providers.
// This is to be on the safe side in case a provider has location derived from
// this disabled provider.
mLastKnownLocation.clear();
changesMade = true;
} else if (!isEnabled && shouldBeEnabled) {
updateProviderListenersLocked(name, true);