Enable clang warnings
This commit enables clang warnings, and fixes all warnings that were
found. Most of these fall into a couple categories:
Variable shadow issues were fixed by renaming variables
unused parameter warnings were resolved by either checking error codes
that had been ignored, or removing the name of the variable from the
scope.
Other various warnings were fixed in the best way I was able to come up
with.
Note, the redfish Node class is especially insidious, as it causes all
imlementers to have variables for parameters, regardless of whether or
not they are used. Deprecating the Node class is on my list of things
to do, as it adds extra overhead, and in general isn't a useful
abstraction. For now, I have simply fixed all the handlers.
Tested:
Added the current meta-clang meta layer into bblayers.conf, and added
TOOLCHAIN_pn-bmcweb = "clang" to my local.conf
Signed-off-by: Ed Tanous <ed@tanous.net>
Change-Id: Ia75b94010359170159c703e535d1c1af182fe700
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 50483ad..847a43e 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -189,7 +189,6 @@
-Wnull-dereference \
-Wdouble-promotion \
-Wformat=2 \
- -Wno-unused-parameter \
"
)
@@ -212,6 +211,36 @@
endif (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 8.0)
endif ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
+if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
+ if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 9.0)
+ set (
+ CMAKE_CXX_FLAGS
+ "${CMAKE_CXX_FLAGS} \
+ -Werror \
+ -Weverything \
+ -Wno-c++98-compat \
+ -Wno-c++98-compat-pedantic \
+ -Wno-global-constructors \
+ -Wno-exit-time-destructors \
+ -Wno-shadow \
+ -Wno-used-but-marked-unused \
+ -Wno-documentation-unknown-command \
+ -Wno-weak-vtables \
+ -Wno-documentation \
+ -Wno-padded \
+ -Wno-unused-parameter \
+ -Wcovered-switch-default \
+ -Wcomma \
+ -Wextra-semi \
+ -Wzero-as-null-pointer-constant \
+ -Wswitch-enum \
+ -Wnull-dereference \
+ -Wdouble-promotion \
+ -Wformat=2 \
+ "
+ )
+ endif (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 8.0)
+endif ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
set (CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fno-rtti")
# general