From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 1791) id DE43B385828B; Mon, 29 Jan 2024 17:55:06 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org DE43B385828B DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sourceware.org; s=default; t=1706550906; bh=lJ0YuKjDhPAZ9Zjb3RJeskRxkL51WlWX1y883Q9FMto=; h=From:To:Subject:Date:From; b=vcxYkGxEGeFEkQEWBN04VsqNNd/t1wEvR+oQi8ZzSs6XCWXRafdQ11Do8jatLb2/l wvn7qmdMxqwyFEK0UG47eZ/iP0R/oi2seNuzCUPtp9xSkACubkq2cBrHjFXgoIDRVb ykLpogQD2dX+JjeFWbnSLMcO7OJBUwcR1bdGUvCI= Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit From: Adhemerval Zanella To: glibc-cvs@sourceware.org Subject: [glibc/azanella/clang] misc: Suppress clang warnings on syslog X-Act-Checkin: glibc X-Git-Author: Adhemerval Zanella X-Git-Refname: refs/heads/azanella/clang X-Git-Oldrev: 6ac58aea0ec1635db6281b05ac932c26144d9756 X-Git-Newrev: b5fd44177ca9bd5e17f201d89ff67229860b5adc Message-Id: <20240129175506.DE43B385828B@sourceware.org> Date: Mon, 29 Jan 2024 17:55:06 +0000 (GMT) List-Id: https://sourceware.org/git/gitweb.cgi?p=glibc.git;h=b5fd44177ca9bd5e17f201d89ff67229860b5adc commit b5fd44177ca9bd5e17f201d89ff67229860b5adc Author: Adhemerval Zanella Date: Fri Apr 29 10:50:13 2022 -0300 misc: Suppress clang warnings on syslog clang complains that adding a 'int_t' to a string does not append to it, but the idea is to print the pid conditionally. Diff: --- misc/syslog.c | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/misc/syslog.c b/misc/syslog.c index 1b8cb722c5..ab1e46ff7d 100644 --- a/misc/syslog.c +++ b/misc/syslog.c @@ -31,6 +31,7 @@ static char sccsid[] = "@(#)syslog.c 8.4 (Berkeley) 3/18/94"; #endif /* LIBC_SCCS and not lint */ +#include #include #include #include @@ -177,6 +178,10 @@ __vsyslog_internal (int pri, const char *fmt, va_list ap, #define SYSLOG_HEADER_WITHOUT_TS(__pri, __msgoff) \ "<%d>: %n", __pri, __msgoff + /* clang complains that adding a 'int_t' to a string does not append to it, + but the idea is to print the pid conditionally. */ + DIAG_PUSH_NEEDS_COMMENT_CLANG; + DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wstring-plus-int"); int l; if (has_ts) l = __snprintf (bufs, sizeof bufs, @@ -184,6 +189,8 @@ __vsyslog_internal (int pri, const char *fmt, va_list ap, else l = __snprintf (bufs, sizeof bufs, SYSLOG_HEADER_WITHOUT_TS (pri, &msgoff)); + DIAG_POP_NEEDS_COMMENT_CLANG; + if (0 <= l && l < sizeof bufs) { va_list apc; @@ -209,6 +216,8 @@ __vsyslog_internal (int pri, const char *fmt, va_list ap, /* Tell the cancellation handler to free this buffer. */ clarg.buf = buf; + DIAG_PUSH_NEEDS_COMMENT_CLANG; + DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wstring-plus-int"); if (has_ts) __snprintf (buf, l + 1, SYSLOG_HEADER (pri, timestamp, &msgoff, pid)); @@ -221,6 +230,7 @@ __vsyslog_internal (int pri, const char *fmt, va_list ap, __vsnprintf_internal (buf + l, bufsize - l + 1, fmt, apc, mode_flags); va_end (apc); + DIAG_POP_NEEDS_COMMENT_CLANG; } else { @@ -233,8 +243,13 @@ __vsyslog_internal (int pri, const char *fmt, va_list ap, /* Output to stderr if requested. */ if (LogStat & LOG_PERROR) - __dprintf (STDERR_FILENO, "%s%s", buf + msgoff, - "\n" + (buf[bufsize - 1] == '\n')); + { + DIAG_PUSH_NEEDS_COMMENT_CLANG; + DIAG_IGNORE_NEEDS_COMMENT_CLANG (13, "-Wstring-plus-int"); + __dprintf (STDERR_FILENO, "%s%s", buf + msgoff, + "\n" + (buf[bufsize - 1] == '\n')); + DIAG_POP_NEEDS_COMMENT_CLANG; + } /* Get connected, output the message to the local logger. */ if (!connected)