Windows: allow using UNC path for git repository

[efl: moved MinGW-specific part to compat/]
[jes: fixed compilation on non-Windows]

Eric Sunshine fixed mingw_offset_1st_component() to return
consistently "foo" for UNC "//machine/share/foo", cf

http://groups.google.com/group/msysgit/browse_thread/thread/c0af578549b5dda0

Author: Eric Sunshine <sunshine@sunshineco.com>
Signed-off-by: Cezary Zawadka <czawadka@gmail.com>
Signed-off-by: Eric Sunshine <sunshine@sunshineco.com>
Signed-off-by: Erik Faye-Lund <kusmabite@gmail.com>
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Stepan Kasal <kasal@ucw.cz>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Cezary Zawadka 2010-07-13 16:17:43 +02:00 коммит произвёл Junio C Hamano
Родитель eea591373e
Коммит c2369bdf7f
5 изменённых файлов: 30 добавлений и 8 удалений

Просмотреть файл

@ -781,7 +781,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"

Просмотреть файл

@ -270,6 +270,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
Просмотреть файл

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