summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Craig Mautner <cmautner@google.com> 2014-09-18 15:38:33 -0700
committer Craig Mautner <cmautner@google.com> 2014-09-18 22:40:12 +0000
commit4767f4b3a97ce468c6ef9abf8fb06e0b8051dba1 (patch)
tree34eec7cd9071b07c4c058b22d86c51154c4ffbbd
parentc1e1550bf489b5fafff70154232c24bc5026b7df (diff)
Don't count finishing activities as effective activities.
They were being counted as effectiveRoot even though they were finishing. Fixes bug 17550936. Change-Id: Iaf7201e6150095e55f88344e4b257e4ae8f19a2b
-rw-r--r--services/core/java/com/android/server/am/TaskRecord.java7
1 files changed, 4 insertions, 3 deletions
diff --git a/services/core/java/com/android/server/am/TaskRecord.java b/services/core/java/com/android/server/am/TaskRecord.java
index 4de73675db02..b8c29a0c0b88 100644
--- a/services/core/java/com/android/server/am/TaskRecord.java
+++ b/services/core/java/com/android/server/am/TaskRecord.java
@@ -784,18 +784,19 @@ final class TaskRecord {
}
int findEffectiveRootIndex() {
- int activityNdx;
+ int effectiveNdx = 0;
final int topActivityNdx = mActivities.size() - 1;
- for (activityNdx = 0; activityNdx < topActivityNdx; ++activityNdx) {
+ for (int activityNdx = 0; activityNdx < topActivityNdx; ++activityNdx) {
final ActivityRecord r = mActivities.get(activityNdx);
if (r.finishing) {
continue;
}
+ effectiveNdx = activityNdx;
if ((r.info.flags & ActivityInfo.FLAG_RELINQUISH_TASK_IDENTITY) == 0) {
break;
}
}
- return activityNdx;
+ return effectiveNdx;
}
void updateEffectiveIntent() {