diff options
author | Mike Yuan <me@yhndnzj.com> | 2025-01-16 18:50:54 +0100 |
---|---|---|
committer | Luca Boccassi <luca.boccassi@gmail.com> | 2025-01-17 20:46:37 +0100 |
commit | 9cd064aa9ffe8728961859a127c18054c857a5b8 (patch) | |
tree | 430074aaa89ff246c3f8b70667016da8a5a979fb | |
parent | hexdump: if size is SIZE_MAX, use strlen() (diff) | |
download | systemd-9cd064aa9ffe8728961859a127c18054c857a5b8.tar.xz systemd-9cd064aa9ffe8728961859a127c18054c857a5b8.zip |
meson: bump C std to gnu17
GCC 8.4 (our baseline) defaults to gnu17 already.
-rw-r--r-- | docs/CODING_STYLE.md | 8 | ||||
-rw-r--r-- | meson.build | 6 | ||||
-rw-r--r-- | src/basic/missing_threads.h | 2 |
3 files changed, 8 insertions, 8 deletions
diff --git a/docs/CODING_STYLE.md b/docs/CODING_STYLE.md index 48fa4b093d..b8b420c142 100644 --- a/docs/CODING_STYLE.md +++ b/docs/CODING_STYLE.md @@ -151,16 +151,16 @@ SPDX-License-Identifier: LGPL-2.1-or-later ## Code Organization and Semantics -- For our codebase we intend to use ISO C11 *with* GNU extensions (aka - "gnu11"). Public APIs (i.e. those we expose via `libsystemd.so` +- For our codebase we intend to use ISO C17 *with* GNU extensions (aka + "gnu17"). Public APIs (i.e. those we expose via `libsystemd.so` i.e. `systemd/sd-*.h`) should only use ISO C89 however (with a very limited set of conservative and common extensions, such as fixed size integer types - from `<inttypes.h>`), so that we don't force consuming programs into C11 + from `<inttypes.h>`), so that we don't force consuming programs into C17 mode. (This discrepancy in particular means one thing: internally we use C99 `bool` booleans, externally C89-compatible `int` booleans which generally have different size in memory and slightly different semantics, also see below.) Both for internal and external code it's OK to use even newer - features and GCC extension than "gnu11", as long as there's reasonable + features and GCC extension than "gnu17", as long as there's reasonable fallback #ifdeffery in place to ensure compatibility is retained with older compilers. diff --git a/meson.build b/meson.build index 617d6d2452..d567f25566 100644 --- a/meson.build +++ b/meson.build @@ -4,7 +4,7 @@ project('systemd', 'c', version : files('meson.version'), license : 'LGPLv2+', default_options: [ - 'c_std=gnu11', + 'c_std=gnu17', 'prefix=/usr', 'sysconfdir=/etc', 'localstatedir=/var', @@ -1761,7 +1761,7 @@ python_39 = python.language_version().version_compare('>=3.9') if conf.get('BPF_FRAMEWORK') == 1 bpf_clang_flags = [ - '-std=gnu11', + '-std=gnu17', '-Wno-compare-distinct-pointer-types', '-fno-stack-protector', '-O2', @@ -1772,7 +1772,7 @@ if conf.get('BPF_FRAMEWORK') == 1 ] bpf_gcc_flags = [ - '-std=gnu11', + '-std=gnu17', '-fno-stack-protector', '-fno-ssa-phiopt', '-O2', diff --git a/src/basic/missing_threads.h b/src/basic/missing_threads.h index d48e05d586..c7da1dbd5e 100644 --- a/src/basic/missing_threads.h +++ b/src/basic/missing_threads.h @@ -5,7 +5,7 @@ #if HAVE_THREADS_H # include <threads.h> #elif !(defined(thread_local)) -# if __STDC_VERSION__ >= 201112L && !(defined(__STDC_NO_THREADS__)) +# ifndef __STDC_NO_THREADS__ # define thread_local _Thread_local # else # define thread_local __thread |