2017-05-25 14:33:16 +08:00
# vcpkg_from_github
2021-03-11 01:56:07 +08:00
The latest version of this document lives in the [vcpkg repo ](https://github.com/Microsoft/vcpkg/blob/master/docs/maintainers/vcpkg_from_github.md ).
2021-03-01 05:17:19 +08:00
2017-05-25 14:33:16 +08:00
Download and extract a project from GitHub. Enables support for `install --head` .
2021-11-23 07:14:23 +08:00
This also works with Gitea by specifying the Gitea server with the `GITHUB_HOST` option.
2017-05-25 14:33:16 +08:00
## Usage:
```cmake
vcpkg_from_github(
OUT_SOURCE_PATH < SOURCE_PATH >
REPO < Microsoft / cpprestsdk >
[REF < v2.0.0 > ]
[SHA512 < 45d0d7f8cc350... > ]
[HEAD_REF < master > ]
2018-08-12 13:12:18 +08:00
[PATCHES < patch1.patch > < patch2.patch > ...]
2019-11-23 02:05:39 +08:00
[GITHUB_HOST < https: / / github . com > ]
[AUTHORIZATION_TOKEN < ${SECRET_FROM_FILE}>]
2020-12-04 05:24:26 +08:00
[FILE_DISAMBIGUATOR < N > ]
2017-05-25 14:33:16 +08:00
)
```
## Parameters:
### OUT_SOURCE_PATH
Specifies the out-variable that will contain the extracted location.
This should be set to `SOURCE_PATH` by convention.
### REPO
The organization or user and repository on GitHub.
### REF
2018-08-12 13:12:18 +08:00
A stable git commit-ish (ideally a tag or commit) that will not change contents. **This should not be a branch.**
2017-10-06 08:49:28 +08:00
For repositories without official releases, this can be set to the full commit id of the current latest master.
2017-05-25 14:33:16 +08:00
If `REF` is specified, `SHA512` must also be specified.
### SHA512
The SHA512 hash that should match the archive (https://github.com/${REPO}/archive/${REF}.tar.gz).
2021-07-16 15:17:19 +08:00
This is most easily determined by first setting it to `0` , then trying to build the port. The error message will contain the full hash, which can be copied back into the portfile.
2017-05-25 14:33:16 +08:00
### HEAD_REF
The unstable git commit-ish (ideally a branch) to pull for `--head` builds.
For most projects, this should be `master` . The chosen branch should be one that is expected to be always buildable on all supported platforms.
2018-08-12 13:12:18 +08:00
### PATCHES
A list of patches to be applied to the extracted sources.
Relative paths are based on the port directory.
2019-11-23 02:05:39 +08:00
### GITHUB_HOST
A replacement host for enterprise GitHub instances.
This field should contain the scheme, host, and port of the desired URL without a trailing slash.
### AUTHORIZATION_TOKEN
A token to be passed via the Authorization HTTP header as "token ${AUTHORIZATION_TOKEN}".
2020-11-21 02:29:25 +08:00
### FILE_DISAMBIGUATOR
A token to uniquely identify the resulting filename if the SHA512 changes even though a git ref does not, to avoid stepping on the same file name.
2017-05-25 14:33:16 +08:00
## Notes:
2017-10-06 08:49:28 +08:00
At least one of `REF` and `HEAD_REF` must be specified, however it is preferable for both to be present.
2017-05-25 14:33:16 +08:00
This exports the `VCPKG_HEAD_VERSION` variable during head builds.
## Examples:
* [cpprestsdk ](https://github.com/Microsoft/vcpkg/blob/master/ports/cpprestsdk/portfile.cmake )
* [ms-gsl ](https://github.com/Microsoft/vcpkg/blob/master/ports/ms-gsl/portfile.cmake )
2021-06-05 07:48:54 +08:00
* [boost-beast ](https://github.com/Microsoft/vcpkg/blob/master/ports/boost-beast/portfile.cmake )
2017-05-25 14:33:16 +08:00
## Source
2021-03-01 05:17:19 +08:00
[scripts/cmake/vcpkg\_from\_github.cmake ](https://github.com/Microsoft/vcpkg/blob/master/scripts/cmake/vcpkg_from_github.cmake )