[v1] Add Reiwa era tests to time/tst-strftime3.c
Commit Message
Steve Ellcey <sellcey@marvell.com> writes:
> tst-strftime3.c:443:62: error: ā%sā directive output may be truncated writing up to 49 bytes into a region of size between 0 and 30 [-Werror=format-truncation=]
Fixed thusly:
snprintf will only truncate the output if the data its given
is corrupted, but a truncated buffer will not match the
"pristine" data's buffer, which is all we need. So just
disable the warning via the DIAG macros.
2019-04-03 DJ Delorie <dj@redhat.com>
* time/tst-strftime3.c (tm_to_printed): Disable warning about
snprintf truncating output.
Comments
On 4/3/19 5:55 PM, DJ Delorie wrote:
> Steve Ellcey <sellcey@marvell.com> writes:
>> tst-strftime3.c:443:62: error: ā%sā directive output may be truncated writing up to 49 bytes into a region of size between 0 and 30 [-Werror=format-truncation=]
>
> Fixed thusly:
>
> snprintf will only truncate the output if the data its given
> is corrupted, but a truncated buffer will not match the
> "pristine" data's buffer, which is all we need. So just
> disable the warning via the DIAG macros.
Thank you for fixing this.
We can always circle back and change things later if we find a way
to do this without DIAG_* macros, but we should fix the regression
first and formost so people like Steve don't have their builds
impacted.
It is *always* OK to use DIAG_* macros in a sensible way like this
to unbreak the builds. We can always change it later.
Cheers,
Carlos.
@@ -25,6 +25,7 @@
#include <support/check.h>
#include <array_length.h>
+#include <libc-diag.h>
/* These exist for the convenience of writing the test data, because
zero-based vs one-based. */
@@ -440,6 +441,14 @@ tm_to_printed (struct tm *tm, char *buffer)
sprintf (temp, "%d", tm->tm_wday);
}
+ DIAG_PUSH_NEEDS_COMMENT;
+#if __GNUC_PREREQ (9, 0)
+ /* GCC 9 warns that strncmp may truncate its output, but that's why
+ we're using it. When it needs to truncate, it got corrupted
+ data, and we only care that the string is different than valid
+ data, which won't truncate. */
+ DIAG_IGNORE_NEEDS_COMMENT (9, "-Wformat-truncation=");
+#endif
snprintf (buffer, TMBUFLEN, "%04d/%02d/%02d %02d:%02d:%02d %s",
tm->tm_year + 1900,
tm->tm_mon + 1,
@@ -448,6 +457,7 @@ tm_to_printed (struct tm *tm, char *buffer)
tm->tm_min,
tm->tm_sec,
wn);
+ DIAG_POP_NEEDS_COMMENT;
}
static int