summaryrefslogtreecommitdiffstats
path: root/services/java
diff options
context:
space:
mode:
authorDavid Christie <dnchrist@google.com>2013-12-18 14:33:57 -0800
committerdcashman <dcashman@google.com>2014-01-06 15:23:39 -0800
commit75c55f92f5ca00ced05b6778389454ae50beed61 (patch)
tree699d0da078d64ebcbc98ed3c789e9f558f9b0068 /services/java
parent76e5ca81b3ba5a4f52126f2ec8907679b4356292 (diff)
downloadframeworks_base-75c55f92f5ca00ced05b6778389454ae50beed61.zip
frameworks_base-75c55f92f5ca00ced05b6778389454ae50beed61.tar.gz
frameworks_base-75c55f92f5ca00ced05b6778389454ae50beed61.tar.bz2
Clear cached locations when location providers disabled
Bug: 12118307 (cherry picked from commit b084fef18ee1b5d24d15cff37dc3a053933d361e) Change-Id: I49eff73f89633052a2587112cdc381ae6d254bfe
Diffstat (limited to 'services/java')
-rw-r--r--services/java/com/android/server/LocationManagerService.java5
1 files changed, 5 insertions, 0 deletions
diff --git a/services/java/com/android/server/LocationManagerService.java b/services/java/com/android/server/LocationManagerService.java
index 8f480dd..eebd1c5 100644
--- a/services/java/com/android/server/LocationManagerService.java
+++ b/services/java/com/android/server/LocationManagerService.java
@@ -1148,6 +1148,11 @@ public class LocationManagerService extends ILocationManager.Stub {
boolean shouldBeEnabled = isAllowedByCurrentUserSettingsLocked(name);
if (isEnabled && !shouldBeEnabled) {
updateProviderListenersLocked(name, false, mCurrentUserId);
+ // 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.
+ mLastLocation.clear();
+ mLastLocationCoarseInterval.clear();
changesMade = true;
} else if (!isEnabled && shouldBeEnabled) {
updateProviderListenersLocked(name, true, mCurrentUserId);