vim-patch:partial:9.1.1050: too many strlen() calls in os_unix.c (#32188)

Problem:  too many strlen() calls in os_unix.c
Solution: refactor os_unix.c and remove calls to strlen()
          (John Marriott)

closes: vim/vim#16496

efc41a5958

Omit os_expand_wildcards() change: Nvim's code is more complicated and
harder to refactor.

Co-authored-by: John Marriott <basilisk@internode.on.net>
This commit is contained in:
zeertzjq
2025-01-24 08:52:55 +08:00
committed by GitHub
parent 8bc28978b6
commit 2470db02c5
3 changed files with 16 additions and 15 deletions

View File

@@ -1875,11 +1875,12 @@ void path_fix_case(char *name)
return;
}
size_t taillen = strlen(tail);
const char *entry;
while ((entry = os_scandir_next(&dir))) {
// Only accept names that differ in case and are the same byte
// length. TODO: accept different length name.
if (STRICMP(tail, entry) == 0 && strlen(tail) == strlen(entry)) {
if (STRICMP(tail, entry) == 0 && taillen == strlen(entry)) {
char newname[MAXPATHL + 1];
// Verify the inode is equal.
@@ -2270,14 +2271,12 @@ int append_path(char *path, const char *to_append, size_t max_len)
// Combine the path segments, separated by a slash.
if (current_length > 0 && !vim_ispathsep_nocolon(path[current_length - 1])) {
current_length += 1; // Count the trailing slash.
// +1 for the NUL at the end.
if (current_length + 1 > max_len) {
return FAIL;
if (current_length + STRLEN_LITERAL(PATHSEPSTR) + 1 > max_len) {
return FAIL; // No space for trailing slash.
}
xstrlcat(path, PATHSEPSTR, max_len);
xstrlcpy(path + current_length, PATHSEPSTR, max_len - current_length);
current_length += STRLEN_LITERAL(PATHSEPSTR);
}
// +1 for the NUL at the end.
@@ -2285,7 +2284,7 @@ int append_path(char *path, const char *to_append, size_t max_len)
return FAIL;
}
xstrlcat(path, to_append, max_len);
xstrlcpy(path + current_length, to_append, max_len - current_length);
return OK;
}