From 874f1b9bd817c0fa7e9fb231ec2e377c819d73a4 Mon Sep 17 00:00:00 2001 From: Roland McGrath Date: Tue, 25 Jul 1995 14:47:53 +0000 Subject: [PATCH] Tue Jul 25 09:14:53 1995 Roland McGrath * stdio/vfprintf.c (vfprintf): For %s with precision spec, use memchr instead of strlen to limit search for NUL by precision. --- ChangeLog | 5 +++++ stdio/vfprintf.c | 23 +++++++++++++++++------ 2 files changed, 22 insertions(+), 6 deletions(-) diff --git a/ChangeLog b/ChangeLog index 5e22580c13..c329a30a64 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Tue Jul 25 09:14:53 1995 Roland McGrath + + * stdio/vfprintf.c (vfprintf): For %s with precision spec, use + memchr instead of strlen to limit search for NUL by precision. + Mon Jul 24 03:13:16 1995 Roland McGrath * sysdeps/posix/pathconf.c: New file. diff --git a/stdio/vfprintf.c b/stdio/vfprintf.c index 056ea32bee..1246229a63 100644 --- a/stdio/vfprintf.c +++ b/stdio/vfprintf.c @@ -531,13 +531,24 @@ vfprintf (s, format, ap) len = 0; } } - else - len = strlen (str); + else if (specs[cnt].info.prec != -1) + { + const char *end = memchr (str, '\0', specs[cnt].info.prec); + if (end) + len = end - str; + else + len = strlen (str); + } + else + { + len = strlen (str); + + if (specs[cnt].info.prec != -1 + && (size_t) specs[cnt].info.prec < len) + /* Limit the length to the precision. */ + len = specs[cnt].info.prec; + } - if (specs[cnt].info.prec != -1 - && (size_t) specs[cnt].info.prec < len) - /* Limit the length to the precision. */ - len = specs[cnt].info.prec; specs[cnt].info.width -= len; if (!specs[cnt].info.left) -- 2.43.5