mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-06 05:40:54 -06:00
Merge topic 'cpack-custom-dmg-names'
6d6f4b9316CPack/DragNDrop: Support CPACK_DMG_<component>_FILE_NAMEb53230fbeeTests: Add DragNDrop as a testable CPack generator Acked-by: Kitware Robot <kwrobot@kitware.com> Merge-request: !4227
This commit is contained in:
@@ -81,6 +81,13 @@ on macOS:
|
||||
``<language>.menu.txt`` and ``<language>.license.txt`` in the directory
|
||||
specified by the :variable:`CPACK_DMG_SLA_DIR` variable.
|
||||
|
||||
.. variable:: CPACK_DMG_<component>_FILE_NAME
|
||||
|
||||
File name when packaging ``<component>`` as its own DMG
|
||||
(``CPACK_COMPONENTS_GROUPING`` set to IGNORE).
|
||||
|
||||
- Default: ``CPACK_PACKAGE_FILE_NAME-<component>``
|
||||
|
||||
.. variable:: CPACK_COMMAND_HDIUTIL
|
||||
|
||||
Path to the ``hdiutil(1)`` command used to operate on disk image files on
|
||||
|
||||
7
Help/release/dev/custom-dmg-names.rst
Normal file
7
Help/release/dev/custom-dmg-names.rst
Normal file
@@ -0,0 +1,7 @@
|
||||
custom-dmg-names
|
||||
----------------
|
||||
|
||||
* The :cpack_gen:`CPack DragNDrop Generator` learned to use
|
||||
the :variable:`CPACK_DMG_<component>_FILE_NAME` variable
|
||||
to set a custom filename when packaging components into
|
||||
their own DMGs.
|
||||
@@ -775,6 +775,11 @@ std::string cmCPackDragNDropGenerator::GetComponentInstallDirNameSuffix(
|
||||
}
|
||||
}
|
||||
|
||||
std::string componentFileName =
|
||||
"CPACK_DMG_" + cmSystemTools::UpperCase(componentName) + "_FILE_NAME";
|
||||
if (this->IsSet(componentFileName)) {
|
||||
return this->GetOption(componentFileName);
|
||||
}
|
||||
return GetComponentPackageFileName(package_file_name, componentName, false);
|
||||
}
|
||||
|
||||
|
||||
@@ -604,6 +604,9 @@ set(cpack_tests
|
||||
STGZ
|
||||
External
|
||||
)
|
||||
if(APPLE)
|
||||
list(APPEND cpack_tests DragNDrop)
|
||||
endif()
|
||||
add_RunCMake_test_group(CPack "${cpack_tests}")
|
||||
# add a test to make sure symbols are exported from a shared library
|
||||
# for MSVC compilers CMAKE_WINDOWS_EXPORT_ALL_SYMBOLS property is used
|
||||
|
||||
54
Tests/RunCMake/CPack/DragNDrop/Helpers.cmake
Normal file
54
Tests/RunCMake/CPack/DragNDrop/Helpers.cmake
Normal file
@@ -0,0 +1,54 @@
|
||||
set(ALL_FILES_GLOB "*.dmg")
|
||||
|
||||
function(getPackageContent FILE RESULT_VAR)
|
||||
get_filename_component(path_ "${FILE}" DIRECTORY)
|
||||
file(REMOVE_RECURSE "${path_}/content")
|
||||
file(MAKE_DIRECTORY "${path_}/content")
|
||||
execute_process(COMMAND ${HDIUTIL_EXECUTABLE} attach -mountroot ${path_}/content -nobrowse ${FILE}
|
||||
RESULT_VARIABLE attach_result_
|
||||
ERROR_VARIABLE attach_error_
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
||||
|
||||
if(attach_result_)
|
||||
message(FATAL_ERROR "Failed to attach DMG: '${attach_result_}';"
|
||||
" '${attach_error_}'.")
|
||||
endif()
|
||||
|
||||
file(GLOB_RECURSE package_content_ LIST_DIRECTORIES true RELATIVE
|
||||
"${path_}/content" "${path_}/content/*")
|
||||
# Some versions of macOS have .Trashes, others do not.
|
||||
list(FILTER package_content_ EXCLUDE REGEX "/.Trashes$")
|
||||
set(${RESULT_VAR} "${package_content_}" PARENT_SCOPE)
|
||||
|
||||
execute_process(COMMAND ${HDIUTIL_EXECUTABLE} detach ${path_}/content/volume-name
|
||||
RESULT_VARIABLE detach_result_
|
||||
ERROR_VARIABLE detach_error_
|
||||
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
||||
|
||||
if(detach_result_)
|
||||
message(FATAL_ERROR "Failed to detach DMG: '${detach_result_}';"
|
||||
" '${detach_error_}'.")
|
||||
endif()
|
||||
endfunction()
|
||||
|
||||
function(getPackageNameGlobexpr NAME COMPONENT VERSION REVISION FILE_NO RESULT_VAR)
|
||||
if(COMPONENT)
|
||||
set(COMPONENT "-${COMPONENT}")
|
||||
endif()
|
||||
|
||||
set(${RESULT_VAR} "${NAME}-${VERSION}-Darwin${COMPONENT}.dmg" PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
||||
function(getPackageContentList FILE RESULT_VAR)
|
||||
getPackageContent("${FILE}" package_content_)
|
||||
|
||||
set(${RESULT_VAR} "${package_content_}" PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
||||
function(toExpectedContentList FILE_NO CONTENT_VAR)
|
||||
set(prefix_ "volume-name")
|
||||
list(TRANSFORM ${CONTENT_VAR} PREPEND "${prefix_}" OUTPUT_VARIABLE prepared_)
|
||||
list(APPEND prepared_ "${prefix_}")
|
||||
|
||||
set(${CONTENT_VAR} "${prepared_}" PARENT_SCOPE)
|
||||
endfunction()
|
||||
8
Tests/RunCMake/CPack/DragNDrop/Prerequirements.cmake
Normal file
8
Tests/RunCMake/CPack/DragNDrop/Prerequirements.cmake
Normal file
@@ -0,0 +1,8 @@
|
||||
function(get_test_prerequirements found_var config_file)
|
||||
find_program(HDIUTIL_EXECUTABLE hdiutil)
|
||||
|
||||
if(HDIUTIL_EXECUTABLE)
|
||||
file(WRITE "${config_file}" "set(HDIUTIL_EXECUTABLE \"${HDIUTIL_EXECUTABLE}\")")
|
||||
set(${found_var} true PARENT_SCOPE)
|
||||
endif()
|
||||
endfunction()
|
||||
@@ -0,0 +1,3 @@
|
||||
set(CPACK_COMPONENTS_GROUPING "IGNORE")
|
||||
set(CPACK_DMG_DISABLE_APPLICATIONS_SYMLINK ON)
|
||||
set(CPACK_DMG_VOLUME_NAME "volume-name")
|
||||
@@ -5,7 +5,7 @@ include("${RunCMake_SOURCE_DIR}/CPackTestHelpers.cmake")
|
||||
|
||||
# run_cpack_test args: TEST_NAME "GENERATORS" RUN_CMAKE_BUILD_STEP "PACKAGING_TYPES"
|
||||
run_cpack_test(CUSTOM_BINARY_SPEC_FILE "RPM.CUSTOM_BINARY_SPEC_FILE" false "MONOLITHIC;COMPONENT")
|
||||
run_cpack_test(CUSTOM_NAMES "RPM.CUSTOM_NAMES;DEB.CUSTOM_NAMES;TGZ" true "COMPONENT")
|
||||
run_cpack_test(CUSTOM_NAMES "RPM.CUSTOM_NAMES;DEB.CUSTOM_NAMES;TGZ;DragNDrop" true "COMPONENT")
|
||||
run_cpack_test(DEBUGINFO "RPM.DEBUGINFO;DEB.DEBUGINFO" true "COMPONENT")
|
||||
run_cpack_test_subtests(DEFAULT_PERMISSIONS "CMAKE_var_set;CPACK_var_set;both_set;invalid_CMAKE_var;invalid_CPACK_var" "RPM.DEFAULT_PERMISSIONS;DEB.DEFAULT_PERMISSIONS" false "MONOLITHIC;COMPONENT")
|
||||
run_cpack_test(DEPENDENCIES "RPM.DEPENDENCIES;DEB.DEPENDENCIES" true "COMPONENT")
|
||||
|
||||
@@ -12,4 +12,7 @@ if(GENERATOR_TYPE STREQUAL "DEB" OR GENERATOR_TYPE STREQUAL "RPM")
|
||||
elseif(GENERATOR_TYPE STREQUAL "TGZ")
|
||||
set(EXPECTED_FILE_2 "second.tar.gz")
|
||||
set(EXPECTED_FILE_3 "pkg_3_abc.tar.gz")
|
||||
elseif(GENERATOR_TYPE STREQUAL "DragNDrop")
|
||||
set(EXPECTED_FILE_2 "second.dmg")
|
||||
set(EXPECTED_FILE_3 "pkg_3_abc.dmg")
|
||||
endif()
|
||||
|
||||
@@ -10,6 +10,9 @@ if(GENERATOR_TYPE STREQUAL "DEB" OR GENERATOR_TYPE STREQUAL "RPM")
|
||||
elseif(GENERATOR_TYPE STREQUAL "TGZ")
|
||||
set(CPACK_ARCHIVE_PKG_2_FILE_NAME "second")
|
||||
set(CPACK_ARCHIVE_PKG_3_FILE_NAME "pkg_3_abc")
|
||||
elseif(GENERATOR_TYPE STREQUAL "DragNDrop")
|
||||
set(CPACK_DMG_PKG_2_FILE_NAME "second")
|
||||
set(CPACK_DMG_PKG_3_FILE_NAME "pkg_3_abc")
|
||||
endif()
|
||||
|
||||
install(FILES CMakeLists.txt DESTINATION foo COMPONENT pkg_1)
|
||||
|
||||
Reference in New Issue
Block a user