Merge branch 'jk/submodule-init-segv-fix'

Fix a segv in 'submodule init' when url is not given for a submodule.

* jk/submodule-init-segv-fix:
  submodule_init: die cleanly on submodules without url defined
This commit is contained in:
Junio C Hamano 2017-05-01 14:14:43 +09:00
Родитель b0f89870ea 627fde1025
Коммит d92dbf1934
2 изменённых файлов: 11 добавлений и 3 удалений

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

@ -376,12 +376,12 @@ static void init_submodule(const char *path, const char *prefix, int quiet)
strbuf_reset(&sb); strbuf_reset(&sb);
strbuf_addf(&sb, "submodule.%s.url", sub->name); strbuf_addf(&sb, "submodule.%s.url", sub->name);
if (git_config_get_string(sb.buf, &url)) { if (git_config_get_string(sb.buf, &url)) {
url = xstrdup(sub->url); if (!sub->url)
if (!url)
die(_("No url found for submodule path '%s' in .gitmodules"), die(_("No url found for submodule path '%s' in .gitmodules"),
displaypath); displaypath);
url = xstrdup(sub->url);
/* Possibly a url relative to parent */ /* Possibly a url relative to parent */
if (starts_with_dot_dot_slash(url) || if (starts_with_dot_dot_slash(url) ||
starts_with_dot_slash(url)) { starts_with_dot_slash(url)) {

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

@ -38,6 +38,14 @@ test_expect_success 'submodule update aborts on missing .gitmodules file' '
test_i18ngrep "Submodule path .sub. not initialized" actual test_i18ngrep "Submodule path .sub. not initialized" actual
' '
test_expect_success 'submodule update aborts on missing gitmodules url' '
test_when_finished "git update-index --remove sub" &&
git update-index --add --cacheinfo 160000,$(git rev-parse HEAD),sub &&
test_when_finished "rm -f .gitmodules" &&
git config -f .gitmodules submodule.s.path sub &&
test_must_fail git submodule init
'
test_expect_success 'configuration parsing' ' test_expect_success 'configuration parsing' '
test_when_finished "rm -f .gitmodules" && test_when_finished "rm -f .gitmodules" &&
cat >.gitmodules <<-\EOF && cat >.gitmodules <<-\EOF &&