-
Notifications
You must be signed in to change notification settings - Fork 2.3k
/
build.ps1
173 lines (157 loc) · 5.48 KB
/
build.ps1
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
param(
# Debug, Release, RelWithDebInfo, MinSizeRel
[string] $BuildType = "Release",
[string] $LlvmDir = "",
[string] $ClangDir = "",
[string] $VisualStudioVersion = "",
# Install python package in user-space.
[switch] $UserSpace = $false,
# Clean up compilation intermediates instead of building Taichi. Note that
# downloaded artifacts (like LLVM and Clang) will not be removed.
[switch] $Clean = $false
)
$ErrorActionPreference = "Stop"
if ($Clean) {
& python setup.py clean
exit
}
$TempDir = "${pwd}/tmp"
$DownloadDir = "${TempDir}/download"
function EnsureDir($Dir) {
if (-not (Test-Path $Dir)) {
New-Item $Dir -ItemType Directory
}
}
function DownloadFile($Uri, $DstFileName) {
EnsureDir $TempDir
EnsureDir $DownloadDir
# Download only if the file is in absence.
$DstPath = "$DownloadDir/$DstFileName"
if (-not (Test-Path $DstPath)) {
Invoke-WebRequest -MaximumRetryCount 10 -RetryIntervalSec 5 $Uri -OutFile $DstPath
}
}
function DownloadArchiveAndExpand($Uri, $ArchiveName) {
DownloadFile $Uri "$ArchiveName.zip";
# Expand archive only if we haven't done it before.
$ExpandDir = "$TempDir/$ArchiveName";
if (-not (Test-Path $ExpandDir)) {
Expand-Archive "$DownloadDir/$ArchiveName.zip" -DestinationPath $ExpandDir
}
}
# Identify Visual Studio version.
if (-not $VisualStudioVersion) {
$VisualStudioVersion = (Get-CimInstance MSFT_VSInstance).Version.Split('.')[0]
Write-Host "Identified Visual Studio version from installation."
}
switch ($VisualStudioVersion) {
"2019" { $VisualStudioVersion = "16" }
"2022" { $VisualStudioVersion = "17" }
}
switch ($VisualStudioVersion) {
"16" {
Write-Host "Using MSVC from Visual Studio 2019."
$PrebuiltLlvmUri = "https://github.com/taichi-dev/taichi_assets/releases/download/llvm10/taichi-llvm-10.0.0-msvc2019.zip"
$LlvmArchiveName = "taichi-llvm-10.0.0-msvc2019"
}
"17" {
Write-Host "Using MSVC from Visual Studio 2022."
$PrebuiltLlvmUri = "https://github.com/taichi-dev/taichi_assets/releases/download/llvm10_msvc2022/taichi-llvm-10.0.0-msvc2022.zip"
$LlvmArchiveName = "taichi-llvm-10.0.0-msvc2022"
}
default {
Write-Error "Unsupported Visual Studio Version"
}
}
# Select build type, by default it's `Release`.
switch ($BuildType) {
"Debug" {
$env:DEBUG = 1;
$env:RELWITHDEBINFO = 0;
$env:MINSIZEREL = 0;
}
"Release" {
$env:DEBUG = 0;
$env:RELWITHDEBINFO = 0;
$env:MINSIZEREL = 0;
}
"RelWithDebInfo" {
$env:DEBUG = 0;
$env:RELWITHDEBINFO = 1;
$env:MINSIZEREL = 0;
}
"MinSizeRel" {
$env:DEBUG = 0;
$env:RELWITHDEBINFO = 0;
$env:MINSIZEREL = 1;
}
Default {
Write-Error "Unknown build type '$BuildType'"
}
}
# Prepare LLVM.
if ($env:LLVM_DIR) {
# Compatible with previous building process, where `LLVM_DIR` and
# `LLVM_AS_EXECUTABLE` are set externally.
$LlvmDir = $env:LLVM_DIR;
}
if (-not $LlvmDir) {
DownloadArchiveAndExpand -Uri $PrebuiltLlvmUri -ArchiveName $LlvmArchiveName
$LlvmDir = "$TempDir/$LlvmArchiveName"
}
if (-not $LlvmDir -or -not (Test-Path $LlvmDir)) {
throw "LLVM cannot be found in local environment and the script failed to download a prebuilt archive. " +
"Please follow the instructions at 'https://docs.taichi-lang.org/docs/dev_install' to manually configure LLVM for Taichi."
} else {
$LlvmDir = (Resolve-Path $LlvmDir).Path;
$env:LLVM_DIR = $LlvmDir
Write-Host "Using LLVM at '$LlvmDir'."
}
#Prepare Clang.
if (-not $ClangDir) {
DownloadArchiveAndExpand -Uri "https://github.com/taichi-dev/taichi_assets/releases/download/llvm10/clang-10.0.0-win.zip" -ArchiveName "taichi-clang"
$ClangDir = "$TempDir/taichi-clang"
}
if (-not $ClangDir -or -not (Test-Path $ClangDir)) {
throw "Clang cannot be found in local environment and the script failed to download a prebuilt archive. " +
"Please follow the instructions at 'https://docs.taichi-lang.org/docs/dev_install' to manually configure Clang for Taichi."
} else {
$ClangDir = (Resolve-Path $ClangDir).Path;
Write-Host "Using Clang at '$ClangDir'."
}
$CMakeArgs = @{
"CLANG_EXECUTABLE" = "$ClangDir/bin/clang++.exe";
"LLVM_AS_EXECUTABLE" = "$LlvmDir/bin/llvm-as.exe";
}
# Build Vulkan backend if Vulkan SDK is installed.
if ($env:VK_SDK_PATH) {
Write-Host "Found existing Vulkan SDK isntalltion at '$env:VK_SDK_PATH', Vulkan backend will be built."
$env:VULKAN_SDK = $env:VK_SDK_PATH;
$CMakeArgs["TI_WITH_VULKAN:BOOL"] = "ON";
}
# Chain up the cmake arguments.
Write-Host "Will build Taichi ($BuildType) with the following CMake args:"
$TaichiCMakeArgs = $env:TAICHI_CMAKE_ARGS ?? ""
foreach ($Pair in $CMakeArgs.GetEnumerator()) {
$Key = $Pair | Select-Object -ExpandProperty Key
$Value = ($Pair | Select-Object -ExpandProperty Value) -replace "\\", "/"
if (-not ($TaichiCMakeArgs.Contains("-D$Key"))) {
$TaichiCMakeArgs += " -D$Key=`"$Value`""
}
}
foreach ($arg in $TaichiCMakeArgs.Split()) {
Write-Host " $arg"
}
$env:TAICHI_CMAKE_ARGS = $TaichiCMakeArgs
# Install in userspace?
$BuildExpr = "python setup.py develop";
if ($UserSpace) {
Write-Host "Taichi Python package will be installed in user-space."
$BuildExpr += " --user"
}
Write-Host
# Do the job.
$stopwatch = [system.diagnostics.stopwatch]::startNew()
Write-Host $BuildExpr
Invoke-Expression $BuildExpr
$stopwatch.Elapsed