Skip to content

Commit

Permalink
github-actions: Further improve cppcheck accuracy
Browse files Browse the repository at this point in the history
Teach cppcheck the C11 _Noreturn attribute.
  • Loading branch information
cwendling committed Nov 15, 2023
1 parent 2c203b1 commit 649764a
Showing 1 changed file with 11 additions and 0 deletions.
11 changes: 11 additions & 0 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -236,6 +236,16 @@ jobs:
# - Wayland-related stuff
# - in-process for Wayland
# - optional features
# - _Noreturn: this is to avoid false positive with functions that
# don't return, like g_assert(false). Here, we rely on G_NORETURN
# (GLib 2.68+) using _Noreturn C11 attribute if __STDC_VERSION__ is
# high enough (which cppcheck sets for us if it's in the right mode);
# but the version of cppcheck we run on don't know about the C11
# attribute, so map it to the GCC one it does know.
# This is a tad over-specific, but it removes some spurious warnings,
# and defining e.g. __GNUC__=12 is simpler, but is a *lot* slower
# (more than 3 times slower), and doesn't seem to yield other
# benefits for the moment.
# - -I flags from pkg-config (grepped from configure.ac)
# - ignore non-source directories
- name: cppcheck
Expand All @@ -248,6 +258,7 @@ jobs:
-DHAVE_WINDOW_PREVIEWS
-DHAVE_LANGINFO_H
-DGETTEXT_PACKAGE='"mate-panel"'
-D_Noreturn='__attribute__((__noreturn__))'
packages: >
gdk-pixbuf-2.0
gio-unix-2.0
Expand Down

0 comments on commit 649764a

Please sign in to comment.