The number of odd cases in which git will try to read config is far too
great to keep putting a bandaid over each one, so we'll just unset it.
If it turns out that scripts really liked to know about $HOME, we can
always reset it in the filter forks.
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
static int prepare_repo_cmd(struct cgit_context *ctx)
{
static int prepare_repo_cmd(struct cgit_context *ctx)
{
- char *user_home;
- char *xdg_home;
unsigned char sha1[20];
int nongit = 0;
int rc;
unsigned char sha1[20];
int nongit = 0;
int rc;
/* Do not look in /etc/ for gitconfig and gitattributes. */
setenv("GIT_CONFIG_NOSYSTEM", "1", 1);
setenv("GIT_ATTR_NOSYSTEM", "1", 1);
/* Do not look in /etc/ for gitconfig and gitattributes. */
setenv("GIT_CONFIG_NOSYSTEM", "1", 1);
setenv("GIT_ATTR_NOSYSTEM", "1", 1);
-
- /* We unset HOME and XDG_CONFIG_HOME before calling the git setup function
- * so that we don't make unneccessary filesystem accesses. */
- user_home = getenv("HOME");
- xdg_home = getenv("XDG_CONFIG_HOME");
unsetenv("HOME");
unsetenv("XDG_CONFIG_HOME");
unsetenv("HOME");
unsetenv("XDG_CONFIG_HOME");
setup_git_directory_gently(&nongit);
init_display_notes(NULL);
setup_git_directory_gently(&nongit);
init_display_notes(NULL);
- /* We restore the unset variables afterward. */
- if (user_home)
- setenv("HOME", user_home, 1);
- if (xdg_home)
- setenv("XDG_CONFIG_HOME", xdg_home, 1);
-
if (nongit) {
const char *name = ctx->repo->name;
rc = errno;
if (nongit) {
const char *name = ctx->repo->name;
rc = errno;
{
struct argv_array argv = ARGV_ARRAY_INIT;
const char **nargv;
{
struct argv_array argv = ARGV_ARRAY_INIT;
const char **nargv;
- char *user_home, *xdg_home;
int result;
argv_array_push(&argv, "snapshot");
argv_array_push(&argv, format);
int result;
argv_array_push(&argv, "snapshot");
argv_array_push(&argv, format);
/* argv_array guarantees a trailing NULL entry. */
memcpy(nargv, argv.argv, sizeof(char *) * (argv.argc + 1));
/* argv_array guarantees a trailing NULL entry. */
memcpy(nargv, argv.argv, sizeof(char *) * (argv.argc + 1));
- user_home = getenv("HOME");
- xdg_home = getenv("XDG_CONFIG_HOME");
- unsetenv("HOME");
- unsetenv("XDG_CONFIG_HOME");
result = write_archive(argv.argc, nargv, NULL, 1, NULL, 0);
result = write_archive(argv.argc, nargv, NULL, 1, NULL, 0);
- if (user_home)
- setenv("HOME", user_home, 1);
- if (xdg_home)
- setenv("XDG_CONFIG_HOME", xdg_home, 1);
argv_array_clear(&argv);
free(nargv);
return result;
argv_array_clear(&argv);
free(nargv);
return result;