diff options
| author | Craig Mautner <cmautner@google.com> | 2014-06-27 23:04:13 +0000 |
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2014-06-27 15:56:14 +0000 |
| commit | 97f82fda0b615cfdb72f2779d86737f2874006fb (patch) | |
| tree | 8f6b6ac0ac0fce3b38689bcaeafa8c523ca3c337 | |
| parent | eb8d1be6acad180eabde84f19196b9ecaba81353 (diff) | |
| parent | 77b04267c68b86c512937793f7ce563da55a99f3 (diff) | |
| download | frameworks_base-97f82fda0b615cfdb72f2779d86737f2874006fb.zip frameworks_base-97f82fda0b615cfdb72f2779d86737f2874006fb.tar.gz frameworks_base-97f82fda0b615cfdb72f2779d86737f2874006fb.tar.bz2 | |
Merge "Add logging to TaskPersister restore."
| -rwxr-xr-x | services/core/java/com/android/server/am/ActivityRecord.java | 3 | ||||
| -rw-r--r-- | services/core/java/com/android/server/am/TaskPersister.java | 30 |
2 files changed, 29 insertions, 4 deletions
diff --git a/services/core/java/com/android/server/am/ActivityRecord.java b/services/core/java/com/android/server/am/ActivityRecord.java index f4e9876..287ad00 100755 --- a/services/core/java/com/android/server/am/ActivityRecord.java +++ b/services/core/java/com/android/server/am/ActivityRecord.java @@ -1147,7 +1147,8 @@ final class ActivityRecord { final ActivityInfo aInfo = stackSupervisor.resolveActivity(intent, resolvedType, 0, null, null, userId); if (aInfo == null) { - throw new XmlPullParserException("restoreActivity resolver error."); + throw new XmlPullParserException("restoreActivity resolver error. Intent=" + intent + + " resolvedType=" + resolvedType); } final ActivityRecord r = new ActivityRecord(service, /*caller*/null, launchedFromUid, launchedFromPackage, intent, resolvedType, aInfo, service.getConfiguration(), diff --git a/services/core/java/com/android/server/am/TaskPersister.java b/services/core/java/com/android/server/am/TaskPersister.java index 132b244..eee7e9e 100644 --- a/services/core/java/com/android/server/am/TaskPersister.java +++ b/services/core/java/com/android/server/am/TaskPersister.java @@ -177,6 +177,23 @@ public class TaskPersister { return false; } + private String fileToString(File file) { + final String newline = System.lineSeparator(); + try { + BufferedReader reader = new BufferedReader(new FileReader(file)); + StringBuffer sb = new StringBuffer((int) file.length() * 2); + String line; + while ((line = reader.readLine()) != null) { + sb.append(line + newline); + } + reader.close(); + return sb.toString(); + } catch (IOException ioe) { + Slog.e(TAG, "Couldn't read file " + file.getName()); + return null; + } + } + ArrayList<TaskRecord> restoreTasksLocked() { final ArrayList<TaskRecord> tasks = new ArrayList<TaskRecord>(); ArraySet<Integer> recoveredTaskIds = new ArraySet<Integer>(); @@ -206,13 +223,18 @@ public class TaskPersister { if (TAG_TASK.equals(name)) { final TaskRecord task = TaskRecord.restoreFromXml(in, mStackSupervisor); - if (DEBUG) Slog.d(TAG, "restoreTasksLocked: restored task=" + task); + if (true || DEBUG) Slog.d(TAG, "restoreTasksLocked: restored task=" + + task); if (task != null) { task.isPersistable = true; + task.needsPersisting = true; tasks.add(task); final int taskId = task.taskId; recoveredTaskIds.add(taskId); mStackSupervisor.setNextTaskId(taskId); + } else { + Slog.e(TAG, "Unable to restore taskFile=" + taskFile + ": " + + fileToString(taskFile)); } } else { Slog.wtf(TAG, "restoreTasksLocked Unknown xml event=" + event + @@ -223,6 +245,7 @@ public class TaskPersister { } } catch (Exception e) { Slog.wtf(TAG, "Unable to parse " + taskFile + ". Error " + e); + Slog.e(TAG, "Failing file: " + fileToString(taskFile)); deleteFile = true; } finally { if (reader != null) { @@ -232,7 +255,7 @@ public class TaskPersister { } } if (!DEBUG && deleteFile) { - if (DEBUG) Slog.d(TAG, "Deleting file=" + taskFile.getName()); + if (true || DEBUG) Slog.d(TAG, "Deleting file=" + taskFile.getName()); taskFile.delete(); } } @@ -276,7 +299,8 @@ public class TaskPersister { continue; } if (!persistentTaskIds.contains(taskId)) { - if (DEBUG) Slog.d(TAG, "removeObsoleteFile: deleting file=" + file.getName()); + if (true || DEBUG) Slog.d(TAG, "removeObsoleteFile: deleting file=" + + file.getName()); file.delete(); } } |
