如何抑制库头中的 GCC 警告?

发布于 2024-12-24 18:18:11 字数 195 浏览 1 评论 0原文

我有一个使用 log4cxx、boost 等库的项目,其标头会生成大量(重复的)警告。有没有办法抑制来自库包含(即#include)或来自某些路径的包含的警告?我想像往常一样在项目代码上使用 -Wall 和/或 -Wextra ,而不会模糊相关信息。我目前在 make 输出上使用 grep,但我想要更好的东西。

I have a project that uses log4cxx, boost, etc. libraries whose headers generate lots of (repetitive) warnings. Is there a way to suppress warnings from library includes (i.e. #include <some-header.h>) or includes from certain paths? I'd like to use -Wall and/or -Wextra as usual on project code without relevant info being obscured. I currently use grep on make output but I'd like something better.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(10

仙女山的月亮 2024-12-31 18:18:11

您可以尝试使用 -isystem 而不是 -I 来包含库标头。这将使它们成为“系统标头”,并且 GCC 不会为它们报告警告。

You may try to include library headers using -isystem instead of -I. This will make them "system headers" and GCC won't report warnings for them.

你げ笑在眉眼 2024-12-31 18:18:11

对于使用 CMake 的用户,您可以修改 include_directories 指令以包含符号 SYSTEM,该符号会抑制针对此类标头的警告。

include_directories(SYSTEM "${LIB_DIR}/Include")
                    ^^^^^^

For those using CMake, you can modify your include_directories directives to include the symbol SYSTEM which suppresses warnings against such headers.

include_directories(SYSTEM "${LIB_DIR}/Include")
                    ^^^^^^
乙白 2024-12-31 18:18:11

您可以使用编译指示。例如:

// save diagnostic state
#pragma GCC diagnostic push 

// turn off the specific warning. Can also use "-Wall"
#pragma GCC diagnostic ignored "-Wunused-but-set-variable"

#include <boost/uuid/uuid.hpp>
#include <boost/uuid/uuid_generators.hpp>
#include <boost/uuid/uuid_io.hpp>
#include <boost/lexical_cast.hpp>

// turn the warnings back on
#pragma GCC diagnostic pop

You can use pragmas. For example:

// save diagnostic state
#pragma GCC diagnostic push 

// turn off the specific warning. Can also use "-Wall"
#pragma GCC diagnostic ignored "-Wunused-but-set-variable"

#include <boost/uuid/uuid.hpp>
#include <boost/uuid/uuid_generators.hpp>
#include <boost/uuid/uuid_io.hpp>
#include <boost/lexical_cast.hpp>

// turn the warnings back on
#pragma GCC diagnostic pop
离旧人 2024-12-31 18:18:11

我找到了窍门。对于库包含,请在 makefile 中使用 -isystem dir,而不是 -Idir。然后,GCC 将 boost 等视为系统包含的内容,并忽略来自它们的任何警告。

I found the trick. For library includes, instead of -Idir use -isystem dir in the makefile. GCC then treats boost etc. as system includes and ignores any warnings from them.

过潦 2024-12-31 18:18:11

#pragma 是对编译器的指令。您可以在 #include 之前设置一些内容并在 #include 之后禁用它。

您还可以在命令行中执行此操作。

另一个专门关于禁用警告的 GCC 页面。

我会选择在源代码中使用#pragma,然后提供
禁用警告的合理理由(作为评论)。这意味着要对头文件进行推理。

GCC 通过对警告类型进行分类来解决此问题。您可以将它们分类为警告或忽略。之前链接的文章将向您显示哪些警告可能被禁用。

注意:您还可以使用 属性;然而,这将您与 GCC 紧密地联系在一起。

注2:GCC 还使用 pop/push 接口,如微软的编译器——微软通过这个接口禁用警告。我建议你进一步调查这个问题,因为我不知道这是否可能。

#pragma are instructions to the compiler. you can set something before the #include and disable it after.

You can also do it at the command line.

Another GCC page specifically on disabling warnings.

I would go for the option of using #pragma's within the source code, and then providing a
sound reason (as a comment) of why you are disabling the warnings. This would mean reasoning about the headers files.

GCC approaches this by classifying the warning types. You can classify them to be warnings or to be ignored. The previously linked articles will show you which warnings are may be disabled.

Note: you can also massage the source code to prevent certain warnings by using attributes; however, this bind you quite closely to GCC.

Note2: GCC also uses the pop/push interface as used in microsoft's compiler -- Microsoft disables warnings through this interface. I suggest you investigate this further , as I do not know if it is even possible.

烏雲後面有陽光 2024-12-31 18:18:11

放置以下内容

#pragma GCC system_header

将关闭此文件中所有以下代码的 GCC 警告。

Putting the following

#pragma GCC system_header

will turn off GCC warnings for all following code in this file.

本宫微胖 2024-12-31 18:18:11

您可以尝试使用预编译标头。警告不会消失,但至少不会出现在您的主编译中。

You can try using precompiled headers. Warnings won't go away but at least the won't show up in your main compilation.

动听の歌 2024-12-31 18:18:11

如果您需要显式覆盖系统标头,那么您只能使用编译指示。您可以通过 make dependent 输出来验证您正在使用哪些内容。

另请参阅 gcc 的诊断推送-弹出 >= 4.6

If you need to explicitly override a system header then you're restricted to pragmas. You can verify which includes you're using via make depend output.

Also see diagnostic push-pop for gcc >= 4.6

你又不是我 2024-12-31 18:18:11

另一种方法是在 makefile 中告诉编译器忽略特定文件夹的警告:

$(BUILD_DIR)/libs/%.c.o: CFLAGS += -w

Another way to do it is, in the makefile, to tell the compiler to ignore warnings for the specific folder:

$(BUILD_DIR)/libs/%.c.o: CFLAGS += -w
萤火眠眠 2024-12-31 18:18:11

这些警告一定是有原因的。这些可能是由使用该库的代码中的错误引起的,或者是由库代码本身的错误引起的。在第一种情况下,修复您的代码。在第二种情况下,要么停止使用该库,要么如果它是 FOSS 代码,请修复它。

There must be reasons for those warnings. These will either be caused by errors in your code that uses the library, or by errors in the library code itself. In the first case, fix your code. In the second case, either stop using the library or if it is FOSS code, fix it.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文