diff options
author | Deepanshu Gupta <deepanshu@google.com> | 2014-09-25 15:42:15 -0700 |
---|---|---|
committer | Deepanshu Gupta <deepanshu@google.com> | 2014-09-25 23:01:38 +0000 |
commit | 803a59cae71f8b5a76a48c73579ee6d3d34a78f7 (patch) | |
tree | 304222acda82d4bac43ac1c7e84600bc8d596d84 /tools/layoutlib | |
parent | 1968b91937020e8aa826224642733bbb9055af2e (diff) | |
download | frameworks_base-803a59cae71f8b5a76a48c73579ee6d3d34a78f7.zip frameworks_base-803a59cae71f8b5a76a48c73579ee6d3d34a78f7.tar.gz frameworks_base-803a59cae71f8b5a76a48c73579ee6d3d34a78f7.tar.bz2 |
Fix error when using list as actionBarNavMode. [DO NOT MERGE]
A bug in the framework leads to the wrong argument being passed to
defStyleRes when obtaining styled attributes. The framework however just
ignores the attribute in such a case. LayoutLib logs an error to help
developers find bugs in their code.
The bug was seen when using list as the actionBarNavMode.
This change ignores the attribute if it detects that it's the framework
bug. Also, we change the error to a warning.
Change-Id: I58e1fe4469de0329a27b577d75c0a59c48d0381b
Diffstat (limited to 'tools/layoutlib')
-rw-r--r-- | tools/layoutlib/bridge/src/com/android/layoutlib/bridge/android/BridgeContext.java | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/android/BridgeContext.java b/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/android/BridgeContext.java index 29e1f76..25e49b3 100644 --- a/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/android/BridgeContext.java +++ b/tools/layoutlib/bridge/src/com/android/layoutlib/bridge/android/BridgeContext.java @@ -637,10 +637,15 @@ public final class BridgeContext extends Context { defStyleRes, value.getSecond()), null /*data*/); } + } else if (value.getFirst() == ResourceType.ATTR) { + // Ignore. There's a bug in the framework where sometimes defStyleAttr ends up + // in defStyleRes. The framework ignores the attribute when it's not a style. + // But to let the developers find bugs in their code, we log an error for other + // cases. } else { - Bridge.getLog().error(null, + Bridge.getLog().warning(null, String.format( - "Resouce id 0x%x is not of type STYLE (instead %s)", + "Resource id 0x%x is not of type STYLE (instead %s)", defStyleRes, value.getFirst().toString()), null /*data*/); } |