From 8084d28fb3a24c309673b23ba731e6150af794ca Mon Sep 17 00:00:00 2001 From: Vladislav Nepogodin Date: Thu, 17 Nov 2022 02:15:20 +0400 Subject: [PATCH] =?UTF-8?q?=F0=9F=9A=A7=20update=20warnings=20flags?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- cmake/CompilerWarnings.cmake | 35 ++++++++++++++++++-- configure.sh | 62 ++++++++++++++++++++++++++++-------- meson.build | 9 ++++++ 3 files changed, 91 insertions(+), 15 deletions(-) diff --git a/cmake/CompilerWarnings.cmake b/cmake/CompilerWarnings.cmake index f0fb060..04a8016 100644 --- a/cmake/CompilerWarnings.cmake +++ b/cmake/CompilerWarnings.cmake @@ -1,5 +1,6 @@ function(set_project_warnings project_name) - option(WARNINGS_AS_ERRORS "Treat compiler warnings as errors" OFF) + option(WARNINGS_AS_ERRORS "Treat compiler warnings as errors" ON) + option(ENABLE_HARD_WARNINGS "Enable HARD warnings for static ananlyzer" OFF) set(MSVC_WARNINGS /W4 # Baseline reasonable warnings @@ -46,7 +47,7 @@ function(set_project_warnings project_name) -Wimplicit-fallthrough # warn on statements that fallthrough without an explicit annotation ) - if(WARNINGS_AS_ERRORS) + if(WARNINGS_AS_ERRORS AND NOT ENABLE_HARD_WARNINGS) set(CLANG_WARNINGS ${CLANG_WARNINGS} -Werror) set(MSVC_WARNINGS ${MSVC_WARNINGS} /WX) endif() @@ -72,8 +73,38 @@ function(set_project_warnings project_name) -Wanalyzer-double-free -Wanalyzer-malloc-leak -Wanalyzer-use-after-free + + ## some more analyzer flags + -Wanalyzer-tainted-allocation-size + -Wanalyzer-use-of-uninitialized-value + -Wanalyzer-use-of-pointer-in-stale-stack-frame + -Wanalyzer-free-of-non-heap + -Wanalyzer-mismatching-deallocation + -Wanalyzer-null-dereference + -Wanalyzer-possible-null-dereference ) + if(ENABLE_HARD_WARNINGS) + set(GCC_WARNINGS + ${GCC_WARNINGS} + -fanalyzer + -Wanalyzer-too-complex + + + ## just for testing + -Wanalyzer-exposure-through-output-file + -Wanalyzer-file-leak + -Wanalyzer-null-argument + -Wanalyzer-possible-null-argument + -Wanalyzer-shift-count-negative + -Wanalyzer-shift-count-overflow + -Wanalyzer-stale-setjmp-buffer + -Wanalyzer-unsafe-call-within-signal-handler + -Wanalyzer-write-to-const + -Wanalyzer-write-to-string-literal + ) + endif() + if(MSVC) set(PROJECT_WARNINGS ${MSVC_WARNINGS}) elseif(CMAKE_CXX_COMPILER_ID MATCHES ".*Clang") diff --git a/configure.sh b/configure.sh index 32bcf0a..62e16cb 100755 --- a/configure.sh +++ b/configure.sh @@ -25,11 +25,15 @@ if [[ $1 == "--help" ]]; then cat< /dev/null; then + _configure_flags+=('-GNinja') +fi + +if command -v mold &> /dev/null; then + _configure_flags+=('-DCMAKE_EXE_LINKER_FLAGS="-fuse-ld=mold"') +fi cmake -S . -B ${_buildpath}/${_buildtype} \ - -GNinja \ - -DCMAKE_EXE_LINKER_FLAGS="-fuse-ld=mold" \ + -DENABLE_SANITIZER_ADDRESS=${_sanitizer_address} \ + -DENABLE_SANITIZER_UNDEFINED_BEHAVIOR=${_sanitizer_UB} \ + -DENABLE_SANITIZER_LEAK=${_sanitizer_leak} \ -DCMAKE_BUILD_TYPE=${_buildtype} \ -DCMAKE_INSTALL_PREFIX=${_prefix} \ - -DCMAKE_INSTALL_LIBDIR=${_libdir} + -DCMAKE_INSTALL_LIBDIR=${_libdir} \ + "${_configure_flags[@]}" cat > build.sh <