mirror of
https://github.com/revanced/Apktool.git
synced 2025-05-11 11:04:24 +02:00
AndrolibSmali.smali(): throws exceptions instead of stopping the VM.
This commit is contained in:
parent
7ed00631c6
commit
1441587bd7
@ -17,11 +17,24 @@
|
|||||||
|
|
||||||
package brut.androlib;
|
package brut.androlib;
|
||||||
|
|
||||||
|
import brut.directory.DirectoryException;
|
||||||
|
import brut.directory.FileDirectory;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.FileOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import org.antlr.runtime.ANTLRInputStream;
|
||||||
|
import org.antlr.runtime.CommonTokenStream;
|
||||||
|
import org.antlr.runtime.RecognitionException;
|
||||||
|
import org.antlr.runtime.tree.CommonTree;
|
||||||
|
import org.antlr.runtime.tree.CommonTreeNodeStream;
|
||||||
import org.jf.baksmali.baksmali;
|
import org.jf.baksmali.baksmali;
|
||||||
|
import org.jf.dexlib.CodeItem;
|
||||||
import org.jf.dexlib.DexFile;
|
import org.jf.dexlib.DexFile;
|
||||||
import org.jf.smali.main;
|
import org.jf.dexlib.Util.ByteArrayAnnotatedOutput;
|
||||||
|
import org.jf.smali.smaliLexer;
|
||||||
|
import org.jf.smali.smaliParser;
|
||||||
|
import org.jf.smali.smaliTreeWalker;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Ryszard Wiśniewski <brut.alll@gmail.com>
|
* @author Ryszard Wiśniewski <brut.alll@gmail.com>
|
||||||
@ -44,7 +57,73 @@ public class AndrolibSmali {
|
|||||||
smali(dir.getAbsolutePath(), dexFile.getAbsolutePath());
|
smali(dir.getAbsolutePath(), dexFile.getAbsolutePath());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void smali(String dir, String dexFile) throws AndrolibException {
|
public void smali(String dir, String dexFileName) throws AndrolibException {
|
||||||
main.main(new String[]{dir, "-o", dexFile});
|
try {
|
||||||
|
DexFile dexFile = new DexFile();
|
||||||
|
|
||||||
|
for (String fileName : new FileDirectory(dir).getFiles(true)) {
|
||||||
|
if (! assembleSmaliFile(
|
||||||
|
new File(dir + "/" + fileName), dexFile)) {
|
||||||
|
throw new AndrolibException(
|
||||||
|
"Could not smali file: " + fileName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
dexFile.place();
|
||||||
|
for (CodeItem codeItem: dexFile.CodeItemsSection.getItems()) {
|
||||||
|
codeItem.fixInstructions(true, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
dexFile.place();
|
||||||
|
|
||||||
|
ByteArrayAnnotatedOutput out = new ByteArrayAnnotatedOutput();
|
||||||
|
dexFile.writeTo(out);
|
||||||
|
byte[] bytes = out.toByteArray();
|
||||||
|
|
||||||
|
DexFile.calcSignature(bytes);
|
||||||
|
DexFile.calcChecksum(bytes);
|
||||||
|
|
||||||
|
FileOutputStream fileOutputStream = new FileOutputStream(dexFileName);
|
||||||
|
fileOutputStream.write(bytes);
|
||||||
|
fileOutputStream.close();
|
||||||
|
} catch (IOException ex) {
|
||||||
|
throw new AndrolibException("Could not smali files", ex);
|
||||||
|
} catch (DirectoryException ex) {
|
||||||
|
throw new AndrolibException("Could not smali files", ex);
|
||||||
|
} catch (RecognitionException ex) {
|
||||||
|
throw new AndrolibException("Could not smali files", ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static boolean assembleSmaliFile(File smaliFile, DexFile dexFile) throws IOException, RecognitionException {
|
||||||
|
ANTLRInputStream input = new ANTLRInputStream(new FileInputStream(smaliFile));
|
||||||
|
input.name = smaliFile.getAbsolutePath();
|
||||||
|
|
||||||
|
smaliLexer lexer = new smaliLexer(input);
|
||||||
|
|
||||||
|
CommonTokenStream tokens = new CommonTokenStream(lexer);
|
||||||
|
smaliParser parser = new smaliParser(tokens);
|
||||||
|
|
||||||
|
smaliParser.smali_file_return result = parser.smali_file();
|
||||||
|
|
||||||
|
if (parser.getNumberOfSyntaxErrors() > 0 || lexer.getNumberOfLexerErrors() > 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
CommonTree t = (CommonTree) result.getTree();
|
||||||
|
|
||||||
|
CommonTreeNodeStream treeStream = new CommonTreeNodeStream(t);
|
||||||
|
treeStream.setTokenStream(tokens);
|
||||||
|
|
||||||
|
smaliTreeWalker dexGen = new smaliTreeWalker(treeStream);
|
||||||
|
|
||||||
|
dexGen.dexFile = dexFile;
|
||||||
|
dexGen.smali_file();
|
||||||
|
|
||||||
|
if (dexGen.getNumberOfSyntaxErrors() > 0) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user