summaryrefslogtreecommitdiffstats
path: root/core/java/android
diff options
context:
space:
mode:
authorBrad Fitzpatrick <bradfitz@android.com>2010-11-23 10:41:07 -0800
committerAndroid (Google) Code Review <android-gerrit@google.com>2010-11-23 10:41:07 -0800
commita6a52dece70d75f6b5781fc902fd646b1122abd7 (patch)
tree638b6db1b3925fa1bccce521b469587dfff4fca5 /core/java/android
parent6c9aca670bbc686852093a803a3464f9ac701c6e (diff)
parentcdcb73ef781b8f7d37d9f758409a0c7671517b37 (diff)
downloadframeworks_base-a6a52dece70d75f6b5781fc902fd646b1122abd7.zip
frameworks_base-a6a52dece70d75f6b5781fc902fd646b1122abd7.tar.gz
frameworks_base-a6a52dece70d75f6b5781fc902fd646b1122abd7.tar.bz2
Merge "Cache WindowManager in StrictMode; add android.util.Singleton"
Diffstat (limited to 'core/java/android')
-rw-r--r--core/java/android/os/StrictMode.java11
-rw-r--r--core/java/android/util/Singleton.java39
2 files changed, 47 insertions, 3 deletions
diff --git a/core/java/android/os/StrictMode.java b/core/java/android/os/StrictMode.java
index 86322ac..ed09362 100644
--- a/core/java/android/os/StrictMode.java
+++ b/core/java/android/os/StrictMode.java
@@ -22,6 +22,7 @@ import android.app.ApplicationErrorReport;
import android.content.Intent;
import android.util.Log;
import android.util.Printer;
+import android.util.Singleton;
import android.view.IWindowManager;
import com.android.internal.os.RuntimeInit;
@@ -922,10 +923,8 @@ public final class StrictMode {
return;
}
- // TODO: cache the window manager stub?
final IWindowManager windowManager = (info.policy & PENALTY_FLASH) != 0 ?
- IWindowManager.Stub.asInterface(ServiceManager.getService("window")) :
- null;
+ sWindowManager.get() : null;
if (windowManager != null) {
try {
windowManager.showStrictModeViolation(true);
@@ -1404,6 +1403,12 @@ public final class StrictMode {
}
};
+ private static Singleton<IWindowManager> sWindowManager = new Singleton<IWindowManager>() {
+ protected IWindowManager create() {
+ return IWindowManager.Stub.asInterface(ServiceManager.getService("window"));
+ }
+ };
+
/**
* Enter a named critical span (e.g. an animation)
*
diff --git a/core/java/android/util/Singleton.java b/core/java/android/util/Singleton.java
new file mode 100644
index 0000000..8a38bdb
--- /dev/null
+++ b/core/java/android/util/Singleton.java
@@ -0,0 +1,39 @@
+/*
+ * Copyright (C) 2010 The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package android.util;
+
+/**
+ * Singleton helper class for lazily initialization.
+ *
+ * Modeled after frameworks/base/include/utils/Singleton.h
+ *
+ * @hide
+ */
+public abstract class Singleton<T> {
+ private T mInstance;
+
+ protected abstract T create();
+
+ public final T get() {
+ synchronized (this) {
+ if (mInstance == null) {
+ mInstance = create();
+ }
+ return mInstance;
+ }
+ }
+}