aboutsummaryrefslogtreecommitdiff
path: root/dir.c
diff options
context:
space:
mode:
authorCollin Funk <collin.funk1@gmail.com>2026-03-08 20:23:06 -0700
committerJunio C Hamano <gitster@pobox.com>2026-03-09 21:52:07 -0700
commit02cbae61df7b3493e7f76f8385fc9257de60755f (patch)
tree5091f610da49e5036f9b534b687065b1e610cc9d /dir.c
parent1ac1d4e761c5f394526873b364ba23cf5b9b0da5 (diff)
downloadgit-02cbae61df7b3493e7f76f8385fc9257de60755f.tar.xz
dir: avoid -Wdiscarded-qualifiers in remove_path()
When building with glibc-2.43 there is the following warning: dir.c:3526:15: warning: assignment discards ‘const’ qualifier from pointer target type [-Wdiscarded-qualifiers] 3526 | slash = strrchr(name, '/'); | ^ In this case we use a non-const pointer to get the last slash of the unwritable file name, and then use it again to write in the strdup'd file name. We can avoid this warning and make the code a bit more clear by using a separate variable to access the original argument and its strdup'd copy. Signed-off-by: Collin Funk <collin.funk1@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'dir.c')
-rw-r--r--dir.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/dir.c b/dir.c
index b00821f294..046a8bbf32 100644
--- a/dir.c
+++ b/dir.c
@@ -3516,15 +3516,15 @@ int get_sparse_checkout_patterns(struct pattern_list *pl)
int remove_path(const char *name)
{
- char *slash;
+ const char *last;
if (unlink(name) && !is_missing_file_error(errno))
return -1;
- slash = strrchr(name, '/');
- if (slash) {
+ last = strrchr(name, '/');
+ if (last) {
char *dirs = xstrdup(name);
- slash = dirs + (slash - name);
+ char *slash = dirs + (last - name);
do {
*slash = '\0';
if (startup_info->original_cwd &&