From a127b7ad151dd1ae66d665a073e98984930c3d9d Mon Sep 17 00:00:00 2001 From: Daniel Sandler Date: Mon, 17 Jun 2013 14:25:46 -0400 Subject: New icon to dump heap information and share it. Alternatively, $ adb shell am start -n /com.android.launcher3.MemoryDumpActivity Change-Id: I8c615ec3abffaf6ad693c93bdf569550d8f97298 --- AndroidManifest.xml | 15 ++++++ proguard.flags | 4 ++ res/values/config.xml | 3 ++ res/values/strings.xml | 3 ++ src/com/android/launcher3/Launcher.java | 2 +- src/com/android/launcher3/LauncherAppState.java | 10 ++++ src/com/android/launcher3/MemoryDumpActivity.java | 66 +++++++++++++++++++++++ 7 files changed, 102 insertions(+), 1 deletion(-) create mode 100644 src/com/android/launcher3/MemoryDumpActivity.java diff --git a/AndroidManifest.xml b/AndroidManifest.xml index fa9938fde..baf6990de 100644 --- a/AndroidManifest.xml +++ b/AndroidManifest.xml @@ -110,6 +110,21 @@ android:resource="@xml/wallpaper_picker_preview" /> + + + + + + + + + 2 100 + + + true diff --git a/res/values/strings.xml b/res/values/strings.xml index f6abf68a6..b57ae7439 100644 --- a/res/values/strings.xml +++ b/res/values/strings.xml @@ -277,4 +277,7 @@ s --> + + * HPROF + diff --git a/src/com/android/launcher3/Launcher.java b/src/com/android/launcher3/Launcher.java index 7f3c4823c..0253103ea 100644 --- a/src/com/android/launcher3/Launcher.java +++ b/src/com/android/launcher3/Launcher.java @@ -1041,7 +1041,7 @@ public class Launcher extends Activity mSearchDropTargetBar.setup(this, dragController); } - if (DEBUG_MEMORY) { + if (getResources().getBoolean(R.bool.debug_memory_enabled)) { Log.v(TAG, "adding WeightWatcher"); ((FrameLayout) mLauncherView).addView(new WeightWatcher(this), new FrameLayout.LayoutParams( diff --git a/src/com/android/launcher3/LauncherAppState.java b/src/com/android/launcher3/LauncherAppState.java index fa1670c3b..e7aa3d8ea 100644 --- a/src/com/android/launcher3/LauncherAppState.java +++ b/src/com/android/launcher3/LauncherAppState.java @@ -23,9 +23,15 @@ import android.content.Intent; import android.content.IntentFilter; import android.content.res.Configuration; import android.database.ContentObserver; +import android.net.Uri; +import android.os.Debug; +import android.os.Environment; import android.os.Handler; +import java.io.File; +import java.io.IOException; import java.lang.ref.WeakReference; +import java.util.ArrayList; public class LauncherAppState { private Context mContext; @@ -61,6 +67,10 @@ public class LauncherAppState { mStarttime = System.currentTimeMillis(); + if (context.getResources().getBoolean(R.bool.debug_memory_enabled)) { + WeightWatcher.sUpdateThread.start(); + } + // set sIsScreenXLarge and sScreenDensity *before* creating icon cache sIsScreenLarge = context.getResources().getBoolean(R.bool.is_large_screen); sScreenDensity = context.getResources().getDisplayMetrics().density; diff --git a/src/com/android/launcher3/MemoryDumpActivity.java b/src/com/android/launcher3/MemoryDumpActivity.java new file mode 100644 index 000000000..19b1c4ed1 --- /dev/null +++ b/src/com/android/launcher3/MemoryDumpActivity.java @@ -0,0 +1,66 @@ +package com.android.launcher3; + +import android.app.Activity; +import android.content.Context; +import android.content.Intent; +import android.content.pm.PackageManager; +import android.net.Uri; +import android.os.Build; +import android.os.Bundle; +import android.os.Debug; +import android.os.Environment; +import android.util.Log; + +import java.io.File; +import java.io.IOException; +import java.util.ArrayList; + +public class MemoryDumpActivity extends Activity { + public void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + } + + public static void dumpHprofAndShare(final Context context) { + try { + final String path = String.format("%s/launcher-memory-%d.ahprof", + Environment.getExternalStorageDirectory(), + System.currentTimeMillis()); + Log.v(Launcher.TAG, "Dumping memory info to " + path); + + android.os.Debug.dumpHprofData(path); // will block + + Intent shareIntent = new Intent(Intent.ACTION_SEND); + shareIntent.setType("application/vnd.android.bugreport"); + + final long pss = Debug.getPss(); + final PackageManager pm = context.getPackageManager(); + shareIntent.putExtra(Intent.EXTRA_SUBJECT, String.format("Launcher memory dump (PSS=%d)", pss)); + String appVersion; + try { + appVersion = pm.getPackageInfo(context.getPackageName(), 0).versionName; + } catch (PackageManager.NameNotFoundException e) { + appVersion = "?"; + } + shareIntent.putExtra(Intent.EXTRA_TEXT, String.format("App version: %s\nBuild: %s", + appVersion, Build.DISPLAY)); + shareIntent.setType("application/vnd.android.hprof"); + + //shareIntent.putExtra(Intent.EXTRA_TEXT, android.os.SystemProperties.get("ro.build.description")); + + final File pathFile = new File(path); + final Uri pathUri = Uri.fromFile(pathFile); + + shareIntent.putExtra(Intent.EXTRA_STREAM, pathUri); + context.startActivity(shareIntent); + } catch (IOException e) { + e.printStackTrace(); + } + } + + @Override + public void onStart() { + super.onStart(); + dumpHprofAndShare(this); + finish(); + } +} \ No newline at end of file -- cgit v1.2.3