Stefan Beller <sbel...@google.com> writes:

> +                     if (!strcmp(arg, "--show-superproject-working-tree")) {
> +                             const char *superproject = 
> get_superproject_working_tree();
> +                             if (superproject)
> +                                     puts(superproject);
> +                             continue;
> +                     }

Returning the exact string of the path from the API function is
absolutely the right thing. I however have to wonder if rev-parse
need to do the c-quoting unless it is told to show pathnames in its
output without quoting (perhaps with "-z").  Paths from "rev-parse"
(like "--git-dir", "--show-toplevel", etc.) already are excempt from
the usual quoting rules, so doing puts() and nothing else is fine to
be consistent with the existing practice, but in the longer term, I
am sure we would need to revisit so that scripts can handle paths
with funny characters sensibly, but that would be a different topic
if existing ones like "--git-dir" are already unsafe.

>                       if (!strcmp(arg, "--show-prefix")) {
>                               if (prefix)
>                                       puts(prefix);
> diff --git a/submodule.c b/submodule.c
> index 3b98766a6b..06473d3646 100644
> --- a/submodule.c
> +++ b/submodule.c
> @@ -1514,3 +1514,86 @@ void absorb_git_dir_into_superproject(const char 
> *prefix,
>               strbuf_release(&sb);
>       }
>  }
> +
> +const char *get_superproject_working_tree(void)
> +{
> +...
> +     argv_array_pushl(&cp.args, "--literal-pathspecs", "-C", "..",
> +                     "ls-files", "--stage", "--full-name", "--", subpath, 
> NULL);
> +     strbuf_reset(&sb);
> +...
> +     if (starts_with(sb.buf, "160000")) {
> +             int super_sub_len;
> +             int cwd_len = strlen(cwd);
> +             char *super_sub, *super_wt;
> +
> +             /*
> +              * There is a superproject having this repo as a submodule.
> +              * The format is <mode> SP <hash> SP <stage> TAB <full name> LF,
> +              * First remove LF, then skip up to \t.
> +              */

Looks more or less right but invoke "ls-files -z" and reading the \0
delimited output would be easier; otherwise you would have to worry
about c-unquoting the pathname when the submodule is bound at a path
with funny character (like a double-quote) in it.

Reply via email to