Allow selection of system default C++ version.
This leaves the decision of which C++ version to use up to our users. We still have a static_assert in port_def.inc that will prevent pre-C++14 usage.
PiperOrigin-RevId: 501351066
diff --git a/CMakeLists.txt b/CMakeLists.txt
index f60142b..ab6a763 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -40,27 +40,6 @@
get_filename_component(protobuf_SOURCE_DIR ${protobuf_SOURCE_DIR} DIRECTORY)
endif()
-# Add C++14 flags
-if(NOT CMAKE_CXX_STANDARD)
- set(CMAKE_CXX_STANDARD 14)
-endif()
-if(CYGWIN)
- string(REGEX_MATCH "-std=gnu\\+\\+([0-9]+)" _protobuf_CXX_STD "${CMAKE_CXX_FLAGS}")
-endif()
-if(NOT _protobuf_CXX_STD)
- set(_protobuf_CXX_STD "${CMAKE_CXX_STANDARD}")
-endif()
-if(_protobuf_CXX_STD LESS "14")
- message(FATAL_ERROR "Protocol Buffers requires at least C++14, but is configured for C++${_protobuf_CXX_STD}")
-endif()
-if(CYGWIN)
- set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=gnu++${_protobuf_CXX_STD}")
-else()
- set(CMAKE_CXX_STANDARD ${_protobuf_CXX_STD})
- set(CMAKE_CXX_STANDARD_REQUIRED ON)
- set(CMAKE_CXX_EXTENSIONS OFF)
-endif()
-
# The Intel compiler isn't able to deal with noinline member functions of
# template classes defined in headers. As such it spams the output with
# warning #2196: routine is both "inline" and "noinline"
diff --git a/cmake/README.md b/cmake/README.md
index 396d495..4bb2e05 100644
--- a/cmake/README.md
+++ b/cmake/README.md
@@ -8,6 +8,19 @@
Most of the instructions will be given using CMake's command-line interface, but
the same actions can be performed using appropriate GUI tools.
+# CMake Flags
+
+## C++ Version
+
+By default, CMake will use whatever C++ version is the system default. Since
+protobuf requires C++14 or newer, sometimes you will need to explicitly override
+this. For example, the following:
+
+ cmake . -DCMAKE_CXX_STANDARD=14
+ cmake --build
+
+will build protobuf using C++14 (see [CXX_STANDARD](https://cmake.org/cmake/help/latest/prop_tgt/CXX_STANDARD.html#prop_tgt:CXX_STANDARD){.external} for all available options).
+
# Windows Builds
On Windows, you can build the project from *Command Prompt* and using an
diff --git a/kokoro/common/cmake.sh b/kokoro/common/cmake.sh
index 99be3be..934170b 100755
--- a/kokoro/common/cmake.sh
+++ b/kokoro/common/cmake.sh
@@ -60,7 +60,8 @@
caplog 01_configure \
cmake -S "${SOURCE_DIR}" \
${CMAKE_BUILD_TYPE_FLAG} \
- ${CAPLOG_CMAKE_ARGS:-}
+ ${CAPLOG_CMAKE_ARGS:-} \
+ -DCMAKE_CXX_STANDARD=14
)
if [[ -n ${CAPLOG_DIR:-} ]]; then
# Save configuration logs.
diff --git a/kokoro/linux/32-bit/test_php.sh b/kokoro/linux/32-bit/test_php.sh
index 250e9ad..ef97337 100644
--- a/kokoro/linux/32-bit/test_php.sh
+++ b/kokoro/linux/32-bit/test_php.sh
@@ -38,7 +38,7 @@
mkdir -p build
pushd build
-cmake ..
+cmake .. -DCMAKE_CXX_STANDARD=14
cmake --build . -- -j20
ctest --verbose --parallel 20
export PROTOC=$(pwd)/protoc
diff --git a/kokoro/linux/cmake/build.sh b/kokoro/linux/cmake/build.sh
index 5abe392..67aea1b 100755
--- a/kokoro/linux/cmake/build.sh
+++ b/kokoro/linux/cmake/build.sh
@@ -8,7 +8,7 @@
cd $(dirname $0)/../../..
GIT_REPO_ROOT=`pwd`
-CONTAINER_IMAGE=gcr.io/protobuf-build/cmake/linux@sha256:79e6ed9d7f3f8e56167a3309a521e5b7e6a212bfb19855c65ee1cbb6f9099671
+CONTAINER_IMAGE=gcr.io/protobuf-build/cmake/linux@sha256:bd17c13255c8c7af2821c6597ad96568d714c0ea9d9e27d81b108fcc195ca858
# Update git submodules and regenerate files
git submodule update --init --recursive
@@ -22,7 +22,10 @@
--cidfile $tmpfile \
-v $GIT_REPO_ROOT:/workspace \
$CONTAINER_IMAGE \
- /test.sh -Dprotobuf_BUILD_CONFORMANCE=ON -Dprotobuf_BUILD_EXAMPLES=ON
+ /test.sh \
+ -Dprotobuf_BUILD_CONFORMANCE=ON \
+ -Dprotobuf_BUILD_EXAMPLES=ON \
+ -DCMAKE_CXX_STANDARD=14
# Save logs for Kokoro
docker cp \
diff --git a/kokoro/linux/cmake_install/build.sh b/kokoro/linux/cmake_install/build.sh
index 9efc110..bdd7ae6 100755
--- a/kokoro/linux/cmake_install/build.sh
+++ b/kokoro/linux/cmake_install/build.sh
@@ -8,7 +8,7 @@
cd $(dirname $0)/../../..
GIT_REPO_ROOT=`pwd`
-CONTAINER_IMAGE=gcr.io/protobuf-build/cmake/linux@sha256:79e6ed9d7f3f8e56167a3309a521e5b7e6a212bfb19855c65ee1cbb6f9099671
+CONTAINER_IMAGE=gcr.io/protobuf-build/cmake/linux@sha256:bd17c13255c8c7af2821c6597ad96568d714c0ea9d9e27d81b108fcc195ca858
# Update git submodules and regenerate files
git submodule update --init --recursive
@@ -22,10 +22,11 @@
--cidfile $tmpfile \
-v $GIT_REPO_ROOT:/workspace \
$CONTAINER_IMAGE \
- "/install.sh && /test.sh \
- -Dprotobuf_REMOVE_INSTALLED_HEADERS=ON \
- -Dprotobuf_BUILD_PROTOBUF_BINARIES=OFF \
- -Dprotobuf_BUILD_CONFORMANCE=ON"
+ "/install.sh -DCMAKE_CXX_STANDARD=14 && /test.sh \
+ -Dprotobuf_REMOVE_INSTALLED_HEADERS=ON \
+ -Dprotobuf_BUILD_PROTOBUF_BINARIES=OFF \
+ -Dprotobuf_BUILD_CONFORMANCE=ON \
+ -DCMAKE_CXX_STANDARD=14"
# Save logs for Kokoro
diff --git a/kokoro/linux/cmake_ninja/build.sh b/kokoro/linux/cmake_ninja/build.sh
index 133d97b..6ee3c61 100755
--- a/kokoro/linux/cmake_ninja/build.sh
+++ b/kokoro/linux/cmake_ninja/build.sh
@@ -8,7 +8,7 @@
cd $(dirname $0)/../../..
GIT_REPO_ROOT=`pwd`
-CONTAINER_IMAGE=gcr.io/protobuf-build/cmake/linux@sha256:79e6ed9d7f3f8e56167a3309a521e5b7e6a212bfb19855c65ee1cbb6f9099671
+CONTAINER_IMAGE=gcr.io/protobuf-build/cmake/linux@sha256:bd17c13255c8c7af2821c6597ad96568d714c0ea9d9e27d81b108fcc195ca858
# Update git submodules and regenerate files
git submodule update --init --recursive
@@ -22,7 +22,7 @@
--cidfile $tmpfile \
-v $GIT_REPO_ROOT:/workspace \
$CONTAINER_IMAGE \
- /test.sh -G Ninja -Dprotobuf_BUILD_CONFORMANCE=ON
+ /test.sh -G Ninja -Dprotobuf_BUILD_CONFORMANCE=ON -DCMAKE_CXX_STANDARD=14
# Save logs for Kokoro
docker cp \
diff --git a/kokoro/linux/cmake_shared/build.sh b/kokoro/linux/cmake_shared/build.sh
index f3d7534..2236926 100755
--- a/kokoro/linux/cmake_shared/build.sh
+++ b/kokoro/linux/cmake_shared/build.sh
@@ -8,7 +8,7 @@
cd $(dirname $0)/../../..
GIT_REPO_ROOT=`pwd`
-CONTAINER_IMAGE=gcr.io/protobuf-build/cmake/linux@sha256:79e6ed9d7f3f8e56167a3309a521e5b7e6a212bfb19855c65ee1cbb6f9099671
+CONTAINER_IMAGE=gcr.io/protobuf-build/cmake/linux@sha256:bd17c13255c8c7af2821c6597ad96568d714c0ea9d9e27d81b108fcc195ca858
# Update git submodules and regenerate files
git submodule update --init --recursive
@@ -22,7 +22,10 @@
--cidfile $tmpfile \
-v $GIT_REPO_ROOT:/workspace \
$CONTAINER_IMAGE \
- /test.sh -Dprotobuf_BUILD_CONFORMANCE=ON -Dprotobuf_BUILD_SHARED_LIBS=ON
+ /test.sh \
+ -Dprotobuf_BUILD_CONFORMANCE=ON \
+ -Dprotobuf_BUILD_SHARED_LIBS=ON \
+ -DCMAKE_CXX_STANDARD=14
# Save logs for Kokoro
docker cp \