mirror of
https://github.com/revanced/Apktool.git
synced 2025-01-22 09:47:34 +01:00
usage redo fixed #403
This commit is contained in:
parent
74493651e6
commit
8b182cacae
@ -47,6 +47,7 @@ import org.jf.util.ConsoleUtil;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Ryszard Wiśniewski <brut.alll@gmail.com>
|
* @author Ryszard Wiśniewski <brut.alll@gmail.com>
|
||||||
|
* @author Connor Tumbleson <connor.tumbleson@gmail.com>
|
||||||
*/
|
*/
|
||||||
public class Main {
|
public class Main {
|
||||||
public static void main(String[] args) throws IOException,
|
public static void main(String[] args) throws IOException,
|
||||||
@ -63,7 +64,7 @@ public class Main {
|
|||||||
_Options();
|
_Options();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
commandLine = parser.parse(allOptions, args, true);
|
commandLine = parser.parse(allOptions, args, false);
|
||||||
} catch (ParseException ex) {
|
} catch (ParseException ex) {
|
||||||
System.out.println(ex.getMessage());
|
System.out.println(ex.getMessage());
|
||||||
usage(commandLine);
|
usage(commandLine);
|
||||||
@ -89,13 +90,13 @@ public class Main {
|
|||||||
cmdDecode(commandLine);
|
cmdDecode(commandLine);
|
||||||
cmdFound = true;
|
cmdFound = true;
|
||||||
} else if (opt.equalsIgnoreCase("b") || opt.equalsIgnoreCase("build")) {
|
} else if (opt.equalsIgnoreCase("b") || opt.equalsIgnoreCase("build")) {
|
||||||
cmdBuild(args);
|
cmdBuild(commandLine);
|
||||||
cmdFound = true;
|
cmdFound = true;
|
||||||
} else if (opt.equalsIgnoreCase("if") || opt.equalsIgnoreCase("install-framework")) {
|
} else if (opt.equalsIgnoreCase("if") || opt.equalsIgnoreCase("install-framework")) {
|
||||||
cmdInstallFramework(args);
|
cmdInstallFramework(commandLine);
|
||||||
cmdFound = true;
|
cmdFound = true;
|
||||||
} else if (opt.equalsIgnoreCase("publicize-resources")) {
|
} else if (opt.equalsIgnoreCase("publicize-resources")) {
|
||||||
cmdPublicizeResources(args);
|
cmdPublicizeResources(commandLine);
|
||||||
cmdFound = true;
|
cmdFound = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -110,11 +111,12 @@ public class Main {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void cmdDecode(CommandLine cli) throws InvalidArgsError,
|
private static void cmdDecode(CommandLine cli) throws AndrolibException {
|
||||||
AndrolibException {
|
|
||||||
ApkDecoder decoder = new ApkDecoder();
|
ApkDecoder decoder = new ApkDecoder();
|
||||||
|
|
||||||
int para = cli.getArgList().size();
|
int paraCount = cli.getArgList().size();
|
||||||
|
String apkName = (String) cli.getArgList().get(paraCount - 1);
|
||||||
|
File outDir = null;
|
||||||
|
|
||||||
// check for options
|
// check for options
|
||||||
if (cli.hasOption("s") || cli.hasOption("no-src")) {
|
if (cli.hasOption("s") || cli.hasOption("no-src")) {
|
||||||
@ -144,55 +146,52 @@ public class Main {
|
|||||||
if (cli.hasOption("o") || cli.hasOption("output")) {
|
if (cli.hasOption("o") || cli.hasOption("output")) {
|
||||||
decoder.setOutDir(new File(cli.getOptionValue("o")));
|
decoder.setOutDir(new File(cli.getOptionValue("o")));
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
// make out folder manually using name of apk
|
||||||
|
String outName = apkName;
|
||||||
|
outName = outName.endsWith(".apk") ? outName.substring(0,
|
||||||
|
outName.length() - 4) : outName + ".out";
|
||||||
|
|
||||||
|
// make file from path
|
||||||
|
outName = new File(outName).getName();
|
||||||
|
outDir = new File(outName);
|
||||||
|
decoder.setOutDir(outDir);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
decoder.setApkFile(new File(apkName));
|
||||||
|
|
||||||
|
try {
|
||||||
// String outName = null;
|
decoder.decode();
|
||||||
// if (args.length == i + 2) {
|
} catch (OutDirExistsException ex) {
|
||||||
// outName = args[i + 1];
|
System.out
|
||||||
// } else if (args.length == i + 1) {
|
.println("Destination directory ("
|
||||||
// outName = args[i];
|
+ outDir.getAbsolutePath()
|
||||||
// outName = outName.endsWith(".apk") ? outName.substring(0,
|
+ ") "
|
||||||
// outName.length() - 4) : outName + ".out";
|
+ "already exists. Use -f switch if you want to overwrite it.");
|
||||||
// outName = new File(outName).getName();
|
System.exit(1);
|
||||||
// } else {
|
} catch (InFileNotFoundException ex) {
|
||||||
// throw new InvalidArgsError();
|
System.out.println("Input file (" + apkName + ") " + "was not found or was not readable.");
|
||||||
// }
|
System.exit(1);
|
||||||
// File outDir = new File(outName);
|
} catch (CantFindFrameworkResException ex) {
|
||||||
// decoder.setOutDir(outDir);
|
System.out
|
||||||
// decoder.setApkFile(new File(args[i]));
|
.println("Can't find framework resources for package of id: "
|
||||||
//
|
+ String.valueOf(ex.getPkgId())
|
||||||
// try {
|
+ ". You must install proper "
|
||||||
// decoder.decode();
|
+ "framework files, see project website for more info.");
|
||||||
// } catch (OutDirExistsException ex) {
|
System.exit(1);
|
||||||
// System.out
|
} catch (IOException ex) {
|
||||||
// .println("Destination directory ("
|
System.out.println("Could not modify file. Please ensure you have permission.");
|
||||||
// + outDir.getAbsolutePath()
|
System.exit(1);
|
||||||
// + ") "
|
}
|
||||||
// + "already exists. Use -f switch if you want to overwrite it.");
|
|
||||||
// System.exit(1);
|
|
||||||
// } catch (InFileNotFoundException ex) {
|
|
||||||
// System.out.println("Input file (" + args[i] + ") "
|
|
||||||
// + "was not found or was not readable.");
|
|
||||||
// System.exit(1);
|
|
||||||
// } catch (CantFindFrameworkResException ex) {
|
|
||||||
// System.out
|
|
||||||
// .println("Can't find framework resources for package of id: "
|
|
||||||
// + String.valueOf(ex.getPkgId())
|
|
||||||
// + ". You must install proper "
|
|
||||||
// + "framework files, see project website for more info.");
|
|
||||||
// System.exit(1);
|
|
||||||
// } catch (IOException ex) {
|
|
||||||
// System.out
|
|
||||||
// .println("Could not modify file. Please ensure you have permission.");
|
|
||||||
// System.exit(1);
|
|
||||||
// }
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void cmdBuild(String[] args) throws BrutException {
|
private static void cmdBuild(CommandLine cli) throws BrutException {
|
||||||
|
int paraCount = cli.getArgList().size();
|
||||||
|
String apkName = (String) cli.getArgList().get(paraCount - 1);
|
||||||
|
String mAaptPath = "";
|
||||||
|
String appDirName = ".";
|
||||||
|
File outFile = null;
|
||||||
Androlib instance = new Androlib();
|
Androlib instance = new Androlib();
|
||||||
|
|
||||||
// hold all the fields
|
// hold all the fields
|
||||||
@ -204,87 +203,61 @@ public class Main {
|
|||||||
flags.put("update", false);
|
flags.put("update", false);
|
||||||
flags.put("copyOriginal", false);
|
flags.put("copyOriginal", false);
|
||||||
|
|
||||||
int i;
|
// check for build options
|
||||||
int skip = 0;
|
if (cli.hasOption("f") || cli.hasOption("force-all")) {
|
||||||
|
|
||||||
ExtFile mOrigApk = null;
|
|
||||||
String mAaptPath = "";
|
|
||||||
for (i = 0; i < args.length; i++) {
|
|
||||||
String opt = args[i];
|
|
||||||
if (!opt.startsWith("-")) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if ("-f".equals(opt) || "--force-all".equals(opt)) {
|
|
||||||
flags.put("forceBuildAll", true);
|
flags.put("forceBuildAll", true);
|
||||||
} else if ("-d".equals(opt) || "--debug".equals(opt)) {
|
}
|
||||||
|
if (cli.hasOption("d") || cli.hasOption("debug")) {
|
||||||
flags.put("debug", true);
|
flags.put("debug", true);
|
||||||
} else if ("-v".equals(opt) || "--verbose".equals(opt)) {
|
}
|
||||||
|
if (cli.hasOption("v") || cli.hasOption("verbose")) {
|
||||||
flags.put("verbose", true);
|
flags.put("verbose", true);
|
||||||
} else if ("-a".equals(opt) || "--aapt".equals(opt)) {
|
}
|
||||||
mAaptPath = args[i + 1];
|
if (cli.hasOption("a") || cli.hasOption("aapt")) {
|
||||||
skip = 1;
|
mAaptPath = cli.getOptionValue("a");
|
||||||
} else if ("-c".equals(opt) || "--copy-original".equals(opt)) {
|
}
|
||||||
|
if (cli.hasOption("c") || cli.hasOption("copy-original")) {
|
||||||
flags.put("copyOriginal", true);
|
flags.put("copyOriginal", true);
|
||||||
} else if ("--frame-path".equals(opt)) {
|
}
|
||||||
i++;
|
if (cli.hasOption("p") || cli.hasOption("frame-path")) {
|
||||||
instance.setFrameworkFolder(args[i]);
|
instance.setFrameworkFolder(cli.getOptionValue("p"));
|
||||||
|
}
|
||||||
|
if (cli.hasOption("o") || cli.hasOption("output")) {
|
||||||
|
outFile = new File(cli.getOptionValue("o"));
|
||||||
} else {
|
} else {
|
||||||
throw new InvalidArgsError();
|
outFile = null;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
String appDirName;
|
if (apkName != null) {
|
||||||
File outFile = null;
|
appDirName = apkName;
|
||||||
switch (args.length - i - skip) {
|
|
||||||
case 0:
|
|
||||||
appDirName = ".";
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
outFile = new File(args[i + 1 + skip]);
|
|
||||||
case 1:
|
|
||||||
appDirName = args[i + skip];
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
throw new InvalidArgsError();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
instance.build(new File(appDirName), outFile, flags, mOrigApk,
|
// try and build apk
|
||||||
mAaptPath);
|
instance.build(new File(appDirName), outFile, flags,mAaptPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void cmdInstallFramework(String[] args)
|
private static void cmdInstallFramework(CommandLine cli)
|
||||||
throws AndrolibException {
|
throws AndrolibException {
|
||||||
|
int paraCount = cli.getArgList().size();
|
||||||
|
String apkName = (String) cli.getArgList().get(paraCount - 1);
|
||||||
String tag = null;
|
String tag = null;
|
||||||
String frame_path = null;
|
String frame_path = null;
|
||||||
int i = 0;
|
|
||||||
switch (args.length) {
|
if (cli.hasOption("p") || cli.hasOption("frame-path")) {
|
||||||
case 4:
|
frame_path = cli.getOptionValue("p");
|
||||||
if (args[2].equalsIgnoreCase("--frame-path")) {
|
|
||||||
i++;
|
|
||||||
} else {
|
|
||||||
throw new InvalidArgsError();
|
|
||||||
}
|
}
|
||||||
case 3:
|
if (cli.hasOption("t") || cli.hasOption("tag")) {
|
||||||
frame_path = args[2 + i];
|
tag = cli.getOptionValue("t");
|
||||||
case 2:
|
|
||||||
if (!(args[1].equalsIgnoreCase("--frame-path"))) {
|
|
||||||
tag = args[1];
|
|
||||||
}
|
}
|
||||||
case 1:
|
new Androlib().installFramework(new File(apkName), tag, frame_path);
|
||||||
new Androlib().installFramework(new File(args[0]), tag, frame_path);
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
throw new InvalidArgsError();
|
private static void cmdPublicizeResources(CommandLine cli)
|
||||||
}
|
throws AndrolibException {
|
||||||
|
int paraCount = cli.getArgList().size();
|
||||||
|
String apkName = (String) cli.getArgList().get(paraCount - 1);
|
||||||
|
|
||||||
private static void cmdPublicizeResources(String[] args)
|
new Androlib().publicizeResources(new File(apkName));
|
||||||
throws InvalidArgsError, AndrolibException {
|
|
||||||
if (args.length != 1) {
|
|
||||||
throw new InvalidArgsError();
|
|
||||||
}
|
|
||||||
|
|
||||||
new Androlib().publicizeResources(new File(args[0]));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void _version() {
|
private static void _version() {
|
||||||
@ -392,6 +365,7 @@ public class Main {
|
|||||||
|
|
||||||
BuildOptions.addOption(debugBuiOption);
|
BuildOptions.addOption(debugBuiOption);
|
||||||
BuildOptions.addOption(aaptOption);
|
BuildOptions.addOption(aaptOption);
|
||||||
|
BuildOptions.addOption(originalOption);
|
||||||
}
|
}
|
||||||
|
|
||||||
// add global options
|
// add global options
|
||||||
@ -409,7 +383,6 @@ public class Main {
|
|||||||
// add basic build options
|
// add basic build options
|
||||||
BuildOptions.addOption(outputBuiOption);
|
BuildOptions.addOption(outputBuiOption);
|
||||||
BuildOptions.addOption(frameDirOption);
|
BuildOptions.addOption(frameDirOption);
|
||||||
BuildOptions.addOption(originalOption);
|
|
||||||
BuildOptions.addOption(forceBuiOption);
|
BuildOptions.addOption(forceBuiOption);
|
||||||
|
|
||||||
// add basic framework options
|
// add basic framework options
|
||||||
@ -434,6 +407,7 @@ public class Main {
|
|||||||
allOptions.addOption(keepResOption);
|
allOptions.addOption(keepResOption);
|
||||||
allOptions.addOption(debugBuiOption);
|
allOptions.addOption(debugBuiOption);
|
||||||
allOptions.addOption(aaptOption);
|
allOptions.addOption(aaptOption);
|
||||||
|
allOptions.addOption(originalOption);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String verbosityHelp() {
|
private static String verbosityHelp() {
|
||||||
@ -534,8 +508,4 @@ public class Main {
|
|||||||
frameOptions = new Options();
|
frameOptions = new Options();
|
||||||
allOptions = new Options();
|
allOptions = new Options();
|
||||||
}
|
}
|
||||||
|
|
||||||
static class InvalidArgsError extends AndrolibException {
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -192,13 +192,13 @@ public class Androlib {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void build(File appDir, File outFile,
|
public void build(File appDir, File outFile,
|
||||||
HashMap<String, Boolean> flags, ExtFile origApk, String aaptPath)
|
HashMap<String, Boolean> flags, String aaptPath)
|
||||||
throws BrutException {
|
throws BrutException {
|
||||||
build(new ExtFile(appDir), outFile, flags, origApk, aaptPath);
|
build(new ExtFile(appDir), outFile, flags, aaptPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void build(ExtFile appDir, File outFile,
|
public void build(ExtFile appDir, File outFile,
|
||||||
HashMap<String, Boolean> flags, ExtFile origApk, String aaptPath)
|
HashMap<String, Boolean> flags, String aaptPath)
|
||||||
throws BrutException {
|
throws BrutException {
|
||||||
|
|
||||||
mAaptPath = aaptPath;
|
mAaptPath = aaptPath;
|
||||||
|
@ -56,9 +56,8 @@ public class BuildAndDecodeTest {
|
|||||||
|
|
||||||
LOGGER.info("Building testapp.apk...");
|
LOGGER.info("Building testapp.apk...");
|
||||||
File testApk = new File(sTmpDir, "testapp.apk");
|
File testApk = new File(sTmpDir, "testapp.apk");
|
||||||
ExtFile blank = null;
|
|
||||||
new Androlib().build(sTestOrigDir, testApk,
|
new Androlib().build(sTestOrigDir, testApk,
|
||||||
BuildAndDecodeTest.returnStock(), blank, "");
|
BuildAndDecodeTest.returnStock(),"");
|
||||||
|
|
||||||
LOGGER.info("Decoding testapp.apk...");
|
LOGGER.info("Decoding testapp.apk...");
|
||||||
ApkDecoder apkDecoder = new ApkDecoder(testApk);
|
ApkDecoder apkDecoder = new ApkDecoder(testApk);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user