mirror of
https://github.com/revanced/Apktool.git
synced 2025-01-21 01:07:34 +01:00
Handle APKs with NULL padding on StringPools
- issue 664
This commit is contained in:
parent
76bf5ead25
commit
62db52fe7b
@ -41,10 +41,12 @@ public class StringBlock {
|
|||||||
* be at the chunk type.
|
* be at the chunk type.
|
||||||
*/
|
*/
|
||||||
public static StringBlock read(ExtDataInput reader) throws IOException {
|
public static StringBlock read(ExtDataInput reader) throws IOException {
|
||||||
reader.skipCheckInt(CHUNK_TYPE);
|
reader.skipCheckChunkTypeInt(CHUNK_STRINGPOOL_TYPE, CHUNK_NULL_TYPE);
|
||||||
int chunkSize = reader.readInt();
|
int chunkSize = reader.readInt();
|
||||||
|
|
||||||
|
// ResStringPool_header
|
||||||
int stringCount = reader.readInt();
|
int stringCount = reader.readInt();
|
||||||
int styleOffsetCount = reader.readInt();
|
int styleCount = reader.readInt();
|
||||||
int flags = reader.readInt();
|
int flags = reader.readInt();
|
||||||
int stringsOffset = reader.readInt();
|
int stringsOffset = reader.readInt();
|
||||||
int stylesOffset = reader.readInt();
|
int stylesOffset = reader.readInt();
|
||||||
@ -55,8 +57,8 @@ public class StringBlock {
|
|||||||
block.m_stringOwns = new int[stringCount];
|
block.m_stringOwns = new int[stringCount];
|
||||||
Arrays.fill(block.m_stringOwns, -1);
|
Arrays.fill(block.m_stringOwns, -1);
|
||||||
|
|
||||||
if (styleOffsetCount != 0) {
|
if (styleCount != 0) {
|
||||||
block.m_styleOffsets = reader.readIntArray(styleOffsetCount);
|
block.m_styleOffsets = reader.readIntArray(styleCount);
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
int size = ((stylesOffset == 0) ? chunkSize : stylesOffset)
|
int size = ((stylesOffset == 0) ? chunkSize : stylesOffset)
|
||||||
@ -343,6 +345,7 @@ public class StringBlock {
|
|||||||
private static final Logger LOGGER = Logger.getLogger(StringBlock.class.getName());
|
private static final Logger LOGGER = Logger.getLogger(StringBlock.class.getName());
|
||||||
|
|
||||||
// ResChunk_header = header.type (0x0001) + header.headerSize (0x001C)
|
// ResChunk_header = header.type (0x0001) + header.headerSize (0x001C)
|
||||||
private static final int CHUNK_TYPE = 0x001C0001;
|
private static final int CHUNK_STRINGPOOL_TYPE = 0x001C0001;
|
||||||
|
private static final int CHUNK_NULL_TYPE = 0x00000000;
|
||||||
private static final int UTF8_FLAG = 0x00000100;
|
private static final int UTF8_FLAG = 0x00000100;
|
||||||
}
|
}
|
||||||
|
@ -62,7 +62,17 @@ public class ExtDataInput extends DataInputDelegate {
|
|||||||
byte got = readByte();
|
byte got = readByte();
|
||||||
if (got != expected) {
|
if (got != expected) {
|
||||||
throw new IOException(String.format(
|
throw new IOException(String.format(
|
||||||
"Expected: 0x%08x, got: 0x%08x", expected, got));
|
"Expected: 0x%08x, got: 0x%08x", expected, got));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void skipCheckChunkTypeInt(int expected, int possible) throws IOException {
|
||||||
|
int got = readInt();
|
||||||
|
|
||||||
|
if (got == possible) {
|
||||||
|
skipCheckChunkTypeInt(expected, -1);
|
||||||
|
} else if (got != expected) {
|
||||||
|
throw new IOException(String.format("Expected: 0x%08x, got: 0x%08x", expected, got));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user