Re: setup_git_directory_gently contract question?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, May 28, 2008 at 1:46 AM, Junio C Hamano <gitster@xxxxxxxxx> wrote:
> "Ciprian Dorin Craciun" <ciprian.craciun@xxxxxxxxx> writes:
>
>>     Is the function setup_git_directory_gently supposed to change the
>> current working directory, or should it keep the initial one?
>>     What is the meaning of nongit_ok?
>
> Most commands that work from subdirectory use setup_git_directory()
> interface, because major parts of the guts of the git internal want you to
> be at the top of the work tree (e.g. so that you grab a path out of the
> index, and be able to open(2) or lstat(2) that path).  A normal sequence
> for a command is: (1) use setup_git_directory() to learn "prefix", (2) use
> get_pathspec() and/or prefix_path() to add "prefix" to the paths given
> from the command to make it a path relative to the work tree, (3) do its
> thing.  setup_git_directory() chdir's up to the top of the work tree for
> this reason.
>
> Some commands can optionally work from even outside a git repository, but
> they would want to operate the same way as other comands, when they are
> started within a git repository.  In such a case, you use "gently"
> variant, and give a pointer to int to store an additional return value to
> signal you if you are inside a git repository or outside.
>
>  * When NULL is given as nongit_ok to gently(), it does not behave gentle
>   at all.  Outside a git repository it dies loudly.
>
>  * If you are inside a git repository, it behaves pretty much the same as
>   setup_git_directory().  "*nongit_ok" is set to zero to signal that you
>   are inside a git repository.
>
>  * If you are outside a git repository, *nongit_ok is set to non-zero so
>   that the caller can tell that it is not in any git repository's work
>   tree.  There is no need to chdir (nor a sensible place to chdir to) in
>   this case, so it doesn't.
>
> The caller thinks of the parameter as "are we operating in non-git mode?"
> boolean, and the callee (i.e. setup_git_directory_gently()) thinks of it
> as "is it ok to be called outside a git repository?" (if it is NULL, the
> caller expects to be inside a repository and wants it to barf otherwise).
> That is why caller's variable are often called "int nongit", and the
> callee's parameter is called "int *nongit_ok".

    Thank you for your complete answer.

    I would propose that these comments to be added to the
Documentation/technical/... directory, (or in the setup.c file), so
that further developers will have this information.

    Thanks again,
    Ciprian.
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux