mirror of
https://github.com/fankes/termux-app.git
synced 2025-10-24 12:49:20 +08:00
Fix installer to check supported abi:s
This fixes installation on e.g. the Samsung Galaxy S5 Neo which has a 64-bit cpu but no 64-bit runtime available (closes #69).
This commit is contained in:
@@ -7,6 +7,7 @@ import android.content.Context;
|
|||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.content.DialogInterface.OnClickListener;
|
import android.content.DialogInterface.OnClickListener;
|
||||||
import android.content.DialogInterface.OnDismissListener;
|
import android.content.DialogInterface.OnDismissListener;
|
||||||
|
import android.os.Build;
|
||||||
import android.os.Environment;
|
import android.os.Environment;
|
||||||
import android.system.Os;
|
import android.system.Os;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
@@ -23,6 +24,7 @@ import java.io.InputStreamReader;
|
|||||||
import java.net.MalformedURLException;
|
import java.net.MalformedURLException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.zip.ZipEntry;
|
import java.util.zip.ZipEntry;
|
||||||
import java.util.zip.ZipInputStream;
|
import java.util.zip.ZipInputStream;
|
||||||
@@ -178,16 +180,25 @@ final class TermuxInstaller {
|
|||||||
|
|
||||||
/** Get bootstrap zip url for this systems cpu architecture. */
|
/** Get bootstrap zip url for this systems cpu architecture. */
|
||||||
static URL determineZipUrl() throws MalformedURLException {
|
static URL determineZipUrl() throws MalformedURLException {
|
||||||
String arch = System.getProperty("os.arch");
|
String termuxArch = null;
|
||||||
if (arch.startsWith("armv8")) {
|
// Note that we cannot use System.getProperty("os.arch") since that may give e.g. "aarch64"
|
||||||
arch = "aarch64";
|
// while a 64-bit runtime may not be installed (like on the Samsung Galaxy S5 Neo).
|
||||||
} else if (arch.startsWith("arm")) {
|
// Instead we search through the supported abi:s on the device, see:
|
||||||
// Handle different arm variants such as armv7l:
|
// http://developer.android.com/ndk/guides/abis.html
|
||||||
arch = "arm";
|
// Note that we search for abi:s in preferred order, and want to avoid installing arm on
|
||||||
} else if (arch.startsWith("x86")) { // "x86" on arcwelder, "x86_64" on 64-bit android.
|
// an x86 system where arm emulation is available.
|
||||||
arch = "i686";
|
final String[] androidArchNames = {"arm64-v8a", "x86", "armeabi-v7a"};
|
||||||
|
final String[] termuxArchNames = {"aarch64", "i686", "arm"};
|
||||||
|
|
||||||
|
final List<String> supportedArches = Arrays.asList(Build.SUPPORTED_ABIS);
|
||||||
|
for (int i = 0; i < termuxArchNames.length; i++) {
|
||||||
|
if (supportedArches.contains(androidArchNames[i])) {
|
||||||
|
termuxArch = termuxArchNames[i];
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return new URL("https://termux.net/bootstrap/bootstrap-" + arch + ".zip");
|
|
||||||
|
return new URL("https://termux.net/bootstrap/bootstrap-" + termuxArch + ".zip");
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Delete a folder and all its content or throw. */
|
/** Delete a folder and all its content or throw. */
|
||||||
|
Reference in New Issue
Block a user