summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMike Yuan <me@yhndnzj.com>2025-01-16 18:50:54 +0100
committerLuca Boccassi <luca.boccassi@gmail.com>2025-01-17 20:46:37 +0100
commit9cd064aa9ffe8728961859a127c18054c857a5b8 (patch)
tree430074aaa89ff246c3f8b70667016da8a5a979fb
parenthexdump: if size is SIZE_MAX, use strlen() (diff)
downloadsystemd-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.md8
-rw-r--r--meson.build6
-rw-r--r--src/basic/missing_threads.h2
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