tastytea
99e1cd8e98
All checks were successful
continuous-integration/drone/push Build is passing
Found out what was wrong: I fed boost::regex_search() the pointer to a substring that was created in-place. match[2] was a pointer to a substring inside that. The problem was, that match was declared outside of the if-block. So after the if-block match[2] would point to a now freed memory address. It didn't have any effects because I didn't use match afterwards. I rewrote the whole thing with iterators. Slightly less readable, slightly better performance (probably).
65 lines
1.7 KiB
CMake
65 lines
1.7 KiB
CMake
# Set compiler flags for Debug builds.
|
|
# Only has an effect on GCC/Clang >= 5.0.
|
|
|
|
set(tmp_CXXFLAGS "")
|
|
set(tmp_LDFLAGS "")
|
|
|
|
if(CMAKE_CXX_COMPILER_ID MATCHES "GNU" OR CMAKE_CXX_COMPILER_ID MATCHES "Clang"
|
|
AND NOT CMAKE_CXX_COMPILER_VERSION VERSION_LESS "5")
|
|
list(APPEND tmp_CXXFLAGS
|
|
"-Wall"
|
|
"-Wextra"
|
|
"-Wpedantic"
|
|
"-Wuninitialized"
|
|
"-Wshadow"
|
|
"-Wnon-virtual-dtor"
|
|
"-Wconversion"
|
|
"-Wsign-conversion"
|
|
"-Wold-style-cast"
|
|
"-Wzero-as-null-pointer-constant"
|
|
"-Wmissing-declarations"
|
|
"-Wcast-align"
|
|
"-Wunused"
|
|
"-Woverloaded-virtual"
|
|
"-Wdouble-promotion"
|
|
"-Wformat=2"
|
|
"-ftrapv"
|
|
"-fsanitize=undefined"
|
|
"-fsanitize=address"
|
|
"-Og"
|
|
"-fno-omit-frame-pointer")
|
|
if(CMAKE_CXX_COMPILER_ID MATCHES "GNU")
|
|
list(APPEND tmp_CXXFLAGS
|
|
"-Wlogical-op"
|
|
"-Wuseless-cast")
|
|
if(NOT CMAKE_CXX_COMPILER_VERSION VERSION_LESS "6")
|
|
list(APPEND tmp_CXXFLAGS
|
|
"-Wmisleading-indentation"
|
|
"-Wduplicated-cond"
|
|
"-Wnull-dereference")
|
|
if(NOT CMAKE_CXX_COMPILER_VERSION VERSION_LESS "7")
|
|
list(APPEND tmp_CXXFLAGS
|
|
"-Wduplicated-branches")
|
|
endif()
|
|
endif()
|
|
endif()
|
|
add_compile_options("$<$<CONFIG:Debug>:${tmp_CXXFLAGS}>")
|
|
|
|
list(APPEND tmp_LDFLAGS
|
|
"-fsanitize=undefined"
|
|
"-fsanitize=address")
|
|
# add_link_options was introduced in version 3.13.
|
|
if(${CMAKE_VERSION} VERSION_LESS 3.13)
|
|
set(CMAKE_SHARED_LINKER_FLAGS_DEBUG "${tmp_LDFLAGS}")
|
|
else()
|
|
add_link_options("$<$<CONFIG:Debug>:${tmp_LDFLAGS}>")
|
|
endif()
|
|
else()
|
|
message(STATUS
|
|
"No additional compiler flags were set, "
|
|
"because your compiler was not anticipated.")
|
|
endif()
|
|
|
|
unset(tmp_CXXFLAGS)
|
|
unset(tmp_LDFLAGS)
|