Przykład tworzenia pakietów repozytoriów GitHub: libogg
Tworzenie pliku manifestu
Plik manifestu (o nazwie vcpkg.json
) to plik json opisujący metadane pakietu.
W przypadku biblioteki libogg utworzymy plik ports/libogg/vcpkg.json
z następującą zawartością:
{
"name": "libogg",
"version-string": "1.3.3",
"description": "Ogg is a multimedia container format, and the native file and stream format for the Xiph.org multimedia codecs.",
"homepage": "https://www.xiph.org/ogg/"
}
Plik manifestu można sformatować do naszych specyfikacji za pomocą polecenia vcpkg format-manifest ports/libogg/vcpkg.json
.
Tworzenie pliku portów
portfile.cmake
Opisuje sposób kompilowania i instalowania pakietu. Najpierw pobierzemy projekt z usługi GitHub za pomocą polecenia vcpkg_from_github
:
vcpkg_from_github(
OUT_SOURCE_PATH SOURCE_PATH
REPO xiph/ogg
REF v1.3.3
SHA512 0bd6095d647530d4cb1f509eb5e99965a25cc3dd9b8125b93abd6b248255c890cf20710154bdec40568478eb5c4cde724abfb2eff1f3a04e63acef0fbbc9799b
HEAD_REF master
)
Ważne elementy do aktualizacji dotyczą REPO
ścieżki repozytorium GitHub, REF
stabilnego tagu/zatwierdzenia do użycia oraz SHA512
sumy kontrolnej pobranego pliku (można to łatwo uzyskać, ustawiając go na 0
, próbując zainstalować pakiet i kopiując sumę kontrolną).
Na koniec skonfigurujemy projekt za pomocą narzędzia CMake, zainstalujemy pakiet i skopiujemy plik licencji:
vcpkg_cmake_configure(SOURCE_PATH ${SOURCE_PATH})
vcpkg_cmake_install()
vcpkg_install_copyright("${SOURCE_PATH}/COPYING")
Zapoznaj się z dokumentacją vcpkg_cmake_configure
i vcpkg_cmake_install
jeśli pakiet wymaga dodatkowych opcji.
Teraz możesz uruchomić polecenie vcpkg install libogg
, aby skompilować i zainstalować pakiet.
Sugerowane przykładowe pliki portów
W katalogu jest wiele bibliotek, które mogą być używane jako przykłady, w tym wiele, które nie są oparte na narzędziu ports/
CMake.
- Biblioteki tylko nagłówków
- rapidjson
- range-v3
- Oparty na programie MSBuild
- chakracore
- Nienależący do narzędzia CMake, niestandardowy system kompilacji
- openssl
- ffmpeg