Merge branch 'sk/windows-unc-path'
* sk/windows-unc-path: Windows: allow using UNC path for git repository
This commit is contained in:
commit
b83163643b
1
cache.h
1
cache.h
@ -826,7 +826,6 @@ int normalize_path_copy(char *dst, const char *src);
|
|||||||
int longest_ancestor_length(const char *path, struct string_list *prefixes);
|
int longest_ancestor_length(const char *path, struct string_list *prefixes);
|
||||||
char *strip_path_suffix(const char *path, const char *suffix);
|
char *strip_path_suffix(const char *path, const char *suffix);
|
||||||
int daemon_avoid_alias(const char *path);
|
int daemon_avoid_alias(const char *path);
|
||||||
int offset_1st_component(const char *path);
|
|
||||||
|
|
||||||
/* object replacement */
|
/* object replacement */
|
||||||
#define LOOKUP_REPLACE_OBJECT 1
|
#define LOOKUP_REPLACE_OBJECT 1
|
||||||
|
@ -1823,3 +1823,27 @@ pid_t waitpid(pid_t pid, int *status, int options)
|
|||||||
errno = EINVAL;
|
errno = EINVAL;
|
||||||
return -1;
|
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]);
|
||||||
|
}
|
||||||
|
@ -339,6 +339,8 @@ static inline char *mingw_find_last_dir_sep(const char *path)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
#define find_last_dir_sep mingw_find_last_dir_sep
|
#define find_last_dir_sep mingw_find_last_dir_sep
|
||||||
|
int mingw_offset_1st_component(const char *path);
|
||||||
|
#define offset_1st_component mingw_offset_1st_component
|
||||||
#define PATH_SEP ';'
|
#define PATH_SEP ';'
|
||||||
#define PRIuMAX "I64u"
|
#define PRIuMAX "I64u"
|
||||||
#define PRId64 "I64d"
|
#define PRId64 "I64d"
|
||||||
|
@ -267,6 +267,10 @@ extern char *gitbasename(char *);
|
|||||||
#define has_dos_drive_prefix(path) 0
|
#define has_dos_drive_prefix(path) 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef offset_1st_component
|
||||||
|
#define offset_1st_component(path) (is_dir_sep((path)[0]))
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef is_dir_sep
|
#ifndef is_dir_sep
|
||||||
#define is_dir_sep(c) ((c) == '/')
|
#define is_dir_sep(c) ((c) == '/')
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user