diff options
author | Junio C Hamano <gitster@pobox.com> | 2014-06-16 10:07:03 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-06-16 10:07:03 -0700 |
commit | b83163643bd7459385003fa58ae049a31f2984cb (patch) | |
tree | ed048a2befb3b9d4f1a51175db7d2db939bb0b46 /compat/mingw.c | |
parent | Merge branch 'rr/rebase-autostash-fix' (diff) | |
parent | Windows: allow using UNC path for git repository (diff) | |
download | tgif-b83163643bd7459385003fa58ae049a31f2984cb.tar.xz |
Merge branch 'sk/windows-unc-path'
* sk/windows-unc-path:
Windows: allow using UNC path for git repository
Diffstat (limited to 'compat/mingw.c')
-rw-r--r-- | compat/mingw.c | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/compat/mingw.c b/compat/mingw.c index e9892f8ee4..a0e13bc862 100644 --- a/compat/mingw.c +++ b/compat/mingw.c @@ -1823,3 +1823,27 @@ pid_t waitpid(pid_t pid, int *status, int options) errno = EINVAL; return -1; } + +int mingw_offset_1st_component(const char *path) +{ + int offset = 0; + if (has_dos_drive_prefix(path)) + offset = 2; + + /* unc paths */ + else if (is_dir_sep(path[0]) && is_dir_sep(path[1])) { + + /* skip server name */ + char *pos = strpbrk(path + 2, "\\/"); + if (!pos) + return 0; /* Error: malformed unc path */ + + do { + pos++; + } while (*pos && !is_dir_sep(*pos)); + + offset = pos - path; + } + + return offset + is_dir_sep(path[offset]); +} |