diff options
author | Junio C Hamano <gitster@pobox.com> | 2017-01-18 00:11:03 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2017-01-18 00:11:03 +0100 |
commit | 07ec05d9e6f54874c6a439fea35ec70ffa05c1a0 (patch) | |
tree | 4d829654e965b28510a52e73209c257e0e7b8878 /path.c | |
parent | Merge branch 'ak/commit-only-allow-empty' into maint (diff) | |
parent | normalize_path_copy(): fix pushing to //server/share/dir on Windows (diff) | |
download | git-07ec05d9e6f54874c6a439fea35ec70ffa05c1a0.tar.xz git-07ec05d9e6f54874c6a439fea35ec70ffa05c1a0.zip |
Merge branch 'js/normalize-path-copy-ceil' into maint
A pathname that begins with "//" or "\\" on Windows is special but
path normalization logic was unaware of it.
* js/normalize-path-copy-ceil:
normalize_path_copy(): fix pushing to //server/share/dir on Windows
Diffstat (limited to 'path.c')
-rw-r--r-- | path.c | 23 |
1 files changed, 14 insertions, 9 deletions
@@ -991,7 +991,7 @@ const char *remove_leading_path(const char *in, const char *prefix) * * Performs the following normalizations on src, storing the result in dst: * - Ensures that components are separated by '/' (Windows only) - * - Squashes sequences of '/'. + * - Squashes sequences of '/' except "//server/share" on Windows * - Removes "." components. * - Removes ".." components, and the components the precede them. * Returns failure (non-zero) if a ".." component appears as first path @@ -1014,17 +1014,22 @@ const char *remove_leading_path(const char *in, const char *prefix) int normalize_path_copy_len(char *dst, const char *src, int *prefix_len) { char *dst0; - int i; + const char *end; - for (i = has_dos_drive_prefix(src); i > 0; i--) - *dst++ = *src++; + /* + * Copy initial part of absolute path: "/", "C:/", "//server/share/". + */ + end = src + offset_1st_component(src); + while (src < end) { + char c = *src++; + if (is_dir_sep(c)) + c = '/'; + *dst++ = c; + } dst0 = dst; - if (is_dir_sep(*src)) { - *dst++ = '/'; - while (is_dir_sep(*src)) - src++; - } + while (is_dir_sep(*src)) + src++; for (;;) { char c = *src; |