You've already forked ReZygisk
mirror of
https://github.com/PerformanC/ReZygisk.git
synced 2025-09-06 06:37:01 +00:00
improve: compiler calling code
This commit improves the code that calls the compiler to compile zygiskd.
This commit is contained in:
@@ -50,7 +50,7 @@ val Files = arrayOf(
|
||||
"zygiskd.c"
|
||||
)
|
||||
|
||||
task<Task>("buildAndStrip") {
|
||||
task("buildAndStrip") {
|
||||
group = "build"
|
||||
description = "Build the native library and strip the debug symbols."
|
||||
|
||||
@@ -60,6 +60,8 @@ task<Task>("buildAndStrip") {
|
||||
|
||||
val aarch64Compiler = Paths.get(ndkPath, "toolchains", "llvm", "prebuilt", "linux-x86_64", "bin", "aarch64-linux-android34-clang").toString()
|
||||
val armv7aCompiler = Paths.get(ndkPath, "toolchains", "llvm", "prebuilt", "linux-x86_64", "bin", "armv7a-linux-androideabi34-clang").toString()
|
||||
val x86Compiler = Paths.get(ndkPath, "toolchains", "llvm", "prebuilt", "linux-x86_64", "bin", "i686-linux-android34-clang").toString()
|
||||
val x86_64Compiler = Paths.get(ndkPath, "toolchains", "llvm", "prebuilt", "linux-x86_64", "bin", "x86_64-linux-android34-clang").toString()
|
||||
|
||||
if (!Paths.get(aarch64Compiler).toFile().exists()) {
|
||||
throw Exception("aarch64 compiler not found at $aarch64Compiler")
|
||||
@@ -69,60 +71,36 @@ task<Task>("buildAndStrip") {
|
||||
throw Exception("armv7a compiler not found at $armv7aCompiler")
|
||||
}
|
||||
|
||||
if (!Paths.get(x86Compiler).toFile().exists()) {
|
||||
throw Exception("x86 compiler not found at $x86Compiler")
|
||||
}
|
||||
|
||||
if (!Paths.get(x86_64Compiler).toFile().exists()) {
|
||||
throw Exception("x86_64 compiler not found at $x86_64Compiler")
|
||||
}
|
||||
|
||||
val Files = Files.map { Paths.get(project.projectDir.toString(), "src", it).toString() }.toTypedArray()
|
||||
|
||||
val buildDir = getLayout().getBuildDirectory().getAsFile().get()
|
||||
buildDir.mkdirs()
|
||||
|
||||
val compileArgs = if (isDebug) CFlagsDebug else CFlagsRelease
|
||||
|
||||
val execFile = { command: Array<String> ->
|
||||
val process = Runtime.getRuntime().exec(command)
|
||||
val output = process.inputStream.bufferedReader().readText()
|
||||
process.waitFor()
|
||||
output
|
||||
}
|
||||
|
||||
val aarch64OutputDir = Paths.get(buildDir.toString(), "arm64-v8a").toFile()
|
||||
aarch64OutputDir.mkdirs()
|
||||
|
||||
/* INFO: Compile for aarch64 */
|
||||
val aarch64Command = arrayOf(aarch64Compiler, "-o", Paths.get(aarch64OutputDir.toString(), "zygiskd").toString(), *compileArgs, *Files)
|
||||
val aarch64CommandResult = execFile(aarch64Command)
|
||||
if (aarch64CommandResult.isNotEmpty()) {
|
||||
println(aarch64CommandResult)
|
||||
}
|
||||
|
||||
val armv7aOutputDir = Paths.get(buildDir.toString(), "armeabi-v7a").toFile()
|
||||
armv7aOutputDir.mkdirs()
|
||||
|
||||
/* INFO: Compile for armv7a */
|
||||
val armv7aCommand = arrayOf(armv7aCompiler, "-o", Paths.get(armv7aOutputDir.toString(), "zygiskd").toString(), *compileArgs, *Files)
|
||||
val armv7aCommandResult = execFile(armv7aCommand)
|
||||
if (armv7aCommandResult.isNotEmpty()) {
|
||||
println(armv7aCommandResult)
|
||||
}
|
||||
|
||||
val x86OutputDir = Paths.get(buildDir.toString(), "x86").toFile()
|
||||
x86OutputDir.mkdirs()
|
||||
|
||||
/* INFO: Compile for x86 */
|
||||
val x86Compiler = Paths.get(ndkPath, "toolchains", "llvm", "prebuilt", "linux-x86_64", "bin", "i686-linux-android34-clang").toString()
|
||||
val x86Command = arrayOf(x86Compiler, "-o", Paths.get(x86OutputDir.toString(), "zygiskd").toString(), *compileArgs, *Files)
|
||||
val x86CommandResult = execFile(x86Command)
|
||||
if (x86CommandResult.isNotEmpty()) {
|
||||
println(x86CommandResult)
|
||||
}
|
||||
|
||||
val x86_64OutputDir = Paths.get(buildDir.toString(), "x86_64").toFile()
|
||||
|
||||
aarch64OutputDir.mkdirs()
|
||||
armv7aOutputDir.mkdirs()
|
||||
x86OutputDir.mkdirs()
|
||||
x86_64OutputDir.mkdirs()
|
||||
|
||||
/* INFO: Compile for x86_64 */
|
||||
val x86_64Compiler = Paths.get(ndkPath, "toolchains", "llvm", "prebuilt", "linux-x86_64", "bin", "x86_64-linux-android34-clang").toString()
|
||||
val x86_64Command = arrayOf(x86_64Compiler, "-o", Paths.get(x86_64OutputDir.toString(), "zygiskd").toString(), *compileArgs, *Files)
|
||||
val x86_64CommandResult = execFile(x86_64Command)
|
||||
if (x86_64CommandResult.isNotEmpty()) {
|
||||
println(x86_64CommandResult)
|
||||
val compileArgs = if (isDebug) CFlagsDebug else CFlagsRelease
|
||||
|
||||
exec {
|
||||
commandLine(aarch64Compiler, "-o", Paths.get(aarch64OutputDir.toString(), "zygiskd").toString(), *compileArgs, *Files)
|
||||
commandLine(armv7aCompiler, "-o", Paths.get(armv7aOutputDir.toString(), "zygiskd").toString(), *compileArgs, *Files)
|
||||
commandLine(x86Compiler, "-o", Paths.get(x86OutputDir.toString(), "zygiskd").toString(), *compileArgs, *Files)
|
||||
commandLine(x86_64Compiler, "-o", Paths.get(x86_64OutputDir.toString(), "zygiskd").toString(), *compileArgs, *Files)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user