Re: setup_git_directory_gently contract question?

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

 



"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".
--
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