Turn on a bunch of warnings
Turn on as many warnings as I could easily from:
https://github.com/lefticus/cppbestpractices/blob/e73393f25a85f83fed7399d8b65cb117d00b2231/02-Use_the_Tools_Available.md#L100
Tested: sensor list still the same
Change-Id: Ie7c56282e6a590a339554b40017b92020dd939f1
Signed-off-by: James Feist <james.feist@linux.intel.com>
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 10d542e..497f886 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -4,10 +4,33 @@
set (CMAKE_CXX_STANDARD 17)
set (CMAKE_CXX_STANDARD_REQUIRED ON)
set (CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake ${CMAKE_MODULE_PATH})
-set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-rtti -Werror -Wall")
+set (
+ CMAKE_CXX_FLAGS
+ "${CMAKE_CXX_FLAGS} -lstdc++fs \
+ -Werror \
+ -Wall \
+ -Wextra \
+ -Wshadow \
+ -Wnon-virtual-dtor \
+ -Wold-style-cast \
+ -Wcast-align \
+ -Wunused \
+ -Woverloaded-virtual \
+ -Wpedantic \
+ -Wconversion \
+ -Wmisleading-indentation \
+ -Wduplicated-cond \
+ -Wduplicated-branches \
+ -Wlogical-op \
+ -Wnull-dereference \
+ -Wuseless-cast \
+ -Wdouble-promotion \
+ -Wformat=2 \
+"
+)
# todo: fix these warnings
-set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-strict-aliasing -Wno-catch-value")
+set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-strict-aliasing -Wno-cast-align")
set (CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fno-rtti")
@@ -59,14 +82,15 @@
&& make -j libsdbusplus.la INSTALL_COMMAND ""
LOG_DOWNLOAD ON)
- include_directories (${CMAKE_BINARY_DIR}/sdbusplus-src)
- include_directories (${CMAKE_BINARY_DIR}/nlohmann/include)
- include_directories (${CMAKE_BINARY_DIR}/nlohmann/include/nlohmann)
- include_directories (${CMAKE_BINARY_DIR}/valijson/include)
- include_directories (${CMAKE_BINARY_DIR}/phosphor-dbus-interfaces/include)
+ include_directories (SYSTEM ${CMAKE_BINARY_DIR}/sdbusplus-src)
+ include_directories (SYSTEM ${CMAKE_BINARY_DIR}/nlohmann/include)
+ include_directories (SYSTEM ${CMAKE_BINARY_DIR}/nlohmann/include/nlohmann)
+ include_directories (SYSTEM ${CMAKE_BINARY_DIR}/valijson/include)
+ include_directories (SYSTEM
+ ${CMAKE_BINARY_DIR}/phosphor-dbus-interfaces/include)
link_directories (${CMAKE_BINARY_DIR}/sdbusplus-src/.libs)
- include_directories (${CMAKE_BINARY_DIR}/boost-src)
+ include_directories (SYSTEM ${CMAKE_BINARY_DIR}/boost-src)
set (CMAKE_PREFIX_PATH ${CMAKE_BINARY_DIR}/boost-src ${CMAKE_PREFIX_PATH})
option (ENABLE_TEST "Enable Google Test" OFF)
if (ENABLE_TEST)
@@ -83,8 +107,6 @@
add_definitions (-DBOOST_NO_TYPEID)
include_directories (${CMAKE_CURRENT_SOURCE_DIR}/include)
-include_directories (${Boost_INCLUDE_DIRS})
-include_directories (${CMAKE_CURRENT_SOURCE_DIR}/include)
add_executable (fru-device src/FruDevice.cpp src/Utils.cpp)