mirror of
https://git.proxmox.com/git/libgit2
synced 2025-06-21 12:17:36 +00:00
Merge pull request #3307 from libgit2/cmn/submodule-backslash
Normalize submodule urls before looking at them
This commit is contained in:
commit
2dfd5eae33
16
src/path.c
16
src/path.c
@ -1676,3 +1676,19 @@ bool git_path_isvalid(
|
|||||||
|
|
||||||
return verify_component(repo, start, (c - start), flags);
|
return verify_component(repo, start, (c - start), flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int git_path_normalize_slashes(git_buf *out, const char *path)
|
||||||
|
{
|
||||||
|
int error;
|
||||||
|
char *p;
|
||||||
|
|
||||||
|
if ((error = git_buf_puts(out, path)) < 0)
|
||||||
|
return error;
|
||||||
|
|
||||||
|
for (p = out->ptr; *p; p++) {
|
||||||
|
if (*p == '\\')
|
||||||
|
*p = '/';
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@ -591,4 +591,9 @@ extern bool git_path_isvalid(
|
|||||||
const char *path,
|
const char *path,
|
||||||
unsigned int flags);
|
unsigned int flags);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert any backslashes into slashes
|
||||||
|
*/
|
||||||
|
int git_path_normalize_slashes(git_buf *out, const char *path);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -781,11 +781,21 @@ const char *git_submodule_url(git_submodule *submodule)
|
|||||||
int git_submodule_resolve_url(git_buf *out, git_repository *repo, const char *url)
|
int git_submodule_resolve_url(git_buf *out, git_repository *repo, const char *url)
|
||||||
{
|
{
|
||||||
int error = 0;
|
int error = 0;
|
||||||
|
git_buf normalized = GIT_BUF_INIT;
|
||||||
|
|
||||||
assert(out && repo && url);
|
assert(out && repo && url);
|
||||||
|
|
||||||
git_buf_sanitize(out);
|
git_buf_sanitize(out);
|
||||||
|
|
||||||
|
/* We do this in all platforms in case someone on Windows created the .gitmodules */
|
||||||
|
if (strchr(url, '\\')) {
|
||||||
|
if ((error = git_path_normalize_slashes(&normalized, url)) < 0)
|
||||||
|
return error;
|
||||||
|
|
||||||
|
url = normalized.ptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if (git_path_is_relative(url)) {
|
if (git_path_is_relative(url)) {
|
||||||
if (!(error = get_url_base(out, repo)))
|
if (!(error = get_url_base(out, repo)))
|
||||||
error = git_path_apply_relative(out, url);
|
error = git_path_apply_relative(out, url);
|
||||||
@ -796,6 +806,7 @@ int git_submodule_resolve_url(git_buf *out, git_repository *repo, const char *ur
|
|||||||
error = -1;
|
error = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
git_buf_free(&normalized);
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -151,6 +151,29 @@ void test_submodule_lookup__lookup_even_with_missing_index(void)
|
|||||||
test_submodule_lookup__simple_lookup(); /* baseline should still pass */
|
test_submodule_lookup__simple_lookup(); /* baseline should still pass */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void test_submodule_lookup__backslashes(void)
|
||||||
|
{
|
||||||
|
git_config *cfg;
|
||||||
|
git_submodule *sm;
|
||||||
|
git_repository *subrepo;
|
||||||
|
git_buf buf = GIT_BUF_INIT;
|
||||||
|
const char *backslashed_path = "..\\submod2_target";
|
||||||
|
|
||||||
|
cl_git_pass(git_config_open_ondisk(&cfg, "submod2/.gitmodules"));
|
||||||
|
cl_git_pass(git_config_set_string(cfg, "submodule.sm_unchanged.url", backslashed_path));
|
||||||
|
git_config_free(cfg);
|
||||||
|
|
||||||
|
cl_git_pass(git_submodule_lookup(&sm, g_repo, "sm_unchanged"));
|
||||||
|
cl_assert_equal_s(backslashed_path, git_submodule_url(sm));
|
||||||
|
cl_git_pass(git_submodule_open(&subrepo, sm));
|
||||||
|
|
||||||
|
cl_git_pass(git_submodule_resolve_url(&buf, g_repo, backslashed_path));
|
||||||
|
|
||||||
|
git_buf_free(&buf);
|
||||||
|
git_submodule_free(sm);
|
||||||
|
git_repository_free(subrepo);
|
||||||
|
}
|
||||||
|
|
||||||
static void baseline_tests(void)
|
static void baseline_tests(void)
|
||||||
{
|
{
|
||||||
/* small baseline that should work even if we change the index or make
|
/* small baseline that should work even if we change the index or make
|
||||||
|
Loading…
Reference in New Issue
Block a user