Merge pull request #181 from uqbar-dao/hf/update-build-release

build-release: build into zip files with proper names
This commit is contained in:
hosted-fornet 2024-01-20 20:43:13 -08:00 committed by GitHub
commit 22aa9848dd
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 75 additions and 42 deletions

View File

@ -1,42 +0,0 @@
#!/usr/bin/env python3
import os
import shutil
import subprocess
def build_and_move(feature, tmp_dir):
print("\n" + "=" * 50)
print(f"BUILDING {feature if feature else 'default'}")
print("=" * 50 + "\n")
if feature:
subprocess.run(["cargo", "+nightly", "build", "--release", "--features", feature], check=True)
binary_name = f"kinode-{feature}"
else:
subprocess.run(["cargo", "+nightly", "build", "--release"], check=True)
binary_name = "kinode"
# Move and rename the binary
source_path = "target/release/kinode"
dest_path = os.path.join(tmp_dir, binary_name)
shutil.move(source_path, dest_path)
def main():
# Features to compile with
features = ["", "simulation-mode"] # Add more features as needed
# Ensure the tmp directory is clean
tmp_dir = "/tmp/kinode-release"
if os.path.exists(tmp_dir):
shutil.rmtree(tmp_dir)
os.makedirs(tmp_dir)
# Loop through the features and build
for feature in features:
build_and_move(feature, tmp_dir)
print(f"Build and move process completed.\nFind release in {tmp_dir}.")
if __name__ == "__main__":
main()

75
scripts/build-release.py Executable file
View File

@ -0,0 +1,75 @@
#!/usr/bin/env python3
import os
import shutil
import subprocess
import zipfile
def get_system_info():
# Get OS and architecture information
os_info = subprocess.run(["uname"], capture_output=True, text=True, check=True).stdout.strip().lower()
arch_info = subprocess.run(["uname", "-p"], capture_output=True, text=True, check=True).stdout.strip().lower()
if os_info == "linux":
os_info = "unknown-linux-gnu"
elif os_info == "darwin":
os_info = "apple-darwin"
if arch_info == "arm":
arch_info = "aarch64"
return arch_info, os_info
def build_and_move(feature, tmp_dir, architecture, os_name):
print("\n" + "=" * 50)
print(f"BUILDING {feature if feature else 'default'}")
print("=" * 50 + "\n")
zip_prefix = f"kinode-{architecture}-{os_name}"
release_env = os.environ.copy()
release_env["CARGO_PROFILE_RELEASE_LTO"] = f"fat"
release_env["CARGO_PROFILE_RELEASE_CODEGEN_UNITS"] = f"1"
release_env["CARGO_PROFILE_RELEASE_STRIP"] = f"symbols"
if feature:
subprocess.run(["cargo", "+nightly", "build", "--release", "--features", feature], check=True, env=release_env)
zip_name = f"{zip_prefix}-{feature}.zip"
else:
subprocess.run(["cargo", "+nightly", "build", "--release"], check=True, env=release_env)
zip_name = f"{zip_prefix}.zip"
# Move and rename the binary
binary_name = "kinode"
source_path = f"target/release/{binary_name}"
dest_path = os.path.join(tmp_dir, binary_name)
shutil.move(source_path, dest_path)
# Create a zip archive of the binary
zip_path = os.path.join(tmp_dir, zip_name)
with zipfile.ZipFile(zip_path, 'w', zipfile.ZIP_DEFLATED) as zipf:
zipf.write(dest_path, os.path.basename(dest_path))
# Remove the original binary
os.remove(dest_path)
def main():
# Get system info
architecture, os_name = get_system_info()
# Modify the temporary directory path
tmp_dir = "/tmp/kinode-release"
if os.path.exists(tmp_dir):
shutil.rmtree(tmp_dir)
os.makedirs(tmp_dir)
# Features to compile with; add more features as needed
features = ["", "simulation-mode"]
# Loop through the features and build
for feature in features:
build_and_move(feature, tmp_dir, architecture, os_name)
print(f"Build and move process completed.\nFind release in {tmp_dir}.")
if __name__ == "__main__":
main()