Skip to content

Commit

Permalink
utils: adjust Windows build to use shared LMDB
Browse files Browse the repository at this point in the history
This adjusts the build to create a shared (static) build of LMDB.
Re-order the build rules, wire up the LMDB build into IndexStoreDB and
SourceKit-LSP.
  • Loading branch information
compnerd committed Nov 18, 2024
1 parent 201edb8 commit 5319f1e
Showing 1 changed file with 21 additions and 4 deletions.
25 changes: 21 additions & 4 deletions utils/build.ps1
Original file line number Diff line number Diff line change
Expand Up @@ -449,9 +449,9 @@ enum HostComponent {
PackageManager
Markdown
Format
LMDB
IndexStoreDB
SourceKitLSP
LMDB
SymbolKit
DocC
}
Expand Down Expand Up @@ -2439,6 +2439,15 @@ function Test-Format {
}
}

function Build-LMDB($Arch) {
Build-CMakeProject `
-Src $SourceCache\swift-lmdb `
-Bin (Get-HostProjectBinaryCache LMDB) `
-Arch $Arch `
-UseMSVCCompilers C `
-BuildTargets default
}

function Build-IndexStoreDB($Arch) {
$SDKInstallRoot = (Get-HostSwiftSDK);

Expand All @@ -2454,6 +2463,7 @@ function Build-IndexStoreDB($Arch) {
BUILD_SHARED_LIBS = "NO";
CMAKE_C_FLAGS = @("-I$SDKInstallRoot\usr\include", "-I$SDKInstallRoot\usr\include\Block");
CMAKE_CXX_FLAGS = @("-I$SDKInstallRoot\usr\include", "-I$SDKInstallRoot\usr\include\Block");
LMDB_DIR = (Get-HostProjectCMakeModules LMDB);
}
}

Expand All @@ -2475,19 +2485,23 @@ function Build-SourceKitLSP($Arch) {
SwiftCrypto_DIR = (Get-HostProjectCMakeModules Crypto);
SwiftCollections_DIR = (Get-HostProjectCMakeModules Collections);
SwiftPM_DIR = (Get-HostProjectCMakeModules PackageManager);
LMDB_DIR = (Get-HostProjectCMakeModules LMDB);
IndexStoreDB_DIR = (Get-HostProjectCMakeModules IndexStoreDB);
}
}

function Test-SourceKitLSP {
$SwiftPMArguments = @(
# dispatch
"-Xcc", "-I$SourceCache\swift-corelibs-libdispatch",
"-Xcc", "-I$SourceCache\swift-corelibs-libdispatch\src\BlocksRuntime",
# swift-syntax
"-Xswiftc", "-I$(Get-HostProjectBinaryCache Compilers)\lib\swift\host",
"-Xswiftc", "-L$(Get-HostProjectBinaryCache Compilers)\lib\swift\host",
# swift-cmark
"-Xswiftc", "-I$($SourceCache)\cmark\src\include",
"-Xswiftc", "-I$($SourceCache)\cmark\extensions\include",
"-Xlinker", "-I$($SourceCache)\cmark\extensions\include",
"-Xswiftc", "-I$SourceCache\cmark\src\include",
"-Xswiftc", "-I$SourceCache\cmark\extensions\include",
"-Xlinker", "-I$SourceCache\cmark\extensions\include",
"-Xlinker", "$(Get-CMarkBinaryCache $HostArch)\src\cmark-gfm.lib",
"-Xlinker", "$(Get-CMarkBinaryCache $HostArch)\extensions\cmark-gfm-extensions.lib",
# swift-system
Expand Down Expand Up @@ -2528,6 +2542,8 @@ function Test-SourceKitLSP {
"-Xlinker", "$(Get-HostProjectBinaryCache IndexStoreDB)\lib\Index\Index.lib",
"-Xlinker", "$(Get-HostProjectBinaryCache IndexStoreDB)\lib\LLVMSupport\LLVMSupport.lib",
"-Xlinker", "$(Get-HostProjectBinaryCache IndexStoreDB)\lib\Support\Support.lib",
# LMDB
"-Xlinker", "$(Get-HostProjectBinaryCache LMDB)\lib\CLMDB.lib",
# sourcekit-lsp
"-Xswiftc", "-I$($SourceCache)\sourcekit-lsp\Sources\CAtomics\include",
"-Xswiftc", "-I$($SourceCache)\sourcekit-lsp\Sources\CSourcekitd\include",
Expand Down Expand Up @@ -2837,6 +2853,7 @@ if (-not $SkipBuild) {
Invoke-BuildStep Build-PackageManager $HostArch
Invoke-BuildStep Build-Markdown $HostArch
Invoke-BuildStep Build-Format $HostArch
Invoke-BuildStep Build-LMDB $HostArch
Invoke-BuildStep Build-IndexStoreDB $HostArch
Invoke-BuildStep Build-SourceKitLSP $HostArch
}
Expand Down

0 comments on commit 5319f1e

Please sign in to comment.