From 9888bc2d8072f0360a10ba32b6a5834668f0349f Mon Sep 17 00:00:00 2001 From: Anthony Bilinski Date: Sun, 12 Apr 2020 01:34:31 -0700 Subject: [PATCH] fix(build): disable Werror by default, keep enabled on CI To allow for easier building with different compilers on user systems. Keep strict checks on CI to make sure new warnings aren't ignored. --- .travis/build-ubuntu-16-04.sh | 5 ++++- CMakeLists.txt | 9 +++++++-- appimage/build.sh | 1 + flatpak/io.github.qtox.qTox.json | 6 ++++-- osx/qTox-Mac-Deployer-ULTIMATE.sh | 9 ++++++++- windows/cross-compile/build.sh | 2 ++ 6 files changed, 26 insertions(+), 6 deletions(-) diff --git a/.travis/build-ubuntu-16-04.sh b/.travis/build-ubuntu-16-04.sh index 9680e7d23..b45fcf50c 100755 --- a/.travis/build-ubuntu-16-04.sh +++ b/.travis/build-ubuntu-16-04.sh @@ -167,6 +167,7 @@ build_qtox() { -DSMILEYS=DISABLED \ -DENABLE_STATUSNOTIFIER=False \ -DENABLE_GTK_SYSTRAY=False \ + -DSTRICT_OPTIONS=ON \ -DSPELL_CHECK=OFF bdir @@ -175,7 +176,9 @@ build_qtox() { rm -rf "$BUILDDIR" echo '*** BUILDING "FULL" VERSION ***' - cmake -H. -B"$BUILDDIR" -DUPDATE_CHECK=ON + cmake -H. -B"$BUILDDIR" \ + -DUPDATE_CHECK=ON \ + -DSTRICT_OPTIONS=ON bdir } diff --git a/CMakeLists.txt b/CMakeLists.txt index 7544e7aa3..74c68ea2c 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -30,6 +30,7 @@ option(SPELL_CHECK "Enable spell cheching support" ON) option(SVGZ_ICON "Compress the SVG icon of qTox" ON) option(ASAN "Compile with AddressSanitizer" OFF) option(DESKTOP_NOTIFICATIONS "Use snorenotify for desktop notifications" OFF) +option(STRICT_OPTIONS "Enable strict compile options, used by CI" OFF) # process generated files if cmake >= 3.10 if(POLICY CMP0071) @@ -84,12 +85,16 @@ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-rtti") set(POSITION_INDEPENDENT_CODE True) set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wstrict-overflow") set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wstrict-aliasing") -set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Werror") + +# Extra-strict compile options that we don't want to subject all users to by default +if (STRICT_OPTIONS) + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Werror") +endif() # avoid timestamps in binary for reproducible builds, not added until GCC 4.9 include(CheckCXXCompilerFlag) CHECK_CXX_COMPILER_FLAG(-Wdate-time COMPILER_SUPPORTS_WDATE_TIME) -if(COMPILER_SUPPORTS_WDATE_TIME) +if (COMPILER_SUPPORTS_WDATE_TIME) set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wdate-time") endif() diff --git a/appimage/build.sh b/appimage/build.sh index e7a16dd44..14e1a4a44 100755 --- a/appimage/build.sh +++ b/appimage/build.sh @@ -107,6 +107,7 @@ cd _build # need to build with -DDESKTOP_NOTIFICATIONS=True for snorenotify cmake -DDESKTOP_NOTIFICATIONS=True \ -DUPDATE_CHECK=True \ + -DSTRICT_OPTIONS=True \ ../ make diff --git a/flatpak/io.github.qtox.qTox.json b/flatpak/io.github.qtox.qTox.json index 8ea7a30ad..c7cf1f3d5 100644 --- a/flatpak/io.github.qtox.qTox.json +++ b/flatpak/io.github.qtox.qTox.json @@ -133,7 +133,10 @@ { "name": "qTox", "buildsystem": "cmake-ninja", - "config-opts": ["-DSVGZ_ICON=OFF"], + "config-opts": [ + "-DSVGZ_ICON=OFF", + "-DSTRICT_OPTIONS=ON" + ], "sources": [ { "type": "dir", @@ -143,4 +146,3 @@ } ] } - diff --git a/osx/qTox-Mac-Deployer-ULTIMATE.sh b/osx/qTox-Mac-Deployer-ULTIMATE.sh index 0debd8ce4..4315acce3 100755 --- a/osx/qTox-Mac-Deployer-ULTIMATE.sh +++ b/osx/qTox-Mac-Deployer-ULTIMATE.sh @@ -262,7 +262,14 @@ build() { fcho "Now working in ${PWD}" fcho "Starting cmake ..." export CMAKE_PREFIX_PATH=$(brew --prefix qt5) - cmake -H$QTOX_DIR -B. -DUPDATE_CHECK=ON -DSPELL_CHECK=OFF + + if [[ $TRAVIS = true ]] + then + STRICT_OPTIONS="ON" + else + STRICT_OPTIONS="OFF" + fi + cmake -H$QTOX_DIR -B. -DUPDATE_CHECK=ON -DSPELL_CHECK=OFF -DSTRICT_OPTIONS="${STRICT_OPTIONS}" make -j$(sysctl -n hw.ncpu) } diff --git a/windows/cross-compile/build.sh b/windows/cross-compile/build.sh index c422ddd0a..da3ce3b86 100644 --- a/windows/cross-compile/build.sh +++ b/windows/cross-compile/build.sh @@ -977,6 +977,7 @@ then -DCMAKE_BUILD_TYPE=Release \ -DSPELL_CHECK=OFF \ -DUPDATE_CHECK=ON \ + -DSTRICT_OPTIONS=ON \ .. elif [[ "$BUILD_TYPE" == "debug" ]] then @@ -984,6 +985,7 @@ then -DCMAKE_BUILD_TYPE=Debug \ -DSPELL_CHECK=OFF \ -DUPDATE_CHECK=ON \ + -DSTRICT_OPTIONS=ON \ .. fi