summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFelipe Leme <felipeal@google.com>2015-06-16 10:25:06 -0700
committerFelipe Leme <felipeal@google.com>2015-06-16 10:32:45 -0700
commit00f4a6ecbca4a0286c7f283850e1af3c424818a0 (patch)
tree6689d1aeceea543f91a3db0cf30691337b600012
parenta106554c20c72e284d64ea074933554e5dc29da9 (diff)
downloadframeworks_base-00f4a6ecbca4a0286c7f283850e1af3c424818a0.zip
frameworks_base-00f4a6ecbca4a0286c7f283850e1af3c424818a0.tar.gz
frameworks_base-00f4a6ecbca4a0286c7f283850e1af3c424818a0.tar.bz2
Improved zipping logic so it zips chunks, instead of the whole file at once, to avoid OOM.
BUG: 20447313 Change-Id: I66f90cdd2a07288f9e37a38185f1583c57cf65c8
-rw-r--r--packages/Shell/src/com/android/shell/BugreportReceiver.java28
1 files changed, 5 insertions, 23 deletions
diff --git a/packages/Shell/src/com/android/shell/BugreportReceiver.java b/packages/Shell/src/com/android/shell/BugreportReceiver.java
index d299d66..13747ed 100644
--- a/packages/Shell/src/com/android/shell/BugreportReceiver.java
+++ b/packages/Shell/src/com/android/shell/BugreportReceiver.java
@@ -37,6 +37,7 @@ import android.util.Log;
import android.util.Patterns;
import com.google.android.collect.Lists;
+import libcore.io.Streams;
import java.io.BufferedOutputStream;
import java.io.ByteArrayOutputStream;
@@ -191,20 +192,17 @@ public class BugreportReceiver extends BroadcastReceiver {
* original in case of failure).
*/
private static File zipBugreport(File bugreportFile) {
- byte[] bytes = read(bugreportFile);
- if (bytes == null) {
- // Could not read bugreport, return original.
- return bugreportFile;
- }
String bugreportPath = bugreportFile.getAbsolutePath();
String zippedPath = bugreportPath.replace(".txt", ".zip");
Log.v(TAG, "zipping " + bugreportPath + " as " + zippedPath);
File bugreportZippedFile = new File(zippedPath);
- try (ZipOutputStream zos = new ZipOutputStream(
+ try (InputStream is = new FileInputStream(bugreportFile);
+ ZipOutputStream zos = new ZipOutputStream(
new BufferedOutputStream(new FileOutputStream(bugreportZippedFile)))) {
ZipEntry entry = new ZipEntry("bugreport.txt");
zos.putNextEntry(entry);
- zos.write(bytes);
+ int totalBytes = Streams.copy(is, zos);
+ Log.v(TAG, "size of original bugreport: " + totalBytes + " bytes");
zos.closeEntry();
// Delete old file;
boolean deleted = bugreportFile.delete();
@@ -220,22 +218,6 @@ public class BugreportReceiver extends BroadcastReceiver {
}
}
- /** Returns the content of file, or {@code null} in case of error. */
- private static byte[] read(File file) {
- try (ByteArrayOutputStream output = new ByteArrayOutputStream();
- InputStream input = new FileInputStream(file)) {
- byte[] buffer = new byte[4096];
- int read = 0;
- while ((read = input.read(buffer)) != -1) {
- output.write(buffer, 0, read);
- }
- return output.toByteArray();
- } catch (IOException e) {
- Log.e(TAG, "IOException reading " + file.getAbsolutePath(), e);
- return null;
- }
- }
-
/**
* Find the best matching {@link Account} based on build properties.
*/