Uso di triplette sovrapposte
Compilazione di librerie dinamiche in Linux
Usando vcpkg è possibile compilare librerie per molte configurazioni predefinite. Tuttavia, questo non include attualmente librerie condivise in Linux e Mac OS.
Questo non significa che non è possibile usare vcpkg per compilare le librerie dinamiche in queste piattaforme. Questo documento illustra come creare triplette personalizzate con --overlay-triplets
per creare facilmente librerie dinamiche in Linux.
Passaggio 1: Creare i file triplet personalizzati
Per risparmiare tempo, copiare il file triplet esistente x64-linux.cmake
.
~/git$ mkdir custom-triplets
~/git$ cp vcpkg/triplets/x64-linux.cmake custom-triplets/x64-linux-dynamic.cmake
Modificare custom-triplets/x64-linux-dynamic.cmake
in modo che corrisponda al contenuto seguente:
# ~/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)
Passaggio 2: Usare --overlay-triplets
per creare librerie dinamiche
Usare l'opzione --overlay-triplets
per includere le triplette nella custom-triplets
directory.
~/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)
I tripli sovrapposti abilitano i file triplette personalizzati quando si usano vcpkg install
, vcpkg update
vcpkg upgrade
, e vcpkg remove
.
Quando si usa l'opzione --overlay-triplets
, un messaggio simile al seguente consente di sapere che viene usato un tripletto personalizzato:
-- Loading triplet configuration from: /home/custom-triplets/x64-linux-dynamic.cmake
Override delle triplette predefinite
Come si può notare, i tripletti predefiniti per Windows (x86-windows
e x64-windows
) installano librerie dinamiche, mentre per le librerie statiche è necessario un suffisso (-static
). Questo è diverso con Linux e Mac OS in cui le librerie statiche vengono compilate da x64-linux
e x64-osx
.
L'uso --overlay-triplets
di è possibile eseguire l'override delle triplette predefinite per eseguire lo stesso comportamento in Linux:
x64-linux
: compila librerie dinamiche,x64-linux-static
: compila librerie statiche.
Passaggio 1: Creare le triplette sovrapposte
Usando il tripletto personalizzato creato nell'esempio precedente, rinominare custom-triplets/x64-linux-dynamic.cmake
custom-triplets/x64-linux.cmake
in . Copiare quindi il tripletto predefinito x64-linux
(che compila librerie statiche) nella custom-triplets
cartella e rinominarlo in 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
Passaggio 2: Usare --overlay-triplets
per eseguire l'override delle triplette predefinite
Usare l'opzione --overlay-triplets
per includere le triplette nella custom-triplets
directory.
~/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)
Il tripletto predefinito è mascherato dal triplo personalizzato:
-- Loading triplet configuration from: /home/victor/git/custom-triplets/x64-linux.cmake