summaryrefslogtreecommitdiffstats
path: root/tools/layoutlib
diff options
context:
space:
mode:
authorDeepanshu Gupta <deepanshu@google.com>2015-03-02 19:36:57 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2015-03-02 19:37:04 +0000
commit10d620ff2c4770e926b693e833105e8dbbd5fa86 (patch)
treecfa05584f93ca72ffd48eb4c0175df3492ca3df5 /tools/layoutlib
parent9b94a5399845efc9d52ebf37e8fde320885c07c8 (diff)
parent68501b87d2891ae9bf65d400f9cd755e197fda0c (diff)
downloadframeworks_base-10d620ff2c4770e926b693e833105e8dbbd5fa86.zip
frameworks_base-10d620ff2c4770e926b693e833105e8dbbd5fa86.tar.gz
frameworks_base-10d620ff2c4770e926b693e833105e8dbbd5fa86.tar.bz2
Merge "Better error msg for StateList/Hexadecimal Color." into lmp-dev
Diffstat (limited to 'tools/layoutlib')
-rw-r--r--tools/layoutlib/bridge/src/android/content/res/BridgeResources.java16
1 files changed, 13 insertions, 3 deletions
diff --git a/tools/layoutlib/bridge/src/android/content/res/BridgeResources.java b/tools/layoutlib/bridge/src/android/content/res/BridgeResources.java
index 66126af..96ca250 100644
--- a/tools/layoutlib/bridge/src/android/content/res/BridgeResources.java
+++ b/tools/layoutlib/bridge/src/android/content/res/BridgeResources.java
@@ -178,11 +178,21 @@ public final class BridgeResources extends Resources {
Pair<String, ResourceValue> value = getResourceValue(id, mPlatformResourceFlag);
if (value != null) {
+ ResourceValue resourceValue = value.getSecond();
try {
- return ResourceHelper.getColor(value.getSecond().getValue());
+ return ResourceHelper.getColor(resourceValue.getValue());
} catch (NumberFormatException e) {
- Bridge.getLog().error(LayoutLog.TAG_RESOURCES_FORMAT, e.getMessage(), e,
- null /*data*/);
+ // Check if the value passed is a file. If it is, mostly likely, user is referencing
+ // a color state list from a place where they should reference only a pure color.
+ String message;
+ if (new File(resourceValue.getValue()).isFile()) {
+ String resource = (resourceValue.isFramework() ? "@android:" : "@") + "color/"
+ + resourceValue.getName();
+ message = "Hexadecimal color expected, found Color State List for " + resource;
+ } else {
+ message = e.getMessage();
+ }
+ Bridge.getLog().error(LayoutLog.TAG_RESOURCES_FORMAT, message, e, null);
return 0;
}
}