Merge "Cherrypick d1ed33c4 from hc-mr1. do not merge." into gingerbread

This commit is contained in:
Xavier Ducrohet
2011-06-03 18:53:41 -07:00
committed by Android (Google) Code Review
3 changed files with 86 additions and 0 deletions

View File

@@ -0,0 +1,80 @@
/*
* Copyright (C) 2011 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.os;
import com.android.layoutlib.bridge.android.BridgeContext;
import com.android.layoutlib.bridge.impl.RenderAction;
import com.android.tools.layoutlib.annotations.LayoutlibDelegate;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* Delegate overriding selected methods of android.os.HandlerThread
*
* Through the layoutlib_create tool, selected methods of Handler have been replaced
* by calls to methods of the same name in this delegate class.
*
*
*/
public class HandlerThread_Delegate {
private static Map<BridgeContext, List<HandlerThread>> sThreads =
new HashMap<BridgeContext, List<HandlerThread>>();
public static void cleanUp(BridgeContext context) {
List<HandlerThread> list = sThreads.get(context);
if (list != null) {
for (HandlerThread thread : list) {
thread.quit();
}
list.clear();
sThreads.remove(context);
}
}
// -------- Delegate methods
@LayoutlibDelegate
/*package*/ static void run(HandlerThread theThread) {
// record the thread so that it can be quit() on clean up.
BridgeContext context = RenderAction.getCurrentContext();
List<HandlerThread> list = sThreads.get(context);
if (list == null) {
list = new ArrayList<HandlerThread>();
sThreads.put(context, list);
}
list.add(theThread);
// ---- START DEFAULT IMPLEMENTATION.
theThread.mTid = Process.myTid();
Looper.prepare();
synchronized (theThread) {
theThread.mLooper = Looper.myLooper();
theThread.notifyAll();
}
Process.setThreadPriority(theThread.mPriority);
theThread.onLooperPrepared();
Looper.loop();
theThread.mTid = -1;
}
}

View File

@@ -29,6 +29,7 @@ import com.android.layoutlib.bridge.Bridge;
import com.android.layoutlib.bridge.android.BridgeContext;
import com.android.resources.ResourceType;
import android.os.HandlerThread_Delegate;
import android.util.DisplayMetrics;
import java.util.concurrent.TimeUnit;
@@ -228,6 +229,10 @@ public abstract class RenderAction<T extends RenderParams> extends FrameworkReso
private void tearDown() {
// Make sure to remove static references, otherwise we could not unload the lib
mContext.disposeResources();
// quit HandlerThread created during this session.
HandlerThread_Delegate.cleanUp(sCurrentContext);
sCurrentContext = null;
Bridge.setLog(null);

View File

@@ -98,6 +98,7 @@ public final class CreateInfo implements ICreateInfo {
"android.content.res.Resources$Theme#resolveAttribute",
"android.graphics.BitmapFactory#finishDecode",
"android.os.Handler#sendMessageAtTime",
"android.os.HandlerThread#run",
"android.os.Build#getString",
"android.view.LayoutInflater#parseInclude",
"android.view.View#isInEditMode",