mirror of
https://github.com/revanced/Apktool.git
synced 2025-01-22 01:37:34 +01:00
Moved publicizeResources() implementation to AndrolibResources.
This commit is contained in:
parent
be3743e967
commit
58e7d6960f
@ -21,8 +21,6 @@ import brut.androlib.java.AndrolibJava;
|
|||||||
import brut.androlib.res.AndrolibResources;
|
import brut.androlib.res.AndrolibResources;
|
||||||
import brut.androlib.res.data.ResPackage;
|
import brut.androlib.res.data.ResPackage;
|
||||||
import brut.androlib.res.data.ResTable;
|
import brut.androlib.res.data.ResTable;
|
||||||
import brut.androlib.res.decoder.ARSCDecoder;
|
|
||||||
import brut.androlib.res.decoder.ARSCDecoder.FlagsOffset;
|
|
||||||
import brut.androlib.res.util.ExtFile;
|
import brut.androlib.res.util.ExtFile;
|
||||||
import brut.androlib.src.SmaliBuilder;
|
import brut.androlib.src.SmaliBuilder;
|
||||||
import brut.androlib.src.SmaliDecoder;
|
import brut.androlib.src.SmaliDecoder;
|
||||||
@ -31,8 +29,6 @@ import brut.directory.*;
|
|||||||
import brut.util.BrutIO;
|
import brut.util.BrutIO;
|
||||||
import brut.util.OS;
|
import brut.util.OS;
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.nio.MappedByteBuffer;
|
|
||||||
import java.nio.channels.FileChannel.MapMode;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
@ -346,25 +342,7 @@ public class Androlib {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void publicizeResources(File arscFile) throws AndrolibException {
|
public void publicizeResources(File arscFile) throws AndrolibException {
|
||||||
try {
|
mAndRes.publicizeResources(arscFile);
|
||||||
FileInputStream in = new FileInputStream(arscFile);
|
|
||||||
List<FlagsOffset> offsets = ARSCDecoder.findFlagsOffsets(in);
|
|
||||||
in.close();
|
|
||||||
|
|
||||||
RandomAccessFile raf = new RandomAccessFile(arscFile, "rw");
|
|
||||||
MappedByteBuffer buf = raf.getChannel().map(MapMode.READ_WRITE, 0, arscFile.length());
|
|
||||||
for (FlagsOffset flags : offsets) {
|
|
||||||
int offset = flags.offset + 3;
|
|
||||||
int end = offset + 4 * flags.count;
|
|
||||||
while(offset < end) {
|
|
||||||
buf.put(offset, (byte) (buf.get(offset) | (byte) 0x40));
|
|
||||||
offset += 4;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
raf.close();
|
|
||||||
} catch (IOException ex) {
|
|
||||||
throw new AndrolibException(ex);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isFrameworkApk(ResTable resTable) {
|
public boolean isFrameworkApk(ResTable resTable) {
|
||||||
|
@ -22,6 +22,7 @@ import brut.androlib.err.CantFindFrameworkResException;
|
|||||||
import brut.androlib.res.data.*;
|
import brut.androlib.res.data.*;
|
||||||
import brut.androlib.res.data.value.ResXmlSerializable;
|
import brut.androlib.res.data.value.ResXmlSerializable;
|
||||||
import brut.androlib.res.decoder.*;
|
import brut.androlib.res.decoder.*;
|
||||||
|
import brut.androlib.res.decoder.ARSCDecoder.FlagsOffset;
|
||||||
import brut.androlib.res.util.ExtFile;
|
import brut.androlib.res.util.ExtFile;
|
||||||
import brut.androlib.res.util.ExtMXSerializer;
|
import brut.androlib.res.util.ExtMXSerializer;
|
||||||
import brut.common.BrutException;
|
import brut.common.BrutException;
|
||||||
@ -346,6 +347,47 @@ final public class AndrolibResources {
|
|||||||
throw new CantFindFrameworkResException(id);
|
throw new CantFindFrameworkResException(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void publicizeResources(File arscFile) throws AndrolibException {
|
||||||
|
byte[] data = new byte[(int) arscFile.length()];
|
||||||
|
|
||||||
|
InputStream in = null;
|
||||||
|
OutputStream out = null;
|
||||||
|
try {
|
||||||
|
in = new FileInputStream(arscFile);
|
||||||
|
in.read(data);
|
||||||
|
|
||||||
|
publicizeResources(data);
|
||||||
|
|
||||||
|
out = new FileOutputStream(arscFile);
|
||||||
|
out.write(data);
|
||||||
|
} catch (IOException ex) {
|
||||||
|
throw new AndrolibException(ex);
|
||||||
|
} finally {
|
||||||
|
if (in != null) {
|
||||||
|
try {
|
||||||
|
in.close();
|
||||||
|
} catch (IOException ex) {}
|
||||||
|
}
|
||||||
|
if (out != null) {
|
||||||
|
try {
|
||||||
|
out.close();
|
||||||
|
} catch (IOException ex) {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void publicizeResources(byte[] arsc) throws AndrolibException {
|
||||||
|
for (FlagsOffset flags :
|
||||||
|
ARSCDecoder.findFlagsOffsets(new ByteArrayInputStream(arsc))) {
|
||||||
|
int offset = flags.offset + 3;
|
||||||
|
int end = offset + 4 * flags.count;
|
||||||
|
while(offset < end) {
|
||||||
|
arsc[offset] |= (byte) 0x40;
|
||||||
|
offset += 4;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private File getFrameworkDir() throws AndrolibException {
|
private File getFrameworkDir() throws AndrolibException {
|
||||||
File dir = new File(System.getProperty("user.home") +
|
File dir = new File(System.getProperty("user.home") +
|
||||||
File.separatorChar + "apktool" + File.separatorChar + "framework");
|
File.separatorChar + "apktool" + File.separatorChar + "framework");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user