OSDN Git Service

am 6826387e: DO NOT MERGE: Clear cached locations when location providers disabled...
authorDavid Christie <dnchrist@google.com>
Fri, 10 Jan 2014 20:55:24 +0000 (12:55 -0800)
committerAndroid Git Automerger <android-git-automerger@android.com>
Fri, 10 Jan 2014 20:55:24 +0000 (12:55 -0800)
* commit '6826387e50f9f272d53ca1f725f573bbddcdf5c1':
  DO NOT MERGE: Clear cached locations when location providers disabled Bug: 12118307

services/java/com/android/server/LocationManagerService.java

index f21f826..90a4209 100644 (file)
@@ -918,6 +918,10 @@ public class LocationManagerService extends ILocationManager.Stub implements Run
             boolean shouldBeEnabled = isAllowedBySettingsLocked(name, mCurrentUserId);
             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();
                 changesMade = true;
             } else if (!isEnabled && shouldBeEnabled) {
                 updateProviderListenersLocked(name, true, mCurrentUserId);