-
Notifications
You must be signed in to change notification settings - Fork 2
243 lines (201 loc) · 8.78 KB
/
win_cmake_build.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
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
name: Windows CMake build
on:
push:
branches: [main]
pull_request:
branches: [main]
env:
# Customize the CMake build type here (Release, Debug, RelWithDebInfo, etc.)
BUILD_TYPE: Release
BUILD_MSVC_PRESET: msvc_dev_all
BUILD_FOLDER_MSVC_DEV_ALL: _build_msvc_dev_all
BUILD_CLANG_PRESET: clang_dev_all
BUILD_FOLDER_CLANG_DEV_ALL: _build_clang_dev_all
jobs:
build_msvc:
name: MSVC single and interface Lib
# The CMake configure and build commands are platform agnostic and should work equally
# well on Windows or Mac. You can convert this to a matrix build if you need
# cross-platform coverage.
# See: https://docs.github.com/en/free-pro-team@latest/actions/learn-github-actions/managing-complex-workflows#using-a-build-matrix
runs-on: windows-2019
steps:
- uses: actions/checkout@v2
with:
submodules: true
- uses: ilammy/msvc-dev-cmd@v1
- name: Check environment
run: |
cmake --version
cl ?
clang --version
clang-tidy --version
python --version
pip --version
- name: Configure CMake
run: |
cmake --list-presets
cmake --preset=${{env.BUILD_MSVC_PRESET}}
- name: Build
# Linux has 2 cores
run: |
cmake --build --list-presets
cmake --build --preset=${{env.BUILD_MSVC_PRESET}} --config Release --parallel 2
- name: Bootstrap through CMake
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}
run: |
cmake --build . --config Release --target run_buildcc_lib_bootstrap_win_msvc --parallel 2
- name: BuildExe Layout setup
working-directory: ${{github.workspace}}/..
run: |
mkdir buildcc_home
$env:BUILDCC_HOME = "${{github.workspace}}/../buildcc_home"
$env:BUILDCC_HOME
cd buildcc_home
mkdir buildcc
mkdir libs
mkdir extensions
cd ..
dir
- name: BuildExe IM example tiny-process-library
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}
run: |
$env:BUILDCC_HOME = "${{github.workspace}}/../buildcc_home"
cmake --build . --config Release --target run_buildexe_im_tpl_win_msvc
# - name: TODO, BuildExe SM simple hyrid example
- name: CPack Release
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}
run: |
cpack -C Release -G ZIP
- name: Upload CPack
uses: actions/upload-artifact@v2
with:
name: "BuildExe_Win"
path: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}/BuildCC-0.1.1-win64.zip
- name: Install
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}
run: |
cmake --install . --config Release
- name: AfterInstall Example
working-directory: ${{github.workspace}}/example/gcc/AfterInstall
run: |
$env:Path += ";C:/Program Files (x86)/BuildCC"
cmake -B build
cmake --build build --config Release --parallel 2
cd build/Release
ls
.\build.exe
- name: Hybrid Single Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}
run: |
cmake --build . --config Release --parallel 2 --target run_hybrid_single_example
- name: Hybrid Simple Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}
run: |
cmake --build . --config Release --parallel 2 --target run_hybrid_simple_example_win
- name: Hybrid Foolib Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}
run: |
cmake --build . --config Release --parallel 2 --target run_hybrid_foolib_example_win
- name: Hybrid External Lib Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}
run: |
cmake --build . --config Release --parallel 2 --target run_hybrid_externallib_example_win
- name: Hybrid Custom Target Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}
run: |
cmake --build . --config Release --parallel 2 --target run_hybrid_customtarget_example_win
- name: Hybrid Generic Target Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}
run: |
cmake --build . --config Release --parallel 2 --target run_hybrid_generic_example
- name: Hybrid PCH Target Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}
run: |
cmake --build . --config Release --parallel 2 --target run_hybrid_pch_example_win
- name: Hybrid Dep Chaining Target Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}
run: |
cmake --build . --config Release --parallel 2 --target run_hybrid_depchaining_example_win
- name: Hybrid Target Info Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_MSVC_DEV_ALL}}
run: |
cmake --build . --config Release --parallel 2 --target run_hybrid_targetinfo_example_win
build_clang:
name: Clang single and interface Lib
# The CMake configure and build commands are platform agnostic and should work equally
# well on Windows or Mac. You can convert this to a matrix build if you need
# cross-platform coverage.
# See: https://docs.github.com/en/free-pro-team@latest/actions/learn-github-actions/managing-complex-workflows#using-a-build-matrix
runs-on: windows-2019
steps:
- uses: actions/checkout@v2
with:
submodules: true
- uses: ilammy/msvc-dev-cmd@v1
- name: Check environment
run: |
cmake --version
cl ?
clang --version
clang-tidy --version
python --version
pip --version
- name: Configure CMake
run: |
cmake --list-presets
cmake --preset=${{env.BUILD_CLANG_PRESET}}
- name: Build
# Linux has 2 cores
run: |
cmake --build --list-presets
cmake --build --preset=${{env.BUILD_CLANG_PRESET}} --parallel 2 --config Release
- name: Install
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_CLANG_DEV_ALL}}
run: |
cmake --install . --config Release
- name: AfterInstall Example
working-directory: ${{github.workspace}}/example/gcc/AfterInstall
run: |
$env:Path += ";C:/Program Files (x86)/BuildCC"
cmake -B build
cmake --build build --parallel 2 --config Release
cd build/Release
ls
.\build.exe
- name: Hybrid Single Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_CLANG_DEV_ALL}}
run: |
cmake --build . --target run_hybrid_single_example --config Release
- name: Hybrid Simple Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_CLANG_DEV_ALL}}
run: |
cmake --build . --target run_hybrid_simple_example_win --config Release
- name: Hybrid Foolib Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_CLANG_DEV_ALL}}
run: |
cmake --build . --target run_hybrid_foolib_example_win --config Release
- name: Hybrid External Lib Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_CLANG_DEV_ALL}}
run: |
cmake --build . --target run_hybrid_externallib_example_win --config Release
- name: Hybrid Custom Target Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_CLANG_DEV_ALL}}
run: |
cmake --build . --target run_hybrid_customtarget_example_win --config Release
- name: Hybrid Generic Target Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_CLANG_DEV_ALL}}
run: |
cmake --build . --target run_hybrid_generic_example --config Release
- name: Hybrid PCH Target Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_CLANG_DEV_ALL}}
run: |
cmake --build . --target run_hybrid_pch_example_win --config Release
- name: Hybrid Dep Chaining Target Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_CLANG_DEV_ALL}}
run: |
cmake --build . --target run_hybrid_depchaining_example_win --config Release
- name: Hybrid Target Info Example
working-directory: ${{github.workspace}}/${{env.BUILD_FOLDER_CLANG_DEV_ALL}}
run: |
cmake --build . --target run_hybrid_targetinfo_example_win --config Release