fix for ResValue cast to ResAttr exception (not really, just bypass)

This commit is contained in:
Alsan Wong 2013-01-18 15:31:22 +08:00
parent 0673c1e2dc
commit efd8349aa5

View File

@ -50,12 +50,25 @@ public class ResStyleValue extends ResBagValue implements ResValuesXmlSerializab
for (int i = 0; i < mItems.length; i++) {
ResResSpec spec = mItems[i].m1.getReferent();
// fix for ClassCastException by Alsan Wong <alsan.wong@gmail.com> at 2013/01/18 15:08
ResAttr attr = null;
String value = null;
try {
// hacky-fix remove bad ReferenceVars
if (spec.getDefaultResource().getValue().toString().contains("ResReferenceValue@")) {
ResValue attrValue = spec.getDefaultResource().getValue();
value = attrValue.toString(); // I know, this is not good, but I don't want another variable just for exception handling
if(true == value.contains("ResReferenceValue@")) {
continue;
}
ResAttr attr = (ResAttr) spec.getDefaultResource().getValue();
String value = attr.convertToResXmlFormat(mItems[i].m2);
attr = (ResAttr)attrValue;
value = attr.convertToResXmlFormat(mItems[i].m2);
} catch(ClassCastException e) {
System.out.println("ClassCastException: " + e.getMessage());
System.out.println(value);
}
if (value == null) {
value = mItems[i].m2.encodeAsResXmlValue();