From 9fcb0c335bd74e1d1d4d09a74d8fdff9c2eedc6c Mon Sep 17 00:00:00 2001 From: Andrew Alderwick Date: Mon, 10 Jan 2022 11:35:45 +0000 Subject: [PATCH] Remove use of snprintf. --- src/devices/file.c | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/src/devices/file.c b/src/devices/file.c index 039017f..28d7f63 100644 --- a/src/devices/file.c +++ b/src/devices/file.c @@ -13,8 +13,6 @@ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE. */ -#define _POSIX_C_SOURCE 200809L - #include #include #include @@ -53,13 +51,13 @@ get_entry(char *p, Uint16 len, const char *pathname, const char *basename, int f if(len < strlen(basename) + 7) return 0; if(stat(pathname, &st)) - return fail_nonzero ? snprintf(p, len, "!!!! %s\n", basename) : 0; + return fail_nonzero ? sprintf(p, "!!!! %s\n", basename) : 0; else if(S_ISDIR(st.st_mode)) - return snprintf(p, len, "---- %s\n", basename); + return sprintf(p, "---- %s\n", basename); else if(st.st_size < 0x10000) - return snprintf(p, len, "%04x %s\n", (unsigned int)st.st_size, basename); + return sprintf(p, "%04x %s\n", (unsigned int)st.st_size, basename); else - return snprintf(p, len, "???? %s\n", basename); + return sprintf(p, "???? %s\n", basename); } static Uint16 @@ -72,7 +70,10 @@ file_read_dir(char *dest, Uint16 len) Uint16 n; if(de->d_name[0] == '.' && de->d_name[1] == '\0') continue; - snprintf(pathname, sizeof(pathname), "%s/%s", current_filename, de->d_name); + if(strlen(current_filename) + 1 + strlen(de->d_name) < sizeof(pathname)) + sprintf(pathname, "%s/%s", current_filename, de->d_name); + else + pathname[0] = '\0'; n = get_entry(p, len, pathname, de->d_name, 1); if(!n) break; p += n;