submodule: extract path to submodule gitdir func
We currently store each submodule gitdir in ".git/modules/<name>", but this has problems with some submodule naming schemes, as described in a comment in submodule_name_to_gitdir() in this patch. Extract the determination of the location of a submodule's gitdir into its own function submodule_name_to_gitdir(). For now, the problem remains unsolved, but this puts us in a better position for finding a solution. This was motivated, at $DAYJOB, by a part of Android's repo hierarchy [1]. In particular, there is a repo "build", and several repos of the form "build/<name>". This is based on earlier work by Brandon Williams [2]. [1] https://android.googlesource.com/platform/ [2] https://lore.kernel.org/git/20180808223323.79989-2-bmwill@google.com/ Signed-off-by: Jonathan Tan <jonathantanmy@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
8b7c11b866
commit
ce125d431a
@ -1704,18 +1704,24 @@ static int add_possible_reference_from_superproject(
|
||||
* standard layout with .git/(modules/<name>)+/objects
|
||||
*/
|
||||
if (strip_suffix(odb->path, "/objects", &len)) {
|
||||
struct repository alternate;
|
||||
char *sm_alternate;
|
||||
struct strbuf sb = STRBUF_INIT;
|
||||
struct strbuf err = STRBUF_INIT;
|
||||
strbuf_add(&sb, odb->path, len);
|
||||
|
||||
repo_init(&alternate, sb.buf, NULL);
|
||||
|
||||
/*
|
||||
* We need to end the new path with '/' to mark it as a dir,
|
||||
* otherwise a submodule name containing '/' will be broken
|
||||
* as the last part of a missing submodule reference would
|
||||
* be taken as a file name.
|
||||
*/
|
||||
strbuf_addf(&sb, "/modules/%s/", sas->submodule_name);
|
||||
strbuf_reset(&sb);
|
||||
submodule_name_to_gitdir(&sb, &alternate, sas->submodule_name);
|
||||
strbuf_addch(&sb, '/');
|
||||
repo_clear(&alternate);
|
||||
|
||||
sm_alternate = compute_alternate_path(sb.buf, &err);
|
||||
if (sm_alternate) {
|
||||
@ -1785,7 +1791,7 @@ static int clone_submodule(struct module_clone_data *clone_data)
|
||||
struct strbuf sb = STRBUF_INIT;
|
||||
struct child_process cp = CHILD_PROCESS_INIT;
|
||||
|
||||
strbuf_addf(&sb, "%s/modules/%s", get_git_dir(), clone_data->name);
|
||||
submodule_name_to_gitdir(&sb, the_repository, clone_data->name);
|
||||
sm_gitdir = absolute_pathdup(sb.buf);
|
||||
strbuf_reset(&sb);
|
||||
|
||||
|
Reference in New Issue
Block a user