2017-05-24 23:33:16 -07:00
## # vcpkg_extract_source_archive
##
2018-11-22 14:48:18 -08:00
## Extract an archive into the source directory. Deprecated in favor of [`vcpkg_extract_source_archive_ex`](vcpkg_extract_source_archive_ex.md).
2017-05-24 23:33:16 -07:00
##
## ## Usage
## ```cmake
## vcpkg_extract_source_archive(
## <${ARCHIVE}> [<${TARGET_DIRECTORY}>]
## )
## ```
## ## Parameters
## ### ARCHIVE
## The full path to the archive to be extracted.
##
## This is usually obtained from calling [`vcpkg_download_distfile`](vcpkg_download_distfile.md).
##
## ### TARGET_DIRECTORY
## If specified, the archive will be extracted into the target directory instead of `${CURRENT_BUILDTREES_DIR}\src\`.
##
## This can be used to mimic git submodules, by extracting into a subdirectory of another archive.
##
## ## Notes
## This command will also create a tracking file named <FILENAME>.extracted in the TARGET_DIRECTORY. This file, when present, will suppress the extraction of the archive.
##
## ## Examples
##
## * [libraw](https://github.com/Microsoft/vcpkg/blob/master/ports/libraw/portfile.cmake)
## * [protobuf](https://github.com/Microsoft/vcpkg/blob/master/ports/protobuf/portfile.cmake)
## * [msgpack](https://github.com/Microsoft/vcpkg/blob/master/ports/msgpack/portfile.cmake)
2016-09-18 20:50:08 -07:00
include ( vcpkg_execute_required_process )
2018-09-04 19:20:46 -04:00
function ( vcpkg_extract_source_archive ARCHIVE )
if ( NOT ARGC EQUAL 2 )
set ( WORKING_DIRECTORY "${CURRENT_BUILDTREES_DIR}/src" )
2016-09-29 08:27:12 -07:00
else ( )
2018-09-04 19:20:46 -04:00
set ( WORKING_DIRECTORY ${ ARGV1 } )
2016-09-29 08:27:12 -07:00
endif ( )
2018-09-04 16:51:01 -07:00
get_filename_component ( ARCHIVE_FILENAME "${ARCHIVE}" NAME )
2016-09-29 08:27:12 -07:00
if ( NOT EXISTS ${ WORKING_DIRECTORY } / ${ ARCHIVE_FILENAME } .extracted )
2018-09-04 19:20:46 -04:00
message ( STATUS "Extracting source ${ARCHIVE}" )
2016-09-29 08:27:12 -07:00
file ( MAKE_DIRECTORY ${ WORKING_DIRECTORY } )
2016-09-18 20:50:08 -07:00
vcpkg_execute_required_process (
2018-09-04 19:20:46 -04:00
C O M M A N D $ { C M A K E _ C O M M A N D } - E t a r x j f $ { A R C H I V E }
2016-09-29 08:27:12 -07:00
W O R K I N G _ D I R E C T O R Y $ { W O R K I N G _ D I R E C T O R Y }
2016-09-18 20:50:08 -07:00
L O G N A M E e x t r a c t
)
2016-09-29 08:27:12 -07:00
file ( WRITE ${ WORKING_DIRECTORY } / ${ ARCHIVE_FILENAME } .extracted )
2016-09-18 20:50:08 -07:00
endif ( )
endfunction ( )