Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Complete initial implementation for treating internal packages as external found with find_package() (#63) #560

Merged
merged 49 commits into from
Mar 29, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
49 commits
Select commit Hold shift + click to select a range
ccb222a
Add printing of <Package>_PACAKGE_BUILD_STATUS (#63)
bartlettroscoe Dec 22, 2022
afcea28
Add documentation for <Package>_SUBPACKAGES varaible (#63)
bartlettroscoe Jan 12, 2023
ee5f2ce
Small doc update (#63)
bartlettroscoe Jan 13, 2023
0fc3973
Change tribits_print_prefix_string_and_list() to pass in list name (#63)
bartlettroscoe Jan 17, 2023
f3f9356
WIP: Add basic logic for setting <Package>_PACKAGE_BUILD_STATUS=EXTER…
bartlettroscoe Jan 24, 2023
09e61e5
WIP: rename some local vars away from UPPPER-CASE (#63)
bartlettroscoe Jan 18, 2023
5648cf7
WIP: Replace bool arg includeEmpty with enum arg enableEmptyStatus (#63)
bartlettroscoe Jan 18, 2023
abd846a
WIP: Small doc and format changes (#63)
bartlettroscoe Jan 18, 2023
cc8d5b7
WIP: Add internalOrExternal arg to tribits_print_packages_list_enable…
bartlettroscoe Jan 19, 2023
f85cc17
WIP: Change name from TribitsGetEnabledSublists.cmake to TribitsPacka…
bartlettroscoe Jan 19, 2023
e30b5bf
WIP: Change printing of package set lists based in INTERNAL/EXTERNAL …
bartlettroscoe Jan 20, 2023
e14b0d2
WIP: Add printing of Final set of [non-]enabled top-level external pa…
bartlettroscoe Jan 20, 2023
864ad9f
Factor out tribits_filter_package_list_from_var() (#63)
bartlettroscoe Jan 20, 2023
7ab3809
MockTrilinos: Set <Project>_TRACE_DEPENDENCY_HANDLING_ONLY=ON (#63)
bartlettroscoe Jan 21, 2023
aaec210
WIP: Adjust processing of internal and external packages (#63)
bartlettroscoe Jan 21, 2023
b9b4567
Finish basic implentation for building against external packages (#63)
bartlettroscoe Jan 24, 2023
33902f7
Process TPLs at base project level, pass info through <Package>Config…
bartlettroscoe Jan 27, 2023
a2790c8
Make WrapExernal work with external TribitsExProj packages (#63)
bartlettroscoe Jan 25, 2023
3065298
Add option <Project>_SKIP_INSTALL_PROJECT_CMAKE_CONFIG_FILES (#63)
bartlettroscoe Jan 25, 2023
aa843a4
WIP: Rename TribitsProcessEnabledTpl.cmake to TribitsProcessEnabledTp…
bartlettroscoe Jan 27, 2023
8e112e0
Add basic special handling for fully TriBITS-compliant external packa…
bartlettroscoe Jan 26, 2023
56b0845
WIP: Add initial failing test case for stagged package installs (#63)
bartlettroscoe Jan 27, 2023
cddd9f1
Initial implementation of pre-building/pre-installing stages of packa…
bartlettroscoe Jan 27, 2023
0c959bb
Revise how internal and external <Package>Config.cmake files are link…
bartlettroscoe Jan 28, 2023
2075dd6
WIP: Improve names of functions and variables (#63)
bartlettroscoe Feb 6, 2023
3b63fbd
WIP: Improve documentation (#63)
bartlettroscoe Feb 6, 2023
3389ceb
WIP: Move functions writing <tplName>Config.cmake files to TribitsExt…
bartlettroscoe Feb 6, 2023
28d1beb
WIP: Rename TribitsExternalPackageFindTplHelpers to TribitsExternalPa…
bartlettroscoe Feb 6, 2023
9a1eba1
WIP: Rename TribitsWriteClientExportFiles.cmake to TribitsInternalPac…
bartlettroscoe Feb 7, 2023
d8d60ae
WIP: Factor out TribitsProjectWriteConfigFile.cmake, reorder funcs (#63)
bartlettroscoe Feb 7, 2023
f14bba2
WIP: Rename func, remove unused funcs (#63)
bartlettroscoe Feb 7, 2023
bdd12c9
WIP: Remove 'Fully' from 'Fully TriBITS-Compliant' (and variations) (…
bartlettroscoe Feb 7, 2023
a2a5b99
Move 'CMake Language Overview and Gotchas' to appendix
bartlettroscoe Feb 9, 2023
61eaf6a
Remove debug print statement that got commited by accident
bartlettroscoe Feb 9, 2023
ba9de28
Adjust logic and printing for setting INTTERNAL packages as EXTERNAL …
bartlettroscoe Feb 18, 2023
80bd994
Update some outputing for TriBITS-compliant external packages (#63)
bartlettroscoe Feb 19, 2023
31de1fe
Add definitions of TriBITS-compliant packages (#63)
bartlettroscoe Feb 20, 2023
652d189
Add links to TriBITS-compliant external package in requirements for F…
bartlettroscoe Feb 20, 2023
8fc1e25
Add build ref item for treating internal packages as external (#634)
bartlettroscoe Feb 21, 2023
2bcc17f
Add CHANGLOG.md entry for -D<Project>_ENABLE_<TplName>=ON (#63, #546)
bartlettroscoe Feb 21, 2023
68c83ef
Add documentation for TriBITS-compliant external packages TRIBITS_PKG…
bartlettroscoe Feb 21, 2023
f8c1ea5
Add CHANGLOG.md entry for supporting pre-installed packages (#63)
bartlettroscoe Feb 21, 2023
f75343e
Merge remote-tracking branch 'github/master' into 63-combined-package…
bartlettroscoe Feb 25, 2023
2de8ca1
Merge branch 'master' into 63-combined-package-data-structures-6
bartlettroscoe Feb 25, 2023
f58975f
Merge remote-tracking branch 'github/master' into 63-combined-package…
bartlettroscoe Feb 28, 2023
90b96ee
Fix some documentation and add new functions to generated docs (#63, …
bartlettroscoe Mar 29, 2023
16b1817
Fix spelling of TribitsCMakeLanguageOverviewAndGotchas.rst (#63, #560)
bartlettroscoe Mar 29, 2023
014a153
Remove unused legacy RELATIVE_PATH code (#63, #560)
bartlettroscoe Mar 29, 2023
ee67e05
Merge remote-tracking branch 'github/master' into 63-combined-package…
bartlettroscoe Mar 29, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
WIP: Add internalOrExternal arg to tribits_print_packages_list_enable…
…_status_from_var() (#63)

This will be used to refactor the functions in
TribitsPrintEnabledPackagesLists.cmake to display the set of internal and
external packages according to <Package>_PACKAGE_BUILD_STATUS instead of fixed
lists formed when the package are first defined.

This included adding a new filtering function
tribits_get_sublist_internal_external()
  • Loading branch information
bartlettroscoe committed Feb 7, 2023
commit cc8d5b7bd636061a6d4a1d24b12c3360c72ffd1e
50 changes: 50 additions & 0 deletions tribits/core/package_arch/TribitsGetEnabledSublists.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -161,3 +161,53 @@ function(tribits_get_sublist_nonenabled enableListName
set(${numNonenabledVarOut} ${numNonenabled} PARENT_SCOPE)
endif()
endfunction()


# @FUNCTION: tribits_get_sublist_internal_external()
#
# Get sub-list of packages that are INTERNAL, EXTERNAL, or either.
#
# Usage::
#
# tribits_get_sublist_internal_external( <inputPackageListName> <internalOrExternal>
# <sublistNameOut> [<sizeSublistOut>] )
#
# where:
#
# * `<internalOrExternal>` is either `INTERNAL`, `EXTERNAL` or empty "".
#
# On output, ``<sublistNameOut>`` contains the sublist of entries in
# ``<inputPackageListName>`` which are either `INTERNAL` or `EXTERNAL` or both
# (if `<internalOrExternal>` is "") based on `<Package>_PACKAGE_BUILD_STATUS`
# for each element package name.
#
function(tribits_get_sublist_internal_external inputPackageListName internalOrExternal
sublistNameOut sizeSublistOut
)
tribits_assert_internal_or_external_arg("${internalOrExternal}")
if (NOT internalOrExternal STREQUAL "")
set(sublist "")
foreach(pkgName IN LISTS ${inputPackageListName})
if (${pkgName}_PACKAGE_BUILD_STATUS STREQUAL internalOrExternal)
list(APPEND sublist ${pkgName})
endif()
endforeach()
else()
set(sublist ${${inputPackageListName}})
endif()
set(${sublistNameOut} ${sublist} PARENT_SCOPE)
if (numEnabledVarOut)
bartlettroscoe marked this conversation as resolved.
Show resolved Hide resolved
list(LENGTH sublist sizeSublist)
set(${sizeSublistOut} ${sizeSublist} PARENT_SCOPE)
endif()
endfunction()


function(tribits_assert_internal_or_external_arg internalOrExternal)
set(allowedValuesList "INTERNAL" "EXTERNAL" "")
if (NOT internalOrExternal IN_LIST allowedValuesList)
message(FATAL_ERROR "ERROR, the argument internalOrExternal="
"'${internalOrExternal}' is not in the list of allowed values"
${allowedValuesList} )
endif()
endfunction()
18 changes: 10 additions & 8 deletions tribits/core/package_arch/TribitsPrintEnabledPackagesLists.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -80,10 +80,10 @@ endfunction()
function(tribits_print_enables_after_adjust_package_enables)
tribits_print_packages_list_enable_status_from_var(
${PROJECT_NAME}_ENABLED_INTERNAL_TOPLEVEL_PACKAGES
"\nFinal set of enabled top-level packages" ON NONEMPTY)
"\nFinal set of enabled top-level packages" "" ON NONEMPTY)
tribits_print_packages_list_enable_status_from_var(
${PROJECT_NAME}_ENABLED_INTERNAL_PACKAGES
"\nFinal set of enabled packages" ON NONEMPTY)
"\nFinal set of enabled packages" "" ON NONEMPTY)
tribits_print_internal_toplevel_package_list_enable_status(
"\nFinal set of non-enabled top-level packages" OFF INCLUDE_EMPTY)
tribits_print_internal_package_list_enable_status(
Expand All @@ -104,7 +104,7 @@ function(tribits_print_internal_toplevel_package_list_enable_status
)
tribits_print_packages_list_enable_status_from_var(
${PROJECT_NAME}_DEFINED_INTERNAL_TOPLEVEL_PACKAGES
"${docString}" ${enabledFlag} ${enableEmptyStatus} )
"${docString}" "" ${enabledFlag} ${enableEmptyStatus} )
endfunction()


Expand Down Expand Up @@ -167,19 +167,21 @@ endfunction()
# packages
#
function(tribits_print_packages_list_enable_status_from_var packageListVarName
docString enabledFlag enableEmptyStatus
docString internalOrExternal enabledFlag enableEmptyStatus
)
tribits_assert_include_empty_param(${enableEmptyStatus})
tribits_get_sublist_internal_external(${packageListVarName} "${internalOrExternal}"
packageListTmp "")
if (enabledFlag AND (enableEmptyStatus STREQUAL "NONEMPTY"))
tribits_get_sublist_enabled(${packageListVarName}
tribits_get_sublist_enabled(packageListTmp
enableStatusList "")
elseif (enabledFlag AND (enableEmptyStatus STREQUAL "INCLUDE_EMPTY"))
tribits_get_sublist_nondisabled(${packageListVarName} enableStatusList "")
tribits_get_sublist_nondisabled(${packageListTmp} enableStatusList "")
elseif (NOT enabledFlag AND (enableEmptyStatus STREQUAL "NONEMPTY"))
tribits_get_sublist_disabled(${packageListVarName}
tribits_get_sublist_disabled(packageListTmp
enableStatusList "")
elseif (NOT enabledFlag AND (enableEmptyStatus STREQUAL "INCLUDE_EMPTY"))
tribits_get_sublist_nonenabled(${packageListVarName}
tribits_get_sublist_nonenabled(packageListTmp
enableStatusList "")
else()
message(FATAL_ERROR "Should never get here!")
Expand Down
2 changes: 1 addition & 1 deletion tribits/ctest_driver/TribitsCTestDriverCore.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -2276,7 +2276,7 @@ function(tribits_ctest_driver)

tribits_print_packages_list_enable_status_from_var(
${PROJECT_NAME}_PACKAGES_TO_DIRECTLY_TEST
"\nFinal set of packages to be explicitly processed by CTest/CDash" ON NONEMPTY)
"\nFinal set of packages to be explicitly processed by CTest/CDash" "" ON NONEMPTY)

message(
"\n***"
Expand Down