diff options
author | Xavier Ducrohet <xav@android.com> | 2011-02-23 18:32:15 -0800 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2011-02-23 18:32:15 -0800 |
commit | 81904fa40b501d3907c086e7d4fdc4a3e25cd922 (patch) | |
tree | 41bac5c55ada779b84217022e5925b9232f40f81 | |
parent | 8ee31a0a93c583cac347dcc69c8dc71c0507774d (diff) | |
parent | f0a53435f14d23d9555fc46014352ee6a7baa647 (diff) | |
download | frameworks_base-81904fa40b501d3907c086e7d4fdc4a3e25cd922.zip frameworks_base-81904fa40b501d3907c086e7d4fdc4a3e25cd922.tar.gz frameworks_base-81904fa40b501d3907c086e7d4fdc4a3e25cd922.tar.bz2 |
Merge "LayoutLib: Add debug mode."
16 files changed, 62 insertions, 14 deletions
diff --git a/tools/layoutlib/bridge/src/android/graphics/Bitmap_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/Bitmap_Delegate.java index b6d5725..66e59d8 100644 --- a/tools/layoutlib/bridge/src/android/graphics/Bitmap_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/Bitmap_Delegate.java @@ -54,7 +54,7 @@ public final class Bitmap_Delegate { // ---- delegate manager ---- private static final DelegateManager<Bitmap_Delegate> sManager = - new DelegateManager<Bitmap_Delegate>(); + new DelegateManager<Bitmap_Delegate>(Bitmap_Delegate.class); // ---- delegate helper data ---- diff --git a/tools/layoutlib/bridge/src/android/graphics/Canvas_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/Canvas_Delegate.java index f0e727f..4decd1a 100644 --- a/tools/layoutlib/bridge/src/android/graphics/Canvas_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/Canvas_Delegate.java @@ -54,7 +54,7 @@ public final class Canvas_Delegate { // ---- delegate manager ---- private static final DelegateManager<Canvas_Delegate> sManager = - new DelegateManager<Canvas_Delegate>(); + new DelegateManager<Canvas_Delegate>(Canvas_Delegate.class); // ---- delegate helper data ---- diff --git a/tools/layoutlib/bridge/src/android/graphics/ColorFilter_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/ColorFilter_Delegate.java index e786eb5..e5a7ab6 100644 --- a/tools/layoutlib/bridge/src/android/graphics/ColorFilter_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/ColorFilter_Delegate.java @@ -38,7 +38,7 @@ public abstract class ColorFilter_Delegate { // ---- delegate manager ---- protected static final DelegateManager<ColorFilter_Delegate> sManager = - new DelegateManager<ColorFilter_Delegate>(); + new DelegateManager<ColorFilter_Delegate>(ColorFilter_Delegate.class); // ---- delegate helper data ---- diff --git a/tools/layoutlib/bridge/src/android/graphics/DrawFilter_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/DrawFilter_Delegate.java index 37c7359..870c46b 100644 --- a/tools/layoutlib/bridge/src/android/graphics/DrawFilter_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/DrawFilter_Delegate.java @@ -38,7 +38,7 @@ public abstract class DrawFilter_Delegate { // ---- delegate manager ---- protected static final DelegateManager<DrawFilter_Delegate> sManager = - new DelegateManager<DrawFilter_Delegate>(); + new DelegateManager<DrawFilter_Delegate>(DrawFilter_Delegate.class); // ---- delegate helper data ---- diff --git a/tools/layoutlib/bridge/src/android/graphics/MaskFilter_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/MaskFilter_Delegate.java index 5a6167d..c2f27e4 100644 --- a/tools/layoutlib/bridge/src/android/graphics/MaskFilter_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/MaskFilter_Delegate.java @@ -38,7 +38,7 @@ public abstract class MaskFilter_Delegate { // ---- delegate manager ---- protected static final DelegateManager<MaskFilter_Delegate> sManager = - new DelegateManager<MaskFilter_Delegate>(); + new DelegateManager<MaskFilter_Delegate>(MaskFilter_Delegate.class); // ---- delegate helper data ---- diff --git a/tools/layoutlib/bridge/src/android/graphics/Matrix_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/Matrix_Delegate.java index 251aa16..451edd2 100644 --- a/tools/layoutlib/bridge/src/android/graphics/Matrix_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/Matrix_Delegate.java @@ -46,7 +46,7 @@ public final class Matrix_Delegate { // ---- delegate manager ---- private static final DelegateManager<Matrix_Delegate> sManager = - new DelegateManager<Matrix_Delegate>(); + new DelegateManager<Matrix_Delegate>(Matrix_Delegate.class); // ---- delegate data ---- private float mValues[] = new float[MATRIX_SIZE]; diff --git a/tools/layoutlib/bridge/src/android/graphics/Paint_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/Paint_Delegate.java index 51b3efe..373f482 100644 --- a/tools/layoutlib/bridge/src/android/graphics/Paint_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/Paint_Delegate.java @@ -62,7 +62,7 @@ public class Paint_Delegate { // ---- delegate manager ---- private static final DelegateManager<Paint_Delegate> sManager = - new DelegateManager<Paint_Delegate>(); + new DelegateManager<Paint_Delegate>(Paint_Delegate.class); // ---- delegate helper data ---- private List<FontInfo> mFonts; diff --git a/tools/layoutlib/bridge/src/android/graphics/PathEffect_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/PathEffect_Delegate.java index 4d5311a..bd2b6de 100644 --- a/tools/layoutlib/bridge/src/android/graphics/PathEffect_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/PathEffect_Delegate.java @@ -40,7 +40,7 @@ public abstract class PathEffect_Delegate { // ---- delegate manager ---- protected static final DelegateManager<PathEffect_Delegate> sManager = - new DelegateManager<PathEffect_Delegate>(); + new DelegateManager<PathEffect_Delegate>(PathEffect_Delegate.class); // ---- delegate helper data ---- diff --git a/tools/layoutlib/bridge/src/android/graphics/Path_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/Path_Delegate.java index c29e9b6..6c9f48f 100644 --- a/tools/layoutlib/bridge/src/android/graphics/Path_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/Path_Delegate.java @@ -50,7 +50,7 @@ public final class Path_Delegate { // ---- delegate manager ---- private static final DelegateManager<Path_Delegate> sManager = - new DelegateManager<Path_Delegate>(); + new DelegateManager<Path_Delegate>(Path_Delegate.class); // ---- delegate data ---- private FillType mFillType = FillType.WINDING; diff --git a/tools/layoutlib/bridge/src/android/graphics/Rasterizer_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/Rasterizer_Delegate.java index e388bd9..2812b6b 100644 --- a/tools/layoutlib/bridge/src/android/graphics/Rasterizer_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/Rasterizer_Delegate.java @@ -38,7 +38,7 @@ public abstract class Rasterizer_Delegate { // ---- delegate manager ---- protected static final DelegateManager<Rasterizer_Delegate> sManager = - new DelegateManager<Rasterizer_Delegate>(); + new DelegateManager<Rasterizer_Delegate>(Rasterizer_Delegate.class); // ---- delegate helper data ---- diff --git a/tools/layoutlib/bridge/src/android/graphics/Region_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/Region_Delegate.java index 91f4347..cb31b8f 100644 --- a/tools/layoutlib/bridge/src/android/graphics/Region_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/Region_Delegate.java @@ -48,7 +48,7 @@ public class Region_Delegate { // ---- delegate manager ---- protected static final DelegateManager<Region_Delegate> sManager = - new DelegateManager<Region_Delegate>(); + new DelegateManager<Region_Delegate>(Region_Delegate.class); // ---- delegate helper data ---- diff --git a/tools/layoutlib/bridge/src/android/graphics/Shader_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/Shader_Delegate.java index a008d15..368c0384 100644 --- a/tools/layoutlib/bridge/src/android/graphics/Shader_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/Shader_Delegate.java @@ -40,7 +40,7 @@ public abstract class Shader_Delegate { // ---- delegate manager ---- protected static final DelegateManager<Shader_Delegate> sManager = - new DelegateManager<Shader_Delegate>(); + new DelegateManager<Shader_Delegate>(Shader_Delegate.class); // ---- delegate helper data ---- diff --git a/tools/layoutlib/bridge/src/android/graphics/Typeface_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/Typeface_Delegate.java index 5af16ae..0f084f7 100644 --- a/tools/layoutlib/bridge/src/android/graphics/Typeface_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/Typeface_Delegate.java @@ -46,7 +46,7 @@ public final class Typeface_Delegate { // ---- delegate manager ---- private static final DelegateManager<Typeface_Delegate> sManager = - new DelegateManager<Typeface_Delegate>(); + new DelegateManager<Typeface_Delegate>(Typeface_Delegate.class); // ---- delegate helper data ---- private static final String DEFAULT_FAMILY = "sans-serif"; diff --git a/tools/layoutlib/bridge/src/android/graphics/Xfermode_Delegate.java b/tools/layoutlib/bridge/src/android/graphics/Xfermode_Delegate.java index f3401fc..962d69c 100644 --- a/tools/layoutlib/bridge/src/android/graphics/Xfermode_Delegate.java +++ b/tools/layoutlib/bridge/src/android/graphics/Xfermode_Delegate.java @@ -40,7 +40,7 @@ public abstract class Xfermode_Delegate { // ---- delegate manager ---- protected static final DelegateManager<Xfermode_Delegate> sManager = - new DelegateManager<Xfermode_Delegate>(); + new DelegateManager<Xfermode_Delegate>(Xfermode_Delegate.class); // ---- delegate helper data ---- diff --git a/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/impl/DelegateManager.java b/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/impl/DelegateManager.java index 295c98c..ae1217d 100644 --- a/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/impl/DelegateManager.java +++ b/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/impl/DelegateManager.java @@ -16,6 +16,7 @@ package com.android.layoutlib.bridge.impl; +import com.android.layoutlib.bridge.util.Debug; import com.android.layoutlib.bridge.util.SparseWeakArray; import android.util.SparseArray; @@ -69,6 +70,7 @@ import java.util.List; * @param <T> the delegate class to manage */ public final class DelegateManager<T> { + private final Class<T> mClass; private final SparseWeakArray<T> mDelegates = new SparseWeakArray<T>(); /** list used to store delegates when their main object holds a reference to them. * This is to ensure that the WeakReference in the SparseWeakArray doesn't get GC'ed @@ -78,6 +80,10 @@ public final class DelegateManager<T> { private final List<T> mJavaReferences = new ArrayList<T>(); private int mDelegateCounter = 0; + public DelegateManager(Class<T> theClass) { + mClass = theClass; + } + /** * Returns the delegate from the given native int. * <p> @@ -91,6 +97,14 @@ public final class DelegateManager<T> { public T getDelegate(int native_object) { if (native_object > 0) { T delegate = mDelegates.get(native_object); + + if (Debug.DEBUG) { + if (delegate == null) { + System.out.println("Unknown " + mClass.getSimpleName() + " with int " + + native_object); + } + } + assert delegate != null; return delegate; } @@ -107,6 +121,11 @@ public final class DelegateManager<T> { mDelegates.put(native_object, newDelegate); assert !mJavaReferences.contains(newDelegate); mJavaReferences.add(newDelegate); + + if (Debug.DEBUG) { + System.out.println("New " + mClass.getSimpleName() + " with int " + native_object); + } + return native_object; } @@ -116,6 +135,12 @@ public final class DelegateManager<T> { */ public void removeJavaReferenceFor(int native_object) { T delegate = getDelegate(native_object); + + if (Debug.DEBUG) { + System.out.println("Removing main Java ref on " + mClass.getSimpleName() + + " with int " + native_object); + } + mJavaReferences.remove(delegate); } } diff --git a/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/util/Debug.java b/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/util/Debug.java new file mode 100644 index 0000000..82eab85 --- /dev/null +++ b/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/util/Debug.java @@ -0,0 +1,23 @@ +/* + * 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 com.android.layoutlib.bridge.util; + +public class Debug { + + public final static boolean DEBUG = false; + +} |