diff options
author | Deepanshu Gupta <deepanshu@google.com> | 2014-10-08 17:34:12 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2014-10-08 17:34:12 +0000 |
commit | 908a4f9a4372a9627e821b5800936095b0f0b5b0 (patch) | |
tree | 7ac469f5fd61ffd4c5dab2b04f6fcb4edf97d44b /tools/layoutlib/create/src/com/android | |
parent | 562262cc89838529316ff2f3e511c0d876b08677 (diff) | |
parent | 4f133894a6e98d8d30557ea42cec92cfb21fa5c9 (diff) | |
download | frameworks_base-908a4f9a4372a9627e821b5800936095b0f0b5b0.zip frameworks_base-908a4f9a4372a9627e821b5800936095b0f0b5b0.tar.gz frameworks_base-908a4f9a4372a9627e821b5800936095b0f0b5b0.tar.bz2 |
am 4f133894: Exclude KXmlParser from LayoutLib.
* commit '4f133894a6e98d8d30557ea42cec92cfb21fa5c9':
Exclude KXmlParser from LayoutLib.
Diffstat (limited to 'tools/layoutlib/create/src/com/android')
4 files changed, 39 insertions, 22 deletions
diff --git a/tools/layoutlib/create/src/com/android/tools/layoutlib/create/AsmAnalyzer.java b/tools/layoutlib/create/src/com/android/tools/layoutlib/create/AsmAnalyzer.java index 9a10f79..aa51c46 100644 --- a/tools/layoutlib/create/src/com/android/tools/layoutlib/create/AsmAnalyzer.java +++ b/tools/layoutlib/create/src/com/android/tools/layoutlib/create/AsmAnalyzer.java @@ -242,7 +242,8 @@ public class AsmAnalyzer { for (Entry<String, ClassReader> entry : zipClasses.entrySet()) { String class_name = entry.getKey(); - if (regexp.matcher(class_name).matches()) { + if (regexp.matcher(class_name).matches() && + !mExcludedClasses.contains(getOuterClassName(class_name))) { findClass(class_name, zipClasses, inOutFound); } } @@ -273,6 +274,9 @@ public class AsmAnalyzer { */ void findClassesDerivingFrom(String super_name, Map<String, ClassReader> zipClasses, Map<String, ClassReader> inOutFound) throws LogAbortException { + if (mExcludedClasses.contains(getOuterClassName(super_name))) { + return; + } findClass(super_name, zipClasses, inOutFound); for (Entry<String, ClassReader> entry : zipClasses.entrySet()) { @@ -352,7 +356,13 @@ public class AsmAnalyzer { return deps; } - + private String getOuterClassName(String className) { + int pos = className.indexOf('$'); + if (pos > 0) { + return className.substring(0, pos); + } + return className; + } // ---------------------------------- @@ -417,7 +427,7 @@ public class AsmAnalyzer { mOutKeep.containsKey(className) || mInDeps.containsKey(className) || mOutDeps.containsKey(className) || - mExcludedClasses.contains(getBaseName(className))) { + mExcludedClasses.contains(getOuterClassName(className))) { return; } @@ -501,14 +511,6 @@ public class AsmAnalyzer { } } - private String getBaseName(String className) { - int pos = className.indexOf('$'); - if (pos > 0) { - return className.substring(0, pos); - } - return className; - } - // --------------------------------------------------- // --- ClassVisitor, FieldVisitor // --------------------------------------------------- diff --git a/tools/layoutlib/create/src/com/android/tools/layoutlib/create/CreateInfo.java b/tools/layoutlib/create/src/com/android/tools/layoutlib/create/CreateInfo.java index 89cbaeb..f20b890 100644 --- a/tools/layoutlib/create/src/com/android/tools/layoutlib/create/CreateInfo.java +++ b/tools/layoutlib/create/src/com/android/tools/layoutlib/create/CreateInfo.java @@ -23,6 +23,10 @@ import com.android.tools.layoutlib.java.IntegralToString; import com.android.tools.layoutlib.java.Objects; import com.android.tools.layoutlib.java.UnsafeByteSequence; +import java.util.Arrays; +import java.util.HashSet; +import java.util.Set; + /** * Describes the work to be done by {@link AsmGenerator}. */ @@ -98,6 +102,17 @@ public final class CreateInfo implements ICreateInfo { public String[] getJavaPkgClasses() { return JAVA_PKG_CLASSES; } + + public Set<String> getExcludedClasses() { + String[] refactoredClasses = getJavaPkgClasses(); + int count = refactoredClasses.length / 2 + EXCLUDED_CLASSES.length; + Set<String> excludedClasses = new HashSet<String>(count); + for (int i = 0; i < refactoredClasses.length; i+=2) { + excludedClasses.add(refactoredClasses[i]); + } + excludedClasses.addAll(Arrays.asList(EXCLUDED_CLASSES)); + return excludedClasses; + } //----- /** @@ -243,6 +258,11 @@ public final class CreateInfo implements ICreateInfo { "java.lang.UnsafeByteSequence", "com.android.tools.layoutlib.java.UnsafeByteSequence", }; + private final static String[] EXCLUDED_CLASSES = + new String[] { + "org.kxml2.io.KXmlParser" + }; + /** * List of classes for which the methods returning them should be deleted. * The array contains a list of null terminated section starting with the name of the class diff --git a/tools/layoutlib/create/src/com/android/tools/layoutlib/create/ICreateInfo.java b/tools/layoutlib/create/src/com/android/tools/layoutlib/create/ICreateInfo.java index 9387814..e49a668 100644 --- a/tools/layoutlib/create/src/com/android/tools/layoutlib/create/ICreateInfo.java +++ b/tools/layoutlib/create/src/com/android/tools/layoutlib/create/ICreateInfo.java @@ -16,6 +16,8 @@ package com.android.tools.layoutlib.create; +import java.util.Set; + /** * Interface describing the work to be done by {@link AsmGenerator}. */ @@ -69,4 +71,6 @@ public interface ICreateInfo { * The list can be empty but must not be null. */ public abstract String[] getJavaPkgClasses(); + + public abstract Set<String> getExcludedClasses(); } diff --git a/tools/layoutlib/create/src/com/android/tools/layoutlib/create/Main.java b/tools/layoutlib/create/src/com/android/tools/layoutlib/create/Main.java index 02f2c02..cd3c39e 100644 --- a/tools/layoutlib/create/src/com/android/tools/layoutlib/create/Main.java +++ b/tools/layoutlib/create/src/com/android/tools/layoutlib/create/Main.java @@ -18,6 +18,7 @@ package com.android.tools.layoutlib.create; import java.io.IOException; import java.util.ArrayList; +import java.util.Arrays; import java.util.HashSet; import java.util.List; import java.util.Map; @@ -87,7 +88,7 @@ public class Main { try { CreateInfo info = new CreateInfo(); - Set<String> excludeClasses = getExcludedClasses(info); + Set<String> excludeClasses = info.getExcludedClasses(); AsmGenerator agen = new AsmGenerator(log, osDestJar, info); AsmAnalyzer aa = new AsmAnalyzer(log, osJarPath, agen, @@ -156,16 +157,6 @@ public class Main { return 1; } - private static Set<String> getExcludedClasses(CreateInfo info) { - String[] refactoredClasses = info.getJavaPkgClasses(); - Set<String> excludedClasses = new HashSet<String>(refactoredClasses.length); - for (int i = 0; i < refactoredClasses.length; i+=2) { - excludedClasses.add(refactoredClasses[i]); - } - return excludedClasses; - - } - private static int listDeps(ArrayList<String> osJarPath, Log log) { DependencyFinder df = new DependencyFinder(log); try { |