[Bf-blender-cvs] [b8cb962fb2e] master: Cleanup: perform string join & allocation in a single step
Campbell Barton
noreply at git.blender.org
Wed Jan 25 00:00:07 CET 2023
Commit: b8cb962fb2ea902d3c50a37f18ff7477ec04f071
Author: Campbell Barton
Date: Wed Jan 25 09:53:36 2023 +1100
Branches: master
https://developer.blender.org/rBb8cb962fb2ea902d3c50a37f18ff7477ec04f071
Cleanup: perform string join & allocation in a single step
===================================================================
M source/blender/blenlib/intern/BLI_filelist.c
===================================================================
diff --git a/source/blender/blenlib/intern/BLI_filelist.c b/source/blender/blenlib/intern/BLI_filelist.c
index 06fb57842e0..2f7662e6220 100644
--- a/source/blender/blenlib/intern/BLI_filelist.c
+++ b/source/blender/blenlib/intern/BLI_filelist.c
@@ -37,6 +37,7 @@
#include "BLI_listbase.h"
#include "BLI_path_util.h"
#include "BLI_string.h"
+#include "BLI_string_utils.h"
#include "../imbuf/IMB_imbuf.h"
@@ -183,17 +184,11 @@ static void bli_builddir(struct BuildDirCtx *dir_ctx, const char *dirname)
struct dirlink *dlink = (struct dirlink *)dirbase.first;
struct direntry *file = &dir_ctx->files[dir_ctx->files_num];
- char fullname[PATH_MAX];
- STRNCPY(fullname, dirname_with_slash);
- char *fullname_name_part = fullname + dirname_with_slash_len;
- const size_t fullname_name_part_len = sizeof(fullname) - dirname_with_slash_len;
-
while (dlink) {
- BLI_strncpy(fullname_name_part, dlink->name, fullname_name_part_len);
memset(file, 0, sizeof(struct direntry));
file->relname = dlink->name;
- file->path = BLI_strdup(fullname);
- if (BLI_stat(fullname, &file->s) != -1) {
+ file->path = BLI_string_joinN(dirname_with_slash, dlink->name);
+ if (BLI_stat(file->path, &file->s) != -1) {
file->type = file->s.st_mode;
}
else if (FILENAME_IS_CURRPAR(file->relname)) {
More information about the Bf-blender-cvs
mailing list