Prefer memcpy to strncpy if either will do

strncpy is trickier and a bit slower.
* src/function.c (func_realpath, func_abspath):
* src/misc.c (xstrndup):
Prefer memcpy or mempcpy to strncpy when the source length is known.
This commit is contained in:
Paul Eggert 2024-08-05 01:21:09 -07:00 committed by Paul Smith
parent 4d3bf7838f
commit c23a7e6232
2 changed files with 7 additions and 7 deletions

View file

@ -2109,7 +2109,7 @@ abspath (const char *name, char *apath)
apath[3] = '/'; apath[3] = '/';
dest++; dest++;
root_len++; root_len++;
/* strncpy above copied one character too many. */ /* memcpy above copied one character too many. */
name--; name--;
} }
else else
@ -2178,13 +2178,13 @@ func_realpath (char *o, char **argv, const char *funcname UNUSED)
{ {
if (len < GET_PATH_MAX) if (len < GET_PATH_MAX)
{ {
char *rp; char *rp, *inend;
struct stat st; struct stat st;
PATH_VAR (in); PATH_VAR (in);
PATH_VAR (out); PATH_VAR (out);
strncpy (in, path, len); inend = mempcpy (in, path, len);
in[len] = '\0'; *inend = '\0';
#ifdef HAVE_REALPATH #ifdef HAVE_REALPATH
ENULLLOOP (rp, realpath (in, out)); ENULLLOOP (rp, realpath (in, out));
@ -2353,9 +2353,9 @@ func_abspath (char *o, char **argv, const char *funcname UNUSED)
{ {
PATH_VAR (in); PATH_VAR (in);
PATH_VAR (out); PATH_VAR (out);
char *inend = mempcpy (in, path, len);
strncpy (in, path, len); *inend = '\0';
in[len] = '\0';
if (abspath (in, out)) if (abspath (in, out))
{ {

View file

@ -351,7 +351,7 @@ xstrndup (const char *str, size_t length)
#else #else
result = xmalloc (length + 1); result = xmalloc (length + 1);
if (length > 0) if (length > 0)
strncpy (result, str, length); memcpy (result, str, length);
result[length] = '\0'; result[length] = '\0';
#endif #endif