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 | |
| parent | 4a43d4f98a1a6a472ce1e87c64cb6df0d1653d02 (diff) | |
| parent | c2369bdf7ff082d588c4a4efe280bc4a483d0192 (diff) | |
| download | git-b83163643bd7459385003fa58ae049a31f2984cb.tar.gz | |
Merge branch 'sk/windows-unc-path'
* sk/windows-unc-path:
  Windows: allow using UNC path for git repository
| -rw-r--r-- | cache.h | 1 | ||||
| -rw-r--r-- | compat/mingw.c | 24 | ||||
| -rw-r--r-- | compat/mingw.h | 2 | ||||
| -rw-r--r-- | git-compat-util.h | 4 | ||||
| -rw-r--r-- | path.c | 7 | 
5 files changed, 30 insertions, 8 deletions
| @@ -826,7 +826,6 @@ int normalize_path_copy(char *dst, const char *src);  int longest_ancestor_length(const char *path, struct string_list *prefixes);  char *strip_path_suffix(const char *path, const char *suffix);  int daemon_avoid_alias(const char *path); -int offset_1st_component(const char *path);  /* object replacement */  #define LOOKUP_REPLACE_OBJECT 1 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]); +} diff --git a/compat/mingw.h b/compat/mingw.h index e033e720c9..3eaf822e28 100644 --- a/compat/mingw.h +++ b/compat/mingw.h @@ -339,6 +339,8 @@ static inline char *mingw_find_last_dir_sep(const char *path)  	return ret;  }  #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 PRIuMAX "I64u"  #define PRId64 "I64d" diff --git a/git-compat-util.h b/git-compat-util.h index 7849d31405..b6f03b36dc 100644 --- a/git-compat-util.h +++ b/git-compat-util.h @@ -267,6 +267,10 @@ extern char *gitbasename(char *);  #define has_dos_drive_prefix(path) 0  #endif +#ifndef offset_1st_component +#define offset_1st_component(path) (is_dir_sep((path)[0])) +#endif +  #ifndef is_dir_sep  #define is_dir_sep(c) ((c) == '/')  #endif @@ -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]); -} | 
