If the target is ARM and the host is ARM, this should work with just `cargo`. I'm not sure if this works for all ARM host/target combos, or if the CPU architecture must be an exact match. But it doesn't really matter too much, since at least for now there's no ARM builds for `cross` (https://github.com/cross-rs/cross/issues/1612). So even if cross-compilation doesn't work natively, we couldn't use `cross` in this case either. I also rewrote the `set-cross-compile.sh` in Python. By "I", I mean I had Claude do it and then I tweaked it.
98 lines
2.5 KiB
Python
Executable File
98 lines
2.5 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
|
|
# Written mostly by Claude.ai based on my original bash script.
|
|
|
|
import sys
|
|
import platform
|
|
import re
|
|
import os
|
|
from subprocess import run, PIPE, CalledProcessError
|
|
|
|
|
|
def main() -> int:
|
|
"""
|
|
Main function to determine cross-compilation requirements.
|
|
|
|
Returns:
|
|
Exit code (0 for success)
|
|
"""
|
|
if len(sys.argv) < 2:
|
|
print("Error: Target architecture argument is required", file=sys.stderr)
|
|
return 1
|
|
|
|
target = sys.argv[1]
|
|
needs_cross = check_needs_cross(target)
|
|
write_github_output(needs_cross)
|
|
|
|
return 0
|
|
|
|
|
|
def check_needs_cross(target: str) -> bool:
|
|
"""
|
|
Determine if cross-compilation is needed based on system and target.
|
|
|
|
Args:
|
|
target: Target architecture string
|
|
|
|
Returns:
|
|
Boolean indicating if cross-compilation is needed
|
|
"""
|
|
system_info = get_uname_info().lower()
|
|
|
|
# Check if we're on macOS or Windows
|
|
if any(os in system_info for os in ["darwin", "msys", "windows"]):
|
|
return False
|
|
|
|
target = target.lower()
|
|
|
|
# Check for x86_64 Linux targets on x86_64 Linux host
|
|
if (
|
|
re.search(r"x86_64.+linux-(?:gnu|musl)", target)
|
|
and "x86_64" in system_info
|
|
and "linux" in system_info
|
|
):
|
|
return False
|
|
|
|
# Check if both host and target are ARM Linux. I'm assuming here that for things like
|
|
# "arm-linux-androideabi" or "armv7-unknown-linux-ohos" we'd still need cross.
|
|
if (
|
|
re.search(r"(?:aarch64|arm).+linux-(?:gnu|musl)", target)
|
|
and ("arm" in system_info or "aarch64" in system_info)
|
|
and "linux" in system_info
|
|
):
|
|
return False
|
|
|
|
return True
|
|
|
|
|
|
def get_uname_info() -> str:
|
|
"""
|
|
Get system information using uname command.
|
|
|
|
Returns:
|
|
String containing system information
|
|
"""
|
|
try:
|
|
result = run(["uname", "-a"], check=True, text=True, stdout=PIPE)
|
|
return result.stdout
|
|
except (CalledProcessError, FileNotFoundError):
|
|
# Fallback to platform.platform() if uname is not available
|
|
return platform.platform()
|
|
|
|
|
|
def write_github_output(needs_cross: bool) -> None:
|
|
"""
|
|
Write the needs-cross output to GITHUB_OUTPUT environment variable file.
|
|
|
|
Args:
|
|
needs_cross: Boolean indicating if cross-compilation is needed
|
|
"""
|
|
github_output = os.getenv("GITHUB_OUTPUT")
|
|
if github_output:
|
|
with open(github_output, "a") as f:
|
|
f.write(f"needs-cross={str(needs_cross).lower()}\n")
|
|
|
|
|
|
if __name__ == "__main__":
|
|
sys.exit(main())
|