The latest version of this document lives in the vcpkg repo.
Extract an archive.
vcpkg_extract_source_archive(
<out-var>
ARCHIVE <path>
[NO_REMOVE_ONE_LEVEL]
[SKIP_PATCH_CHECK]
[PATCHES <patch>...]
[REF <ref>]
[SOURCE_BASE <base>]
[BASE_DIRECTORY <relative-path> | WORKING_DIRECTORY <absolute-path>]
)
Name of the variable to set with the directory containing the extracted contents.
Full path to the archive to extract.
Skip removing the top level directory of the archive.
Most archives contain a single top-level directory, such as:
zlib-1.2.11/
doc/
...
examples/
...
ChangeLog
CMakeLists.txt
README
zlib.h
...
By default, vcpkg_extract_source_archive
removes this directory and moves all contents into the directory returned in <out-var>
. If there is no top-level directory, it is an error.
With this flag, the top-level directory will be preserved and it is not an error to not have one.
Silence and ignore errors when applying patches.
This option should only be passed when operating in an unstable mode like --head
. If the sources are pinned, failing to apply a patch should be considered a fatal error.
List of patches to apply to the extracted source.
Patches will be applied in order, after any top-level directories are removed (see NO_REMOVE_ONE_LEVEL
). Relative paths are interpreted relative to the current port directory.
If a patch should be conditionally applied based on target information, you can construct a list and splat it.
set(patches "")
if(VCPKG_TARGET_IS_WINDOWS)
list(APPEND patches only-windows.patch)
endif()
vcpkg_extract_source_archive(src
ARCHIVE "${archive}"
PATCHES
always-applied.patch
${patches}
)
Pretty name for the extracted directory.
Forward slashes (/
) will be replaced with -
. Otherwise identical to SOURCE_BASE
.
See WORKING_DIRECTORY
for more details.
Pretty name for the extracted directory.
Must not contain path separators (/
or \\
).
See WORKING_DIRECTORY
for more details.
Root subfolder for the extracted directory.
Defaults to src
. Must be a relative path.
See WORKING_DIRECTORY
for more details.
Root folder for the extracted directory.
Defaults to ${CURRENT_BUILDTREES_DIR}/<BASE_DIRECTORY>
. Must be an absolute path.
vcpkg_extract_source_archive
extracts the archive into <WORKING_DIRECTORY>/<SOURCE_BASE>-<short-hash>.clean
. If the folder exists, it is deleted before extraction. Without specifying REF
, SOURCE_BASE
, BASE_DIRECTORY
, or WORKING_DIRECTORY
, this will default to ${CURRENT_BUILDTREES_DIR}/src/<archive-stem>-<short-hash>.clean
.
In --editable
mode:
- No
.clean
suffix is added to the extracted folder - The extracted folder is not deleted. If it exists,
vcpkg_extract_source_archive
does nothing.
vcpkg_download_distfile(
archive # "archive" is set to the path to the downloaded file
URLS "https://nmap.org/dist/nmap-7.70.tar.bz2"
FILENAME "nmap-7.70.tar.bz2"
SHA512 084c148b022ff6550e269d976d0077f7932a10e2ef218236fe13aa3a70b4eb6506df03329868fc68cb3ce78e4360b200f5a7a491d3145028fed679ef1c9ecae5
)
vcpkg_extract_source_archive(
src # "src" is set to the path to the extracted files
ARCHIVE "${archive}"
REF 7.70
PATCHES 0001-disable-werror.patch
)
vcpkg_cmake_configure(SOURCE_PATH "${src}")
Deprecated Syntax
This command also supports a deprecated overload:
vcpkg_extract_source_archive(<archive> [<working_directory>])
The deprecated overload extracts <archive>
into ${working_directory}/<archive-filename>.extracted
if the target does not exist. This incorrect behavior allows patches and other modifications to leak between different builds, resulting in hard-to-debug errors.
All uses of the deprecated overload should be replaced with the syntax in Usage above by adding an explicit ARCHIVE
parameter and replacing direct references to the extracted path with uses of the <out-var>
.
Replacement
This command replaces vcpkg_extract_source_archive_ex()
.