Export of internal Abseil changes.
-- f6c627ce4470a814adc377947b58346eef69a4c9 by Jon Cohen <cohenjon@google.com>: Don't create install rules when Abseil is used as a subdirectory. Fix #287 PiperOrigin-RevId: 240559825 -- a5d9b06fe736143068997988b654b5f66ec3266a by Matt Calabrese <calabrese@google.com>: Make absl::nullopt an inline constexpr variable, as specified in the standard (with a workaround for pre-c++17 compilers). PiperOrigin-RevId: 240552286 -- d7bee50cff745fbb8d1cdf56a200d9073d311c80 by Abseil Team <absl-team@google.com>: Internal Change PiperOrigin-RevId: 240425622 -- 828dd49d392d83dbeecd9d3e9cb14551ab265905 by Jon Cohen <cohenjon@google.com>: Add default link options to absl builds. Currently all this does is add -ignore:4221 to Abseil msvc builds, but the structure is all in place to add more link options when necessary Fix #277 Note: This CL changes tact for us in that it puts the default options in the helper function as opposed to the invocations of absl_cc_blah. The original intent of keeping these out of the helper functions was to make generating the CMakeLists.txt files have a smaller diff, but looking now that is a problem for the future, and small compared to making maintenance and use of our CMake buildsystem easier PiperOrigin-RevId: 240409463 -- 4aa120e9dcf76d29e9ca0008d0f6d4d9fa8abe8c by Matt Kulukundis <kfm@google.com>: Reduce flake rate for non-determistic test to < 1/10,000 PiperOrigin-RevId: 240370938 -- bc30e219531827bfbf90915b2067c7fb8160bb6d by Derek Mauro <dmauro@google.com>: Add Bazel caching on Kokoro for new linux targets. PiperOrigin-RevId: 240356556 -- c4e06d79a50d7bb211312b7845c4bd92c0761747 by Jon Cohen <cohenjon@google.com>: include AbseilInstallDirs instead of GNUInstallDirs. It worked before because global_CMakeLists.txt also included AbseilInstallDirs PiperOrigin-RevId: 240206409 -- c254dc6cade8a263f3f97fb1417d92fe5235ff32 by Jon Cohen <cohenjon@google.com>: Fix logic for when we create the variant_exception_safety_test in CMake. Currently we are only running in on gcc > 4.9, when we want it run on every compiler except gcc <= 4.8 PiperOrigin-RevId: 240194174 -- 01518006b351d3670ba1d349cfbcb7dd6f3a8b84 by CJ Johnson <johnsoncj@google.com>: Removes old implementation warning comment now that InlinedVector has an implementation detail file PiperOrigin-RevId: 240167265 -- eb05355ae8c7397752ab7a65afc9e0a99472ba9d by Jon Cohen <cohenjon@google.com>: Remove the forward declaration of Span PiperOrigin-RevId: 240156660 -- b7e75aa3933d6e79dd086821cf58d15e72f476f4 by Jon Cohen <cohenjon@google.com>: Prepare CMake install rule for LTS releases: * Remove the warning against installing in system install locations * Insert versioning to keep different LTS installs from colliding. Headers are installed in <prefix>/absl_$version/include, .a files in <prefix>/absl_$version/lib, and config files in <prefix>/absl_$version/lib/cmake PiperOrigin-RevId: 240153986 -- de63488ab6236e041f08260794b0b634a2b8ed16 by CJ Johnson <johnsoncj@google.com>: Reduce reader confusion by using std::addressof(...) even when the type is known to not overload operator&(...) PiperOrigin-RevId: 240131902 GitOrigin-RevId: f6c627ce4470a814adc377947b58346eef69a4c9 Change-Id: I95dbbacaaf65aceeeca9e9bee5fd9ea456225f62
This commit is contained in:
parent
eab2078b53
commit
5b65c4af51
33 changed files with 493 additions and 233 deletions
|
|
@ -16,7 +16,7 @@
|
|||
|
||||
include(CMakeParseArguments)
|
||||
include(AbseilConfigureCopts)
|
||||
include(GNUInstallDirs)
|
||||
include(AbseilInstallDirs)
|
||||
|
||||
# The IDE folder for Abseil that will be used if Abseil is included in a CMake
|
||||
# project that sets
|
||||
|
|
@ -105,13 +105,15 @@ function(absl_cc_library)
|
|||
target_include_directories(${_NAME}
|
||||
PUBLIC
|
||||
$<BUILD_INTERFACE:${ABSL_COMMON_INCLUDE_DIRS}>
|
||||
$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>
|
||||
$<INSTALL_INTERFACE:${ABSL_INSTALL_INCLUDEDIR}>
|
||||
)
|
||||
target_compile_options(${_NAME}
|
||||
PRIVATE ${ABSL_CC_LIB_COPTS})
|
||||
target_link_libraries(${_NAME}
|
||||
PUBLIC ${ABSL_CC_LIB_DEPS}
|
||||
PRIVATE ${ABSL_CC_LIB_LINKOPTS}
|
||||
PRIVATE
|
||||
${ABSL_CC_LIB_LINKOPTS}
|
||||
${ABSL_DEFAULT_LINKOPTS}
|
||||
)
|
||||
target_compile_definitions(${_NAME} PUBLIC ${ABSL_CC_LIB_DEFINES})
|
||||
|
||||
|
|
@ -140,10 +142,13 @@ function(absl_cc_library)
|
|||
target_include_directories(${_NAME}
|
||||
INTERFACE
|
||||
$<BUILD_INTERFACE:${ABSL_COMMON_INCLUDE_DIRS}>
|
||||
$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>
|
||||
$<INSTALL_INTERFACE:${ABSL_INSTALL_INCLUDEDIR}>
|
||||
)
|
||||
target_link_libraries(${_NAME}
|
||||
INTERFACE ${ABSL_CC_LIB_DEPS} ${ABSL_CC_LIB_LINKOPTS}
|
||||
INTERFACE
|
||||
${ABSL_CC_LIB_DEPS}
|
||||
${ABSL_CC_LIB_LINKOPTS}
|
||||
${ABSL_DEFAULT_LINKOPTS}
|
||||
)
|
||||
target_compile_definitions(${_NAME} INTERFACE ${ABSL_CC_LIB_DEFINES})
|
||||
endif()
|
||||
|
|
@ -152,9 +157,9 @@ function(absl_cc_library)
|
|||
# installed abseil can't be tested.
|
||||
if (NOT ABSL_CC_LIB_TESTONLY)
|
||||
install(TARGETS ${_NAME} EXPORT ${PROJECT_NAME}Targets
|
||||
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
|
||||
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
|
||||
ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
|
||||
RUNTIME DESTINATION ${ABSL_INSTALL_BINDIR}
|
||||
LIBRARY DESTINATION ${ABSL_INSTALL_LIBDIR}
|
||||
ARCHIVE DESTINATION ${ABSL_INSTALL_LIBDIR}
|
||||
)
|
||||
endif()
|
||||
|
||||
|
|
|
|||
20
CMake/AbseilInstallDirs.cmake
Normal file
20
CMake/AbseilInstallDirs.cmake
Normal file
|
|
@ -0,0 +1,20 @@
|
|||
include(GNUInstallDirs)
|
||||
|
||||
# absl_VERSION is only set if we are an LTS release being installed, in which
|
||||
# case it may be into a system directory and so we need to make subdirectories
|
||||
# for each installed version of Abseil. This mechanism is implemented in
|
||||
# Abseil's internal Copybara (https://github.com/google/copybara) workflows and
|
||||
# isn't visible in the CMake buildsystem itself.
|
||||
|
||||
if (absl_VERSION)
|
||||
set(ABSL_SUBDIR "${PROJECT_NAME}_${PROJECT_VERSION}")
|
||||
set(ABSL_INSTALL_BINDIR "${CMAKE_INSTALL_BINDIR}/${ABSL_SUBDIR}")
|
||||
set(ABSL_INSTALL_CONFIGDIR "${CMAKE_INSTALL_LIBDIR}/cmake/${ABSL_SUBDIR}")
|
||||
set(ABSL_INSTALL_INCLUDEDIR "${CMAKE_INSTALL_INCLUDEDIR}/{ABSL_SUBDIR}")
|
||||
set(ABSL_INSTALL_LIBDIR "${CMAKE_INSTALL_LIBDIR}/${ABSL_SUBDIR}")
|
||||
else()
|
||||
set(ABSL_INSTALL_BINDIR "${CMAKE_INSTALL_BINDIR}")
|
||||
set(ABSL_INSTALL_CONFIGDIR "${CMAKE_INSTALL_LIBDIR}/cmake/${PROJECT_NAME}")
|
||||
set(ABSL_INSTALL_INCLUDEDIR "${CMAKE_INSTALL_INCLUDEDIR}")
|
||||
set(ABSL_INSTALL_LIBDIR "${CMAKE_INSTALL_LIBDIR}")
|
||||
endif()
|
||||
|
|
@ -24,15 +24,6 @@
|
|||
|
||||
# Fail on any error. Treat unset variables an error. Print commands as executed.
|
||||
set -euox pipefail
|
||||
absl_dir=/abseil-cpp
|
||||
absl_build_dir=/buildfs/absl-build
|
||||
project_dir="${absl_dir}"/CMake/install_test_project
|
||||
project_build_dir=/buildfs/project-build
|
||||
install_dir="${project_build_dir}"/install
|
||||
|
||||
mkdir -p "${absl_build_dir}"
|
||||
mkdir -p "${project_build_dir}"
|
||||
mkdir -p "${install_dir}"
|
||||
|
||||
install_absl() {
|
||||
pushd "${absl_build_dir}"
|
||||
|
|
@ -51,10 +42,41 @@ uninstall_absl() {
|
|||
mkdir -p "${absl_build_dir}"
|
||||
}
|
||||
|
||||
lts_install=""
|
||||
|
||||
while getopts ":l" lts; do
|
||||
case "${lts}" in
|
||||
l )
|
||||
lts_install="true"
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
absl_dir=/abseil-cpp
|
||||
absl_build_dir=/buildfs/absl-build
|
||||
project_dir="${absl_dir}"/CMake/install_test_project
|
||||
project_build_dir=/buildfs/project-build
|
||||
|
||||
mkdir -p "${absl_build_dir}"
|
||||
mkdir -p "${project_build_dir}"
|
||||
|
||||
if [[ "${lts_install}" ]]; then
|
||||
install_dir="/usr/local"
|
||||
else
|
||||
install_dir="${project_build_dir}"/install
|
||||
fi
|
||||
mkdir -p "${install_dir}"
|
||||
|
||||
# Test build, install, and link against installed abseil
|
||||
install_absl "${install_dir}"
|
||||
pushd "${project_build_dir}"
|
||||
cmake "${project_dir}" -DCMAKE_PREFIX_PATH="${install_dir}"
|
||||
if [[ "${lts_install}" ]]; then
|
||||
install_absl
|
||||
cmake "${project_dir}"
|
||||
else
|
||||
install_absl "${install_dir}"
|
||||
cmake "${project_dir}" -DCMAKE_PREFIX_PATH="${install_dir}"
|
||||
fi
|
||||
|
||||
cmake --build . --target simple
|
||||
|
||||
output="$(${project_build_dir}/simple "printme" 2>&1)"
|
||||
|
|
@ -64,14 +86,16 @@ if [[ "${output}" != *"Arg 1: printme"* ]]; then
|
|||
exit 1
|
||||
fi
|
||||
|
||||
popd
|
||||
|
||||
# Test that we haven't accidentally made absl::abslblah
|
||||
pushd "${install_dir}"
|
||||
|
||||
# Starting in CMake 3.12 the default install dir is lib$bit_width
|
||||
if [[ -d lib ]]; then
|
||||
libdir="lib"
|
||||
elif [[ -d lib64 ]]; then
|
||||
if [[ -d lib64 ]]; then
|
||||
libdir="lib64"
|
||||
elif [[ -d lib ]]; then
|
||||
libdir="lib"
|
||||
else
|
||||
echo "ls *, */*, */*/*:"
|
||||
ls *
|
||||
|
|
@ -80,7 +104,15 @@ else
|
|||
echo "unknown lib dir"
|
||||
fi
|
||||
|
||||
if ! grep absl::strings "${libdir}"/cmake/absl/abslTargets.cmake; then
|
||||
if [[ "${lts_install}" ]]; then
|
||||
# LTS versions append the date of the release to the subdir.
|
||||
# 9999/99/99 is the dummy date used in the local_lts workflow.
|
||||
absl_subdir="absl_99999999"
|
||||
else
|
||||
absl_subdir="absl"
|
||||
fi
|
||||
|
||||
if ! grep absl::strings "${libdir}/cmake/${absl_subdir}/abslTargets.cmake"; then
|
||||
cat "${libdir}"/cmake/absl/abslTargets.cmake
|
||||
echo "CMake targets named incorrectly"
|
||||
exit 1
|
||||
|
|
@ -89,22 +121,24 @@ fi
|
|||
uninstall_absl
|
||||
popd
|
||||
|
||||
# Test that we warn if installed without a prefix or a system prefix
|
||||
output="$(install_absl 2>&1)"
|
||||
if [[ "${output}" != *"Please set CMAKE_INSTALL_PREFIX"* ]]; then
|
||||
echo "Install without prefix didn't warn as expected. Output:"
|
||||
echo "${output}"
|
||||
exit 1
|
||||
fi
|
||||
uninstall_absl
|
||||
if [[ ! "${lts_install}" ]]; then
|
||||
# Test that we warn if installed without a prefix or a system prefix
|
||||
output="$(install_absl 2>&1)"
|
||||
if [[ "${output}" != *"Please set CMAKE_INSTALL_PREFIX"* ]]; then
|
||||
echo "Install without prefix didn't warn as expected. Output:"
|
||||
echo "${output}"
|
||||
exit 1
|
||||
fi
|
||||
uninstall_absl
|
||||
|
||||
output="$(install_absl /usr 2>&1)"
|
||||
if [[ "${output}" != *"Please set CMAKE_INSTALL_PREFIX"* ]]; then
|
||||
echo "Install with /usr didn't warn as expected. Output:"
|
||||
echo "${output}"
|
||||
exit 1
|
||||
output="$(install_absl /usr 2>&1)"
|
||||
if [[ "${output}" != *"Please set CMAKE_INSTALL_PREFIX"* ]]; then
|
||||
echo "Install with /usr didn't warn as expected. Output:"
|
||||
echo "${output}"
|
||||
exit 1
|
||||
fi
|
||||
uninstall_absl
|
||||
fi
|
||||
uninstall_absl
|
||||
|
||||
echo "Install test complete!"
|
||||
exit 0
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue