ResXmlSerializer: normal value serializing if attr is undefined.

This commit is contained in:
Ryszard Wiśniewski 2010-03-13 12:51:13 +01:00
parent 8c0a1a0c98
commit 2d9580eb86

View File

@ -18,11 +18,11 @@
package brut.androlib.res.decoder;
import brut.androlib.*;
import brut.androlib.err.UndefinedResObject;
import brut.androlib.res.AndrolibResources;
import brut.androlib.res.data.ResPackage;
import brut.androlib.res.data.value.ResAttr;
import brut.androlib.res.data.value.ResScalarValue;
import brut.androlib.res.data.value.ResValue;
import java.io.IOException;
import org.xmlpull.mxp1_serializer.MXSerializer;
import org.xmlpull.v1.XmlSerializer;
@ -44,24 +44,35 @@ public class ResXmlSerializer extends MXSerializer {
if (! mDecodingEnabled) {
return super.attribute(namespace, name, value);
}
String origVal = value;
try {
ResScalarValue resValue =
mCurrentPackage.getValueFactory().factory(value);
value = null;
if (namespace == null || namespace.isEmpty()) {
value = resValue.toResXmlFormat();
} else {
if (namespace != null && ! namespace.isEmpty()) {
String pkgName = RES_NAMESPACE.equals(namespace) ?
"android" : mCurrentPackage.getName();
try {
ResAttr attr = (ResAttr) mCurrentPackage.getResTable()
.getValue(pkgName, "attr", name);
value = attr.convertToResXmlFormat(resValue);
} catch (UndefinedResObject ex) {
System.err.println(String.format(
"warning: udefined attr when decoding: " +
"ns=%s, name=%s, value=%s",
namespace, name, origVal));
}
}
if (value == null) {
value = resValue.toResXmlFormat();
}
} catch (AndrolibException ex) {
throw new IllegalArgumentException(String.format(
"could not decode attribute: ns=%s, name=%s, value=%s",
namespace, name, value), ex);
namespace, name, origVal), ex);
}
if (value == null) {