Merge branch 'sk/windows-unc-path'

* sk/windows-unc-path:
  Windows: allow using UNC path for git repository
This commit is contained in:
Junio C Hamano 2014-06-16 10:07:03 -07:00
commit b83163643b
5 changed files with 30 additions and 8 deletions

View File

@ -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

View File

@ -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]);
}

View File

@ -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"

View File

@ -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

7
path.c
View File

@ -823,10 +823,3 @@ int daemon_avoid_alias(const char *p)
} }
} }
} }
int offset_1st_component(const char *path)
{
if (has_dos_drive_prefix(path))
return 2 + is_dir_sep(path[2]);
return is_dir_sep(path[0]);
}