オーバーレイトリプレットの使用
Linux での動的ライブラリの構築
vcpkg を使用すると、多くの構成のライブラリをすぐにビルドできます。 ただし、現時点では、Linux および Mac OS 上の共有ライブラリは含まれていません。
これは、vcpkg を使用してこれらのプラットフォームで動的ライブラリをビルドできないことを意味するものではありません。 このドキュメントでは、Linux で動的ライブラリを簡単に構築するための独自のカスタム トリプレット --overlay-triplets
を作成する方法について説明します。
手順 1: カスタムトリプレット ファイルを作成する
時間を節約するには、既存 x64-linux.cmake
のトリプレット ファイルをコピーします。
~/git$ mkdir custom-triplets
~/git$ cp vcpkg/triplets/x64-linux.cmake custom-triplets/x64-linux-dynamic.cmake
次の内容に一致するように変更 custom-triplets/x64-linux-dynamic.cmake
します。
# ~/git/custom-triplets/x64-linux-dynamic.cmake
set(VCPKG_TARGET_ARCHITECTURE x64)
set(VCPKG_CRT_LINKAGE dynamic)
set(VCPKG_LIBRARY_LINKAGE dynamic) # This changed from static to dynamic
set(VCPKG_CMAKE_SYSTEM_NAME Linux)
手順 2: 動的ライブラリの構築に使用 --overlay-triplets
する
このオプションを --overlay-triplets
使用して、ディレクトリにトリプレットを custom-triplets
含めます。
~/git$ vcpkg/vcpkg install sqlite3:x64-linux-dynamic --overlay-triplets=custom-triplets
The following packages will be built and installed:
sqlite3[core]:x64-linux-dynamic
Starting package 1/1: sqlite3:x64-linux-dynamic
Building package sqlite3[core]:x64-linux-dynamic...
-- Loading triplet configuration from: /home/victor/git/custom-triplets/x64-linux-dynamic.cmake
-- Downloading https://sqlite.org/2019/sqlite-amalgamation-3280000.zip...
-- Extracting source /home/victor/git/vcpkg/downloads/sqlite-amalgamation-3280000.zip
-- Applying patch fix-arm-uwp.patch
-- Using source at /home/victor/git/vcpkg/buildtrees/sqlite3/src/3280000-6a3ff7ce92
-- Configuring x64-linux-dynamic-dbg
-- Configuring x64-linux-dynamic-rel
-- Building x64-linux-dynamic-dbg
-- Building x64-linux-dynamic-rel
-- Performing post-build validation
-- Performing post-build validation done
Building package sqlite3[core]:x64-linux-dynamic... done
Installing package sqlite3[core]:x64-linux-dynamic...
Installing package sqlite3[core]:x64-linux-dynamic... done
Elapsed time for package sqlite3:x64-linux-dynamic: 44.82 s
Total elapsed time: 44.82 s
The package sqlite3:x64-linux-dynamic provides CMake targets:
find_package(unofficial-sqlite3 CONFIG REQUIRED)
target_link_libraries(main PRIVATE unofficial::sqlite3::sqlite3)
オーバーレイトリプレットを使用すると、カスタムトリプレットファイルを有効vcpkg install
にします。 vcpkg update
vcpkg upgrade
vcpkg remove
このオプションを --overlay-triplets
使用すると、次のようなメッセージで、カスタムトリプレットが使用されていることを知らせます。
-- Loading triplet configuration from: /home/custom-triplets/x64-linux-dynamic.cmake
既定のトリプレットのオーバーライド
お気付きかもしれませんが、Windows (x86-windows
および) の既定のトリプレットは動的ライブラリをインストールします x64-windows
が、静的ライブラリにはサフィックス (-static
) が必要です。 これは、静的ライブラリがビルド x64-linux
される Linux および Mac OS とは x64-osx
異なります。
これを使用すると --overlay-triplets
、既定のトリプレットをオーバーライドして、Linux で同じ動作を実現できます。
x64-linux
: 動的ライブラリをビルドします。x64-linux-static
: 静的ライブラリをビルドします。
手順 1: オーバーレイトリプレットを作成する
前の例で作成したカスタム トリプレットを使用して、名前 custom-triplets/x64-linux-dynamic.cmake
を custom-triplets/x64-linux.cmake
. 次に、フォルダー内の既定 x64-linux
のトリプレット (静的ライブラリをビルドする) を custom-triplets
コピーし、名前を > に変更します x64-linux-static.cmake
。
~/git$ mv custom-triplets/x64-linux-dynamic.cmake custom-triplets/x64-linux.cmake
~/git$ cp vcpkg/triplets/x64-linux.cmake custom-triplets/x64-linux-static.cmake
手順 2: 既定のトリプレットをオーバーライドするために使用 --overlay-triplets
する
このオプションを --overlay-triplets
使用して、ディレクトリにトリプレットを custom-triplets
含めます。
~/git$ vcpkg/vcpkg install sqlite3:x64-linux --overlay-triplets=custom-triplets
The following packages will be built and installed:
sqlite3[core]:x64-linux
Starting package 1/1: sqlite3:x64-linux
Building package sqlite3[core]:x64-linux...
-- Loading triplet configuration from: /home/victor/git/custom-triplets/x64-linux.cmake
-- Downloading https://sqlite.org/2019/sqlite-amalgamation-3280000.zip...
-- Extracting source /home/victor/git/vcpkg/downloads/sqlite-amalgamation-3280000.zip
-- Applying patch fix-arm-uwp.patch
-- Using source at /home/victor/git/vcpkg/buildtrees/sqlite3/src/3280000-6a3ff7ce92
-- Configuring x64-linux-dbg
-- Configuring x64-linux-rel
-- Building x64-linux-dbg
-- Building x64-linux-rel
-- Performing post-build validation
-- Performing post-build validation done
Building package sqlite3[core]:x64-linux... done
Installing package sqlite3[core]:x64-linux...
Installing package sqlite3[core]:x64-linux... done
Elapsed time for package sqlite3:x64-linux: 44.82 s
Total elapsed time: 44.82 s
The package sqlite3:x64-linux provides CMake targets:
find_package(unofficial-sqlite3 CONFIG REQUIRED)
target_link_libraries(main PRIVATE unofficial::sqlite3::sqlite3)
既定のトリプレットは、カスタム トリプレットによってマスクされます。
-- Loading triplet configuration from: /home/victor/git/custom-triplets/x64-linux.cmake
vcpkg