OSDN Git Service

Fix error when using list as actionBarNavMode. [DO NOT MERGE]
authorDeepanshu Gupta <deepanshu@google.com>
Thu, 25 Sep 2014 22:42:15 +0000 (15:42 -0700)
committerDeepanshu Gupta <deepanshu@google.com>
Thu, 25 Sep 2014 22:59:58 +0000 (22:59 +0000)
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

tools/layoutlib/bridge/src/com/android/layoutlib/bridge/android/BridgeContext.java

index a2fd593..9202fa5 100644 (file)
@@ -624,10 +624,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*/);
                 }