2017-05-24 23:33:16 -07: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-02-28 13:17:19 -08:00
2017-05-24 23:33:16 -07:00
Download and extract a project from GitHub. Enables support for `install --head` .
2021-11-22 17:14:23 -06:00
This also works with Gitea by specifying the Gitea server with the `GITHUB_HOST` option.
2017-05-24 23:33:16 -07: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-11 22:12:18 -07:00
[PATCHES < patch1.patch > < patch2.patch > ...]
2019-11-22 10:05:39 -08:00
[GITHUB_HOST < https: / / github . com > ]
[AUTHORIZATION_TOKEN < ${SECRET_FROM_FILE}>]
2020-12-03 13:24:26 -08:00
[FILE_DISAMBIGUATOR < N > ]
2017-05-24 23:33:16 -07: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-11 22:12:18 -07:00
A stable git commit-ish (ideally a tag or commit) that will not change contents. **This should not be a branch.**
2017-10-05 17:49:28 -07:00
For repositories without official releases, this can be set to the full commit id of the current latest master.
2017-05-24 23:33:16 -07: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 00:17:19 -07: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-24 23:33:16 -07: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-11 22:12:18 -07:00
### PATCHES
A list of patches to be applied to the extracted sources.
Relative paths are based on the port directory.
2019-11-22 10: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-20 10: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-24 23:33:16 -07:00
## Notes:
2017-10-05 17:49:28 -07:00
At least one of `REF` and `HEAD_REF` must be specified, however it is preferable for both to be present.
2017-05-24 23:33:16 -07: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 05:18:54 +05:30
* [boost-beast ](https://github.com/Microsoft/vcpkg/blob/master/ports/boost-beast/portfile.cmake )
2017-05-24 23:33:16 -07:00
## Source
2021-02-28 13:17:19 -08:00
[scripts/cmake/vcpkg\_from\_github.cmake ](https://github.com/Microsoft/vcpkg/blob/master/scripts/cmake/vcpkg_from_github.cmake )