On Tue, Jun 13, 2017 at 02:03:20PM -0700, Brandon Williams wrote:

> Currently 'discover_git_directory' only looks at the gitdir to determine
> if a git directory was discovered.  This causes a problem in the event
> that the gitdir which was discovered was in fact a per-worktree git
> directory and not the common git directory.  This is because the
> repository config, which is checked to verify the repository's format,
> is stored in the commondir and not in the per-worktree gitdir.  Correct
> this behavior by checking the config stored in the commondir.
> 
> It will also be of use for callers to have access to the commondir, so
> lets also return that upon successfully discovering a git directory.

This makes sense, and I agree is the correct path forward for handling
the config code's needs.

> diff --git a/cache.h b/cache.h
> index fd45b8c55..a4176436d 100644
> --- a/cache.h
> +++ b/cache.h
> @@ -530,7 +530,8 @@ extern void setup_work_tree(void);
>   * appended to gitdir. The return value is either NULL if no repository was
>   * found, or pointing to the path inside gitdir's buffer.
>   */
> -extern const char *discover_git_directory(struct strbuf *gitdir);
> +extern const char *discover_git_directory(struct strbuf *commondir,
> +                                       struct strbuf *gitdir);

Does the docstring above the function need updating? What happens when
you are not in a worktree? Are both strbufs filled out with the same
value?

That's what I'd assume (and what it looks like looking at the code), but
it's probably worth being explicit.

We also return a pointer. I think this still points into the gitdir
strbuf. Which I guess is reasonable, though probably should be
documented.

Given that the callers only ever look at whether it's non-NULL, it
probably would be better to just return a true/false value. This might
be a good time to do that, because the function signature is changing
already (so if we switch to the usual "0 is success", a newly added call
won't silently do the wrong thing).

> @@ -983,6 +987,7 @@ const char *discover_git_directory(struct strbuf *gitdir)
>               warning("ignoring git dir '%s': %s",
>                       gitdir->buf + gitdir_offset, err.buf);
>               strbuf_release(&err);
> +             strbuf_setlen(commondir, commondir_offset);
>               return NULL;
>       }

I'd have expected these resetting setlens to be paired between gitdir
and commondir. And indeed, they should be; this is the same case that
Dscho fixed in the first patch of his series.

I kind of wonder if one of you should take ownership and do a combined
series.

-Peff

Reply via email to