From 3c3470579841ab2118845eb7af54443dc06a48cd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ryszard=20Wi=C5=9Bniewski?= Date: Mon, 30 Aug 2010 15:25:12 +0200 Subject: [PATCH] ARSCDecoder.readConfigFlags(): better handling of exceeding flags data. --- .../androlib/res/decoder/ARSCDecoder.java | 20 +++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/src/brut/androlib/res/decoder/ARSCDecoder.java b/src/brut/androlib/res/decoder/ARSCDecoder.java index 6229bd06..6209aac9 100644 --- a/src/brut/androlib/res/decoder/ARSCDecoder.java +++ b/src/brut/androlib/res/decoder/ARSCDecoder.java @@ -260,14 +260,22 @@ public class ARSCDecoder { mIn.skipBytes(2); } - int unknownBytes = size - KNOWN_CONFIG_BYTES; - if (unknownBytes > 0) { - byte[] buf = new byte[unknownBytes]; + int exceedingSize = size - KNOWN_CONFIG_BYTES; + if (exceedingSize > 0) { + byte[] buf = new byte[exceedingSize]; mIn.readFully(buf); - LOGGER.warning(String.format( - "Config size > %d. Omitting exceeding bytes: %0" + (unknownBytes * 2) + "X.", - KNOWN_CONFIG_BYTES, new BigInteger(buf))); + BigInteger exceedingBI = new BigInteger(buf); + if (exceedingBI.equals(BigInteger.ZERO)) { + LOGGER.fine(String.format( + "Config flags size > %d, but exceeding bytes are all zero, so it should be ok.", + KNOWN_CONFIG_BYTES)); + } else { + LOGGER.warning(String.format( + "Config flags size > %d. Exceeding bytes: %0" + (exceedingSize * 2) + "X.", + KNOWN_CONFIG_BYTES, exceedingBI)); + isInvalid = true; + } } return new ResConfigFlags(mcc, mnc, language, country, orientation,