[#562] Detect and warn when running under Rosetta
This commit is contained in:
parent
17c09908a8
commit
491154f467
|
@ -0,0 +1,47 @@
|
|||
import java.util.concurrent.TimeUnit
|
||||
if (isRosetta()) {
|
||||
logger.warn("This Gradle invocation is running under Rosetta. Use an ARM (aarch64) JDK to " +
|
||||
"improve performance. One can be downloaded from https://adoptium.net/temurin/releases")
|
||||
}
|
||||
|
||||
@Suppress("MagicNumber")
|
||||
private val maxTimeoutMillis = 5000L
|
||||
|
||||
/**
|
||||
* This method is safe to call from any operating system or CPU architecture.
|
||||
*
|
||||
* @return True if the application is running under Rosetta.
|
||||
*/
|
||||
fun isRosetta(): Boolean {
|
||||
if (System.getProperty("os.name").toLowerCase(java.util.Locale.ROOT).startsWith("mac")) {
|
||||
// Counterintuitive, but running under Rosetta is reported as Intel64 to the JVM
|
||||
if (!System.getProperty("os.arch").toLowerCase(java.util.Locale.ROOT).contains("aarch64")) {
|
||||
val outputValue = Runtime.getRuntime()
|
||||
.exec("sysctl -in sysctl.proc_translated")
|
||||
.scanOutputLine()
|
||||
?.toIntOrNull()
|
||||
|
||||
if (1 == outputValue) {
|
||||
return true
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return false
|
||||
}
|
||||
|
||||
fun Process.scanOutputLine(): String? {
|
||||
var outputString = ""
|
||||
|
||||
inputStream.use { inputStream ->
|
||||
java.util.Scanner(inputStream).useDelimiter("\\A").use { scanner ->
|
||||
while (scanner.hasNext()) {
|
||||
outputString = scanner.next()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
waitFor(maxTimeoutMillis, TimeUnit.MILLISECONDS)
|
||||
|
||||
return outputString.trim()
|
||||
}
|
|
@ -15,6 +15,7 @@ plugins {
|
|||
id("com.osacky.fulladle")
|
||||
id("io.gitlab.arturbosch.detekt")
|
||||
id("zcash-sdk.ktlint-conventions")
|
||||
id("zcash-sdk.rosetta-conventions")
|
||||
}
|
||||
|
||||
tasks {
|
||||
|
@ -85,4 +86,4 @@ if (firebaseTestLabKeyPath.isNotBlank()) {
|
|||
|
||||
flankVersion.set(libs.versions.flank.get())
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue