-
Notifications
You must be signed in to change notification settings - Fork 4
153 lines (149 loc) · 5.15 KB
/
rust.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
name: ci
on:
pull_request:
push:
branches: ['master']
tags: ['v*']
schedule:
- cron: '00 01 * * *'
jobs:
test:
name: test
runs-on: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
build:
- linux
- macos
- win-msvc
include:
- build: linux
os: ubuntu-20.04
- build: macos
os: macos-latest
- build: win-msvc
os: windows-latest
steps:
- uses: actions/checkout@v4
- uses: actions/checkout@v4
name: Clone tokens
with:
path: assets/
repository: pdx-tools/tokens
token: ${{secrets.GH_PAT}}
- name: Cache saves
uses: actions/cache@v4
with:
path: assets/saves
key: assets/saves
- name: Build
run: cargo build --all --verbose --release
- name: create save assets directory
shell: bash
run: mkdir -p assets/saves
- name: Retrieve assets
shell: bash
run: |
[ ! -f kandy2.bin.eu4 ] && curl -O https://eu4saves-test-cases.s3.us-west-002.backblazeb2.com/kandy2.bin.eu4 || true
[ ! -f af_Munso_867_Ironman.ck3 ] && curl -O https://ck3saves-test-cases.s3.us-west-002.backblazeb2.com/af_Munso_867_Ironman.ck3 || true
[ ! -f observer1.5.rome ] && curl -O https://imperator-test-cases.s3.us-west-002.backblazeb2.com/observer1.5.rome || true
[ ! -f 1.10-ironman.zip ] && curl -O https://hoi4saves-test-cases.s3.us-west-002.backblazeb2.com/1.10-ironman.zip && unzip 1.10-ironman.zip || true
working-directory: ./assets/saves
- name: Run verifier
if: matrix.os == 'ubuntu-20.04'
working-directory: ./target
run: |
set -eou
cp ../sample.cpp .
cp ./release/librakaly.so .
g++ sample.cpp -o melter -std=c++17 -Werror -Wall -Wextra -O2 librakaly.so
LD_LIBRARY_PATH=. ./melter save ../assets/saves/kandy2.bin.eu4 > /dev/null
LD_LIBRARY_PATH=. ./melter save ../assets/saves/af_Munso_867_Ironman.ck3 > /dev/null
LD_LIBRARY_PATH=. ./melter save ../assets/saves/observer1.5.rome > /dev/null
LD_LIBRARY_PATH=. ./melter save ../assets/saves/1.10-ironman.hoi4 > /dev/null
- uses: ilammy/msvc-dev-cmd@v1
- name: Run verifier (windows)
if: matrix.os == 'windows-latest'
working-directory: ./target
run: |
cp ..\sample.cpp .
cp .\release\rakaly* .
cl /EHsc sample.cpp /std:c++17 /link rakaly.dll.lib /out:melter.exe
.\melter.exe save ..\assets\saves\kandy2.bin.eu4 > NUL
.\melter.exe save ..\assets\saves\af_Munso_867_Ironman.ck3 > NUL
.\melter.exe save ..\assets\saves\observer1.5.rome > NUL
.\melter.exe save ..\assets\saves\1.10-ironman.hoi4 > NUL
- name: Stage Release
shell: bash
run: |
if [[ "${GITHUB_REF}" = *refs/tags/* ]]; then
VERSION="${GITHUB_REF#refs/tags/}"
else
VERSION="vnightly"
fi
echo "version is $VERSION"
STAGING="librakaly-${VERSION:1}-${{ matrix.build }}"
echo "STAGING DIR: $STAGING"
mkdir $STAGING
if [[ "${{ matrix.os }}" = windows* ]]; then
cp target/release/rakaly.{dll,dll.lib} "$STAGING/"
cp target/rakaly.h "$STAGING/"
else
find target/release -maxdepth 1 -name "librakaly.so" -o -name "librakaly.dylib" | xargs -I{} cp {} "$STAGING/"
fi
echo "ASSET=$STAGING" >> $GITHUB_ENV
- uses: actions/upload-artifact@v4
with:
path: ${{ env.ASSET }}
name: ${{ env.ASSET }}
if-no-files-found: error
- uses: actions/upload-artifact@v4
with:
path: target/rakaly.h
name: rakaly.h
if-no-files-found: error
overwrite: true
release:
needs: test
runs-on: ubuntu-20.04
steps:
- uses: actions/checkout@v4
- uses: actions/download-artifact@v4
with:
path: artifacts-temp
- name: Flatten artifacts
run: |
mkdir artifacts
cd artifacts-temp
for i in *; do
tar czf "../artifacts/$(basename "$i").tar.gz" "$i"
done
ls -lR ../artifacts
- name: Create Release
if: github.event_name == 'push' && contains(github.ref, 'refs/tags/')
uses: actions/github-script@v7
with:
github-token: ${{secrets.GITHUB_TOKEN}}
script: |
console.log('environment', process.versions);
const fs = require('fs').promises;
const { repo: { owner, repo }, sha } = context;
console.log({ owner, repo, sha });
const tag_name = process.env.GITHUB_REF.split("/")[2];
const release = await github.rest.repos.createRelease({
owner, repo,
tag_name,
draft: false,
target_commitish: sha
});
console.log('created release', { release });
for (let file of await fs.readdir('artifacts')) {
console.log('uploading', file);
await github.rest.repos.uploadReleaseAsset({
owner, repo,
release_id: release.data.id,
name: file,
data: await fs.readFile(`artifacts/${file}`)
});
}