From f67e8f6038266e4812ea340a5a9c8c91e700ebd9 Mon Sep 17 00:00:00 2001 From: Brian Szmyd Date: Tue, 17 Oct 2023 17:12:35 -0700 Subject: [PATCH] Remove vestigial options. (#54) --- CMakeLists.txt | 12 +++----- cmake/debug_flags.cmake | 68 ----------------------------------------- conanfile.py | 2 +- 3 files changed, 6 insertions(+), 76 deletions(-) delete mode 100644 cmake/debug_flags.cmake diff --git a/CMakeLists.txt b/CMakeLists.txt index ab3b116..a86f8dc 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -12,13 +12,11 @@ else() message(WARNING "Conan Build file does not exist, trying to build without!") endif() -if(${CMAKE_BUILD_TYPE} STREQUAL "Debug") - include (cmake/debug_flags.cmake) -else() - if((${CMAKE_CXX_COMPILER_ID} STREQUAL "GNU") OR (${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang")) - remove_flag("-O[0-4]") - add_flags("-O2") - endif() +if (DEFINED BUILD_COVERAGE) + if (${BUILD_COVERAGE}) + include (cmake/CodeCoverage.cmake) + APPEND_COVERAGE_COMPILER_FLAGS() + endif () endif() if (DEFINED MEMORY_SANITIZER_ON AND ${MEMORY_SANITIZER_ON}) diff --git a/cmake/debug_flags.cmake b/cmake/debug_flags.cmake deleted file mode 100644 index 7374b8e..0000000 --- a/cmake/debug_flags.cmake +++ /dev/null @@ -1,68 +0,0 @@ -# This list is generated from the output of: -# -# gcc -Q --help=optimizers -O0 -# -# with GCC 4.8.4 (Ubuntu 4.8.4-2ubuntu1-14.04.3). Yes, every one of these flags -# is on even with -O0 specified, and nothing changes when you add debugging -# options (-g/-g3/-gdwarf-4/etc.) in there. This should be updated every time -# the version of GCC used to compile changes. -# -# If you add an option here, it is your responsibility to comment it, with the -# following convention (feel free to add your own if there's not one suitable). -# DO YOUR RESEARCH. -# -# CBWITPOB: Can be wrong in the presence of bugs. When are you usually -# debugging? When there's a bug. Optimizations that can be wrong -# in the presence of bugs mean that, for example, you won't see -# a variable be modified when it actually happens--if it's -# modified due to the bug, as far as the debugger is concerned, -# it wasn't modified by the program, and things like conditional -# breakpoints won't work right, unless maybe it's a volatile -# variable. -# Inlining: Although GDB claims to track this correctly with -g3 and inject -# the code while you're stepping, it does not. You'll either be -# missing stack frames, or unable to view locals when you step -# to that frame--even if those locals exist nowhere else (i.e. -# not a function argument or tail return value). -# Eliding: Behavior may not change, but who knows where the values come -# from. -# Hoisting: Your program is not running instructions in the order of the -# code. Again, GDB claims to handle this, but it does not, or at -# least not well. -# Vectorizing: Great optimization, but the simulation of going through for -# loops is far from perfect, especially when you're dealing -# with bugs. -# -# And yes, these optimizations severely effect the quality of the debugging -# experience. Without these, you're lucky to be able to step into 80% of the -# stack, and of that 80%, you'll see anywhere from 50% to 100% of locals -# missing values. With these, I've never seen a stack frame I couldn't step -# into, and never seen when I look at a local. -# -set (REALLY_NO_OPTIMIZATION_FLAGS "-fno-short-enums" )# Binary-incompatible with code compiled otherwise. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-aggressive-loop-optimizations" ) # Changes behavior on overflow. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-branch-count-reg" )# Changes CPU instructions used. set (REALLY_NO_OPTIMIZATION_FLAGS ="${REALLY_NO_OPTIMIZATION_FLAGS}+= -fno-dce )# Can be wrong in the presence of bugs (CBWITPOB). set (REALLY_NO_OPTIMIZATION_FLAGS ="${REALLY_NO_OPTIMIZATION_FLAGS}+= -fno-delete-null-pointer-checks )# CBWITPOB. set (REALLY_NO_OPTIMIZATION_FLAGS ="${REALLY_NO_OPTIMIZATION_FLAGS}+= -fno-dse )# CBWITPOB. set (REALLY_NO_OPTIMIZATION_FLAGS ="${REALLY_NO_OPTIMIZATION_FLAGS}+= -fno-early-inlining )# NO INLINING! Because... set (REALLY_NO_OPTIMIZATION_FLAGS ="${REALLY_NO_OPTIMIZATION_FLAGS}+= -fno-gcse-lm )# Changes CPU instructions used. set (REALLY_NO_OPTIMIZATION_FLAGS ="${REALLY_NO_OPTIMIZATION_FLAGS}+= -fno-inline )# ...inlining also does things like elide locals. set (REALLY_NO_OPTIMIZATION_FLAGS ="${REALLY_NO_OPTIMIZATION_FLAGS}+= -fno-ira-hoist-pressure )# Might be irrelevant, but NO HOISTING! set (REALLY_NO_OPTIMIZATION_FLAGS ="${REALLY_NO_OPTIMIZATION_FLAGS}+= -fno-ivopts )# Elides and changes instructions. CBWITPOB. set (REALLY_NO_OPTIMIZATION_FLAGS ="${REALLY_NO_OPTIMIZATION_FLAGS}+= -fno-jump-tables )# Changes CPU instructions for switch statements. set (REALLY_NO_OPTIMIZATION_FLAGS ="${REALLY_NO_OPTIMIZATION_FLAGS}+= -fno-move-loop-invariants )# NO HOISTING! set (REALLY_NO_OPTIMIZATION_FLAGS ="${REALLY_NO_OPTIMIZATION_FLAGS}+= -fno-peephole )# Exploiting CPU quirks. CBWITPOB. set (REALLY_NO_OPTIMIZATION_FLAGS ="${REALLY_NO_OPTIMIZATION_FLAGS}+= -fno-prefetch-loop-arrays )# Changes CPU instructions, even GCC manual is ambivalent. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-rename-registers" )# Maybe wrong in the presence of bugs? -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-toplevel-reorder" )# Elides unused static variable, reorders globals. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-tree-coalesce-vars" )# Elides temporaries. CBWITPOB. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-tree-cselim" )# Reorders, violates C++ mem model, CBWITPOB. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-tree-forwprop" )# Reorders and changes instructions. CBWITPOB. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-tree-loop-if-convert" )# Reorders and changes instructions. CBWITPOB. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-tree-loop-im" )# Reorders and changes instructions. CBWITPOB. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-tree-loop-optimize" )# Reorders and changes instructions. CBWITPOB. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-tree-phiprop" )# NO HOISTING! Reorders and changes. CBWITPOB. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-tree-pta" )# Less analysis means maybe less interference. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-tree-reassoc" )# Elides and vectories. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-tree-scev-cprop" )# Elides and changes instructions. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-tree-vect-loop-version" )# E&C. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-web" )# E&C. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fno-tree-slp-vectorize" )# E&C. -set (REALLY_NO_OPTIMIZATION_FLAGS "${REALLY_NO_OPTIMIZATION_FLAGS} -fthreadsafe-statics" )# Slightly smaller in code that doesn't need to be TS. - -set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${REALLY_NO_OPTIMIZATION_FLAGS}") -if (DEFINED BUILD_COVERAGE) - if (${BUILD_COVERAGE}) - include (cmake/CodeCoverage.cmake) - APPEND_COVERAGE_COMPILER_FLAGS() - endif () -endif () diff --git a/conanfile.py b/conanfile.py index 51a11fe..071f961 100644 --- a/conanfile.py +++ b/conanfile.py @@ -67,7 +67,7 @@ def requirements(self): self.requires("pistache/0.0.5") self.requires("zmarok-semver/1.1.0") self.requires("openssl/3.1.1", override=True) - self.requires("libcurl/8.0.1", override=True) + self.requires("libcurl/8.2.1", override=True) def build(self): cmake = CMake(self)