aboutsummaryrefslogtreecommitdiff
path: root/ci
diff options
context:
space:
mode:
authorA1029384756 <hayden.gray104@gmail.com>2024-09-05 01:52:40 -0400
committerA1029384756 <hayden.gray104@gmail.com>2024-09-08 18:35:16 -0400
commit036d7edda92c8d93c1295e4f2661152abe729bf1 (patch)
tree06615fc751ec5e970889acffc0c35f89e90be7d6 /ci
parentddf5ca7adf16b87c202989537840d6099c553638 (diff)
Changed Linux CI builds to static linking with Musl for better
compatibility Changed to tarball distribution for mac and linux Updated upload-artifact to v4
Diffstat (limited to 'ci')
-rwxr-xr-xci/build_linux_static.sh19
-rw-r--r--ci/nightly.py39
2 files changed, 41 insertions, 17 deletions
diff --git a/ci/build_linux_static.sh b/ci/build_linux_static.sh
new file mode 100755
index 000000000..f821cbb59
--- /dev/null
+++ b/ci/build_linux_static.sh
@@ -0,0 +1,19 @@
+#!/usr/bin/env sh
+# Intended for use in Alpine containers, see the "nightly" Github action for a list of dependencies
+
+CXX="clang++-18"
+LLVM_CONFIG="llvm-config-18"
+
+DISABLED_WARNINGS="-Wno-switch -Wno-macro-redefined -Wno-unused-value"
+
+CPPFLAGS="-DODIN_VERSION_RAW=\"dev-$(date +"%Y-%m")\""
+CXXFLAGS="-std=c++14 $($LLVM_CONFIG --cxxflags --ldflags)"
+
+LDFLAGS="-static -lm -lzstd -lz -lffi -pthread -ldl -fuse-ld=mold"
+LDFLAGS="$LDFLAGS $($LLVM_CONFIG --link-static --ldflags --libs --system-libs --libfiles)"
+LDFLAGS="$LDFLAGS -Wl,-rpath=\$ORIGIN"
+
+EXTRAFLAGS="-DNIGHTLY -O3"
+
+set -x
+$CXX src/main.cpp src/libtommath.cpp $DISABLED_WARNINGS $CPPFLAGS $CXXFLAGS $EXTRAFLAGS $LDFLAGS -o odin
diff --git a/ci/nightly.py b/ci/nightly.py
index 7bd32899d..779a04d96 100644
--- a/ci/nightly.py
+++ b/ci/nightly.py
@@ -2,7 +2,7 @@ import os
import sys
from zipfile import ZipFile, ZIP_DEFLATED
from b2sdk.v2 import InMemoryAccountInfo, B2Api
-from datetime import datetime
+from datetime import datetime, UTC
import json
UPLOAD_FOLDER = "nightly/"
@@ -22,7 +22,7 @@ def auth() -> bool:
pass # Not yet authenticated
err = b2_api.authorize_account("production", application_key_id, application_key)
- return err == None
+ return err is None
def get_bucket():
if not auth(): sys.exit(1)
@@ -32,30 +32,35 @@ def remove_prefix(text: str, prefix: str) -> str:
return text[text.startswith(prefix) and len(prefix):]
def create_and_upload_artifact_zip(platform: str, artifact: str) -> int:
- now = datetime.utcnow().replace(hour=0, minute=0, second=0, microsecond=0)
- destination_zip_name = "odin-{}-nightly+{}.zip".format(platform, now.strftime("%Y-%m-%d"))
+ now = datetime.now(UTC).replace(hour=0, minute=0, second=0, microsecond=0)
- source_zip_name = artifact
- if not artifact.endswith(".zip"):
- print(f"Creating archive {destination_zip_name} from {artifact} and uploading to {bucket_name}")
+ source_archive: str
+ destination_name = f'odin-{platform}-nightly+{now.strftime("%Y-%m-%d")}'
- source_zip_name = destination_zip_name
- with ZipFile(source_zip_name, mode='w', compression=ZIP_DEFLATED, compresslevel=9) as z:
+ if platform.startswith("linux") or platform.startswith("macos"):
+ destination_name += ".tar.gz"
+ source_archive = artifact
+ else:
+ destination_name += ".zip"
+ source_archive = destination_name
+
+ print(f"Creating archive {destination_name} from {artifact} and uploading to {bucket_name}")
+ with ZipFile(source_archive, mode='w', compression=ZIP_DEFLATED, compresslevel=9) as z:
for root, directory, filenames in os.walk(artifact):
for file in filenames:
file_path = os.path.join(root, file)
zip_path = os.path.join("dist", os.path.relpath(file_path, artifact))
z.write(file_path, zip_path)
- if not os.path.exists(source_zip_name):
- print(f"Error: Newly created ZIP archive {source_zip_name} not found.")
+ if not os.path.exists(source_archive):
+ print(f"Error: Newly created ZIP archive {source_archive} not found.")
return 1
- print("Uploading {} to {}".format(source_zip_name, UPLOAD_FOLDER + destination_zip_name))
+ print("Uploading {} to {}".format(source_archive, UPLOAD_FOLDER + destination_name))
bucket = get_bucket()
res = bucket.upload_local_file(
- source_zip_name, # Local file to upload
- "nightly/" + destination_zip_name, # B2 destination path
+ source_archive, # Local file to upload
+ "nightly/" + destination_name, # B2 destination path
)
return 0
@@ -66,7 +71,7 @@ def prune_artifacts():
for file, _ in bucket.ls(UPLOAD_FOLDER, latest_only=False):
# Timestamp is in milliseconds
date = datetime.fromtimestamp(file.upload_timestamp / 1_000.0).replace(hour=0, minute=0, second=0, microsecond=0)
- now = datetime.utcnow().replace(hour=0, minute=0, second=0, microsecond=0)
+ now = datetime.now(UTC).replace(hour=0, minute=0, second=0, microsecond=0)
delta = now - date
if delta.days > int(days_to_keep):
@@ -100,7 +105,7 @@ def update_nightly_json():
'sizeInBytes': size,
})
- now = datetime.utcnow().isoformat()
+ now = datetime.now(UTC).isoformat()
nightly = json.dumps({
'last_updated' : now,
@@ -137,4 +142,4 @@ if __name__ == "__main__":
elif command == "json":
res = update_nightly_json()
- sys.exit(res) \ No newline at end of file
+ sys.exit(res)