diff options
author | Johannes Schindelin <johannes.schindelin@gmx.de> | 2024-10-30 00:52:16 +0100 |
---|---|---|
committer | Johannes Schindelin <johannes.schindelin@gmx.de> | 2024-11-26 22:14:59 +0100 |
commit | c39c2d29e62d5bd13f390ca20f6e756aced681b1 (patch) | |
tree | 63a1b00a4df948d65f46b0d3cc382bfe4037085a /strbuf.c | |
parent | Git 2.43.5 (diff) | |
parent | Git 2.42.4 (diff) | |
download | git-c39c2d29e62d5bd13f390ca20f6e756aced681b1.tar.xz git-c39c2d29e62d5bd13f390ca20f6e756aced681b1.zip |
Sync with 2.42.4
* maint-2.42:
Git 2.42.4
Git 2.41.3
Git 2.40.4
credential: disallow Carriage Returns in the protocol by default
credential: sanitize the user prompt
credential_format(): also encode <host>[:<port>]
t7300: work around platform-specific behaviour with long paths on MinGW
compat/regex: fix argument order to calloc(3)
mingw: drop bogus (and unneeded) declaration of `_pgmptr`
ci: remove 'Upload failed tests' directories' step from linux32 jobs
Diffstat (limited to 'strbuf.c')
-rw-r--r-- | strbuf.c | 4 |
1 files changed, 3 insertions, 1 deletions
@@ -463,7 +463,9 @@ void strbuf_add_percentencode(struct strbuf *dst, const char *src, int flags) unsigned char ch = src[i]; if (ch <= 0x1F || ch >= 0x7F || (ch == '/' && (flags & STRBUF_ENCODE_SLASH)) || - strchr(URL_UNSAFE_CHARS, ch)) + ((flags & STRBUF_ENCODE_HOST_AND_PORT) ? + !isalnum(ch) && !strchr("-.:[]", ch) : + !!strchr(URL_UNSAFE_CHARS, ch))) strbuf_addf(dst, "%%%02X", (unsigned char)ch); else strbuf_addch(dst, ch); |