2018-11-16 11:24:19 +00:00
## Packaging Github Repos Example: libogg
2020-09-14 15:07:02 -07:00
### Create the manifest file
The manifest file (called `vcpkg.json` ) is a json file describing the package's metadata.
For libogg, we'll create the file `ports/libogg/vcpkg.json` with the following content:
```json
{
"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."
}
2018-11-16 11:24:19 +00:00
```
2020-09-14 15:07:02 -07:00
You can format the manifest file to our specifications with `vcpkg format-manifest ports/libogg/vcpkg.json` .
2018-11-16 11:24:19 +00:00
### Create the portfile
2019-12-16 16:15:01 -08:00
`portfile.cmake` describes how to build and install the package. First we download the project from Github with [`vcpkg_from_github` ](../maintainers/vcpkg_from_github.md ):
2018-11-16 11:24:19 +00:00
2020-09-14 15:07:02 -07:00
```cmake
2018-11-16 11:24:19 +00:00
vcpkg_from_github(
OUT_SOURCE_PATH SOURCE_PATH
REPO xiph/ogg
REF v1.3.3
SHA512 0bd6095d647530d4cb1f509eb5e99965a25cc3dd9b8125b93abd6b248255c890cf20710154bdec40568478eb5c4cde724abfb2eff1f3a04e63acef0fbbc9799b
HEAD_REF master
)
```
2021-06-16 01:14:40 +08:00
The important parts to update are `REPO` for the GitHub repository path, `REF` for a stable tag/commit to use, and `SHA512` with the checksum of the downloaded zipfile (you can get this easily by setting it to `0` , trying to install the package, and copying the checksum).
2018-11-16 11:24:19 +00:00
Finally, we configure the project with CMake, install the package, and copy over the license file:
2020-09-14 15:07:02 -07:00
```cmake
2022-02-18 02:08:33 +01:00
vcpkg_cmake_configure(SOURCE_PATH ${SOURCE_PATH})
vcpkg_cmake_install()
file(INSTALL "${SOURCE_PATH}/COPYING" DESTINATION "${CURRENT_PACKAGES_DIR}/share/libogg" RENAME copyright)
2018-11-16 11:24:19 +00:00
```
2022-08-16 15:51:42 -07:00
Check the documentation for [`vcpkg_cmake_configure` ](../maintainers/vcpkg_cmake_configure.md ) and [`vcpkg_cmake_install` ](../maintainers/vcpkg_cmake_install.md ) if your package needs additional options.
2018-11-16 11:24:19 +00:00
Now you can run `vcpkg install libogg` to build and install the package.
### Suggested example portfiles
2020-09-14 15:07:02 -07:00
In the `ports/` directory are many libraries that can be used as examples, including many that are not based on CMake.
2018-11-16 11:24:19 +00:00
- Header only libraries
2020-09-14 15:07:02 -07:00
- rapidjson
- range-v3
2018-11-16 11:24:19 +00:00
- MSBuild-based
2020-09-14 15:07:02 -07:00
- mpg123
2018-11-16 11:24:19 +00:00
- Non-CMake, custom buildsystem
2020-09-14 15:07:02 -07:00
- openssl
- ffmpeg