Merge "Fix issue #23581553: Ignore Battery Optimization not work for re-install app" into mnc-dr-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
6cc3735a49
@@ -242,6 +242,14 @@ public class DeviceIdleController extends SystemService
|
||||
if (Intent.ACTION_BATTERY_CHANGED.equals(intent.getAction())) {
|
||||
int plugged = intent.getIntExtra("plugged", 0);
|
||||
updateChargingLocked(plugged != 0);
|
||||
} else if (Intent.ACTION_PACKAGE_REMOVED.equals(intent.getAction())) {
|
||||
if (!intent.getBooleanExtra(Intent.EXTRA_REPLACING, false)) {
|
||||
Uri data = intent.getData();
|
||||
String ssp;
|
||||
if (data != null && (ssp=data.getSchemeSpecificPart()) != null) {
|
||||
removePowerSaveWhitelistAppInternal(ssp);
|
||||
}
|
||||
}
|
||||
} else if (ACTION_STEP_IDLE_STATE.equals(intent.getAction())) {
|
||||
synchronized (DeviceIdleController.this) {
|
||||
stepIdleStateLocked();
|
||||
@@ -912,6 +920,10 @@ public class DeviceIdleController extends SystemService
|
||||
filter.addAction(Intent.ACTION_BATTERY_CHANGED);
|
||||
filter.addAction(ACTION_STEP_IDLE_STATE);
|
||||
getContext().registerReceiver(mReceiver, filter);
|
||||
filter = new IntentFilter();
|
||||
filter.addAction(Intent.ACTION_PACKAGE_REMOVED);
|
||||
filter.addDataScheme("package");
|
||||
getContext().registerReceiver(mReceiver, filter);
|
||||
|
||||
mLocalPowerManager.setDeviceIdleWhitelist(mPowerSaveWhitelistAllAppIdArray);
|
||||
|
||||
@@ -924,7 +936,10 @@ public class DeviceIdleController extends SystemService
|
||||
public boolean addPowerSaveWhitelistAppInternal(String name) {
|
||||
synchronized (this) {
|
||||
try {
|
||||
ApplicationInfo ai = getContext().getPackageManager().getApplicationInfo(name, 0);
|
||||
ApplicationInfo ai = getContext().getPackageManager().getApplicationInfo(name,
|
||||
PackageManager.GET_UNINSTALLED_PACKAGES
|
||||
| PackageManager.GET_DISABLED_COMPONENTS
|
||||
| PackageManager.GET_DISABLED_UNTIL_USED_COMPONENTS);
|
||||
if (mPowerSaveWhitelistUserApps.put(name, UserHandle.getAppId(ai.uid)) == null) {
|
||||
reportPowerSaveWhitelistChangedLocked();
|
||||
updateWhitelistAppIdsLocked();
|
||||
@@ -1518,7 +1533,6 @@ public class DeviceIdleController extends SystemService
|
||||
} catch (IOException e) {
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private void readConfigFileLocked(XmlPullParser parser) {
|
||||
@@ -1547,7 +1561,10 @@ public class DeviceIdleController extends SystemService
|
||||
String name = parser.getAttributeValue(null, "n");
|
||||
if (name != null) {
|
||||
try {
|
||||
ApplicationInfo ai = pm.getApplicationInfo(name, 0);
|
||||
ApplicationInfo ai = pm.getApplicationInfo(name,
|
||||
PackageManager.GET_UNINSTALLED_PACKAGES
|
||||
| PackageManager.GET_DISABLED_COMPONENTS
|
||||
| PackageManager.GET_DISABLED_UNTIL_USED_COMPONENTS);
|
||||
mPowerSaveWhitelistUserApps.put(ai.packageName,
|
||||
UserHandle.getAppId(ai.uid));
|
||||
} catch (PackageManager.NameNotFoundException e) {
|
||||
|
||||
Reference in New Issue
Block a user