diff options
| author | 2014-09-18 15:38:33 -0700 | |
|---|---|---|
| committer | 2014-09-18 22:40:12 +0000 | |
| commit | 4767f4b3a97ce468c6ef9abf8fb06e0b8051dba1 (patch) | |
| tree | 34eec7cd9071b07c4c058b22d86c51154c4ffbbd | |
| parent | c1e1550bf489b5fafff70154232c24bc5026b7df (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.java | 7 |
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() { |