diff options
-rw-r--r-- | AndroidManifest.xml | 15 | ||||
-rw-r--r-- | proguard.flags | 4 | ||||
-rw-r--r-- | res/values/config.xml | 3 | ||||
-rw-r--r-- | res/values/strings.xml | 3 | ||||
-rw-r--r-- | src/com/android/launcher3/Launcher.java | 2 | ||||
-rw-r--r-- | src/com/android/launcher3/LauncherAppState.java | 10 | ||||
-rw-r--r-- | src/com/android/launcher3/MemoryDumpActivity.java | 66 |
7 files changed, 102 insertions, 1 deletions
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" /> </activity> + <!-- Debugging tools --> + <activity + android:name="com.android.launcher3.MemoryDumpActivity" + android:theme="@android:style/Theme.NoDisplay" + android:label="@string/debug_memory_activity" + android:enabled="@bool/debug_memory_enabled" + android:icon="@null" + > + <intent-filter> + <action android:name="android.intent.action.MAIN" /> + <category android:name="android.intent.category.DEFAULT" /> + <category android:name="android.intent.category.LAUNCHER" /> + </intent-filter> + </activity> + <!-- Intent received used to prepopulate the default workspace. --> <receiver android:name="com.android.launcher3.PreloadReceiver" diff --git a/proguard.flags b/proguard.flags index ada622695..7397088b7 100644 --- a/proguard.flags +++ b/proguard.flags @@ -62,3 +62,7 @@ -keep class com.android.launcher3.ClippedImageView { *; } + +-keep class com.android.launcher3.MemoryDumpActivity { + *; +} diff --git a/res/values/config.xml b/res/values/config.xml index d4f81854b..e65818f15 100644 --- a/res/values/config.xml +++ b/res/values/config.xml @@ -90,4 +90,7 @@ <integer name="hotseat_all_apps_index">2</integer> <!-- must be between 0 and 100 --> <integer name="hotseat_item_scale_percentage">100</integer> + + <!-- Memory debugging, including a memory dump icon --> + <bool name="debug_memory_enabled">true</bool> </resources> 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 --> <!-- Dummy string [CHAR_LIMIT=60] --> <string name="custom_workspace_cling_description_2"></string> + <!-- Debug-only activity name. [DO NOT TRANSLATE] --> + <string name="debug_memory_activity">* HPROF</string> + </resources> 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 |