diff options
| author | Vicent Martà <tanoku@gmail.com> | 2012-05-23 15:05:03 -0700 | 
|---|---|---|
| committer | Vicent Martà <tanoku@gmail.com> | 2012-05-23 15:05:03 -0700 | 
| commit | 87ac556f2f74a9a49c8d3ee8f9b7104fc4d287c8 (patch) | |
| tree | 637d70ebb04bb43f43944b460de3d3b864aa2244 /src | |
| parent | c4c9de6a272e5111920b63865d4405e33afb5bcf (diff) | |
| parent | dc07184fa9f187eddab16b2996db24e9731aa3f0 (diff) | |
| download | libgit2-87ac556f2f74a9a49c8d3ee8f9b7104fc4d287c8.tar.gz | |
Merge pull request #720 from nulltoken/fix/libgit2sharp_issue_153
Make git_futils_mkdir_r() able to cope with Windows network paths
Diffstat (limited to 'src')
| -rw-r--r-- | src/fileops.c | 22 | ||||
| -rw-r--r-- | src/fileops.h | 3 | 
2 files changed, 18 insertions, 7 deletions
| diff --git a/src/fileops.c b/src/fileops.c index ee9d4212d..d6960ca1a 100644 --- a/src/fileops.c +++ b/src/fileops.c @@ -241,28 +241,36 @@ void git_futils_mmap_free(git_map *out)  int git_futils_mkdir_r(const char *path, const char *base, const mode_t mode)  { -	int root_path_offset;  	git_buf make_path = GIT_BUF_INIT; -	size_t start; +	size_t start = 0;  	char *pp, *sp;  	bool failed = false;  	if (base != NULL) { +		/* +		 * when a base is being provided, it is supposed to already exist. +		 * Therefore, no attempt is being made to recursively create this leading path +		 * segment. It's just skipped. */  		start = strlen(base);  		if (git_buf_joinpath(&make_path, base, path) < 0)  			return -1;  	} else { -		start = 0; +		int root_path_offset; +  		if (git_buf_puts(&make_path, path) < 0)  			return -1; + +		root_path_offset = git_path_root(make_path.ptr); +		if (root_path_offset > 0) { +			 /* +			  * On Windows, will skip the drive name (eg. C: or D:) +			  * or the leading part of a network path (eg. //computer_name ) */ +			start = root_path_offset; +		}  	}  	pp = make_path.ptr + start; -	root_path_offset = git_path_root(make_path.ptr); -	if (root_path_offset > 0) -		pp += root_path_offset; /* On Windows, will skip the drive name (eg. C: or D:) */ -  	while (!failed && (sp = strchr(pp, '/')) != NULL) {  		if (sp != pp && git_path_isdir(make_path.ptr) == false) {  			*sp = 0; diff --git a/src/fileops.h b/src/fileops.h index be619d620..b0c5779e5 100644 --- a/src/fileops.h +++ b/src/fileops.h @@ -49,6 +49,9 @@ extern int git_futils_creat_locked_withpath(const char *path, const mode_t dirmo  /**   * Create a path recursively + * + * If a base parameter is being passed, it's expected to be valued with a path pointing to an already + * exisiting directory.   */  extern int git_futils_mkdir_r(const char *path, const char *base, const mode_t mode); | 
