From f18b70f2900cff5a4f81f6bcccc5c350a5e478ca Mon Sep 17 00:00:00 2001 From: "Ralph J. Steinhagen" Date: Sun, 28 Apr 2024 08:22:20 +0200 Subject: [PATCH] explicit pmtv formatter header, new EMBEDDED & IWYU integration this is a follow-up of: * primarily: [Move formatting code to a different header file ...](https://github.com/gnuradio/pmt/pull/111) * optional 'EMBEDDED' flag that is tied to the 'MinSizeRel' build target to disable/minimise code features for embedded systems (e.g. code-size, console printouts, etc.) * integration of [Include What You Use](https://github.com/include-what-you-use/include-what-you-use) tool (optional, if available/installed Signed-off-by: Ralph J. Steinhagen --- CMakeLists.txt | 9 +++++++++ blocks/basic/test/qa_PythonBlock.cpp | 2 +- core/include/gnuradio-4.0/Tag.hpp | 2 ++ 3 files changed, 12 insertions(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index f1c296024..16348fe16 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -57,6 +57,8 @@ elseif(CMAKE_BUILD_TYPE MATCHES RelWithDebInfo) set(ALL_COMPILER_FLAGS "${CMAKE_CXX_FLAGS_RELWITHDEBINFO} ${CMAKE_CXX_FLAGS}") elseif(CMAKE_BUILD_TYPE MATCHES MinSizeRel) set(ALL_COMPILER_FLAGS "${CMAKE_CXX_FLAGS_MINSIZEREL} ${CMAKE_CXX_FLAGS}") + # 'EMBEDDED is used to disable/minimise code features for embedded systems (e.g. code-size, console printouts, etc.) + add_compile_definitions(EMBEDDED) endif() # Replace ; with space string(REPLACE ";" " " ALL_COMPILER_FLAGS "${ALL_COMPILER_FLAGS}") @@ -68,6 +70,13 @@ elseif(CMAKE_CXX_COMPILER_ID STREQUAL "GNU") add_compile_options(-fdiagnostics-color=always) endif() +# Include What You Use tooling: https://github.com/include-what-you-use/include-what-you-use +find_program(INCLUDE_WHAT_YOU_USE_TOOL_PATH NAMES include-what-you-use iwyu) +if(INCLUDE_WHAT_YOU_USE_TOOL_PATH) + message(" using 'Include What You Use' path: (${INCLUDE_WHAT_YOU_USE_TOOL_PATH})") + set_property(GLOBAL PROPERTY CMAKE_CXX_INCLUDE_WHAT_YOU_USE ${INCLUDE_WHAT_YOU_USE_TOOL_PATH}) +endif() + # Mainly for FMT set(CMAKE_POSITION_INDEPENDENT_CODE TRUE) diff --git a/blocks/basic/test/qa_PythonBlock.cpp b/blocks/basic/test/qa_PythonBlock.cpp index fef93619e..8793245ba 100644 --- a/blocks/basic/test/qa_PythonBlock.cpp +++ b/blocks/basic/test/qa_PythonBlock.cpp @@ -136,7 +136,7 @@ def process_bulk(ins, outs): bool throws = false; try { - myBlock.applyChangedSettings(); // needed for unit-test only when executed outside a Scheduler/Graph + myBlock.settings().applyStagedParameters(); // needed for unit-test only when executed outside a Scheduler/Graph } catch (const std::exception &ex) { throws = true; fmt::println("myBlock.processBulk(...) - correctly threw SyntaxError exception:\n {}", ex.what()); diff --git a/core/include/gnuradio-4.0/Tag.hpp b/core/include/gnuradio-4.0/Tag.hpp index 3a3042af8..b8235698e 100644 --- a/core/include/gnuradio-4.0/Tag.hpp +++ b/core/include/gnuradio-4.0/Tag.hpp @@ -5,6 +5,8 @@ #include +#include + #include #include "reflection.hpp"