Skip to content

Commit fae73c7

Browse files
authored
Merge pull request #2506 from dscho/issue-2283
Allow running Git directly from `C:\Program Files\Git\mingw64\bin\git.exe`
2 parents 2c4b5e4 + fda9606 commit fae73c7

File tree

4 files changed

+114
-2
lines changed

4 files changed

+114
-2
lines changed

Makefile

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2717,6 +2717,11 @@ ifdef GIT_INTEROP_MAKE_OPTS
27172717
endif
27182718
ifdef GIT_TEST_INDEX_VERSION
27192719
@echo GIT_TEST_INDEX_VERSION=\''$(subst ','\'',$(subst ','\'',$(GIT_TEST_INDEX_VERSION)))'\' >>$@+
2720+
endif
2721+
ifdef RUNTIME_PREFIX
2722+
@echo RUNTIME_PREFIX=\'true\' >>$@+
2723+
else
2724+
@echo RUNTIME_PREFIX=\'false\' >>$@+
27202725
endif
27212726
@if cmp $@+ $@ >/dev/null 2>&1; then $(RM) $@+; else mv $@+ $@; fi
27222727

compat/mingw.c

Lines changed: 69 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3167,6 +3167,47 @@ int xwcstoutf(char *utf, const wchar_t *wcs, size_t utflen)
31673167
return -1;
31683168
}
31693169

3170+
#ifdef ENSURE_MSYSTEM_IS_SET
3171+
static size_t append_system_bin_dirs(char *path, size_t size)
3172+
{
3173+
#if !defined(RUNTIME_PREFIX) || !defined(HAVE_WPGMPTR)
3174+
return 0;
3175+
#else
3176+
char prefix[32768];
3177+
const char *slash;
3178+
size_t len = xwcstoutf(prefix, _wpgmptr, sizeof(prefix)), off = 0;
3179+
3180+
if (len == 0 || len >= sizeof(prefix) ||
3181+
!(slash = find_last_dir_sep(prefix)))
3182+
return 0;
3183+
/* strip trailing `git.exe` */
3184+
len = slash - prefix;
3185+
3186+
/* strip trailing `cmd` or `mingw64\bin` or `mingw32\bin` or `bin` or `libexec\git-core` */
3187+
if (strip_suffix_mem(prefix, &len, "\\mingw64\\libexec\\git-core") ||
3188+
strip_suffix_mem(prefix, &len, "\\mingw64\\bin"))
3189+
off += xsnprintf(path + off, size - off,
3190+
"%.*s\\mingw64\\bin;", (int)len, prefix);
3191+
else if (strip_suffix_mem(prefix, &len, "\\mingw32\\libexec\\git-core") ||
3192+
strip_suffix_mem(prefix, &len, "\\mingw32\\bin"))
3193+
off += xsnprintf(path + off, size - off,
3194+
"%.*s\\mingw32\\bin;", (int)len, prefix);
3195+
else if (strip_suffix_mem(prefix, &len, "\\cmd") ||
3196+
strip_suffix_mem(prefix, &len, "\\bin") ||
3197+
strip_suffix_mem(prefix, &len, "\\libexec\\git-core"))
3198+
off += xsnprintf(path + off, size - off,
3199+
"%.*s\\mingw%d\\bin;", (int)len, prefix,
3200+
(int)(sizeof(void *) * 8));
3201+
else
3202+
return 0;
3203+
3204+
off += xsnprintf(path + off, size - off,
3205+
"%.*s\\usr\\bin;", (int)len, prefix);
3206+
return off;
3207+
#endif
3208+
}
3209+
#endif
3210+
31703211
static void setup_windows_environment(void)
31713212
{
31723213
char *tmp = getenv("TMPDIR");
@@ -3219,6 +3260,34 @@ static void setup_windows_environment(void)
32193260
setenv("HOME", tmp, 1);
32203261
}
32213262

3263+
if (!getenv("PLINK_PROTOCOL"))
3264+
setenv("PLINK_PROTOCOL", "ssh", 0);
3265+
3266+
#ifdef ENSURE_MSYSTEM_IS_SET
3267+
if (!(tmp = getenv("MSYSTEM")) || !tmp[0]) {
3268+
const char *home = getenv("HOME"), *path = getenv("PATH");
3269+
char buf[32768];
3270+
size_t off = 0;
3271+
3272+
xsnprintf(buf, sizeof(buf),
3273+
"MINGW%d", (int)(sizeof(void *) * 8));
3274+
setenv("MSYSTEM", buf, 1);
3275+
3276+
if (home)
3277+
off += xsnprintf(buf + off, sizeof(buf) - off,
3278+
"%s\\bin;", home);
3279+
off += append_system_bin_dirs(buf + off, sizeof(buf) - off);
3280+
if (path)
3281+
off += xsnprintf(buf + off, sizeof(buf) - off,
3282+
"%s", path);
3283+
else if (off > 0)
3284+
buf[off - 1] = '\0';
3285+
else
3286+
buf[0] = '\0';
3287+
setenv("PATH", buf, 1);
3288+
}
3289+
#endif
3290+
32223291
/*
32233292
* Change 'core.symlinks' default to false, unless native symlinks are
32243293
* enabled in MSys2 (via 'MSYS=winsymlinks:nativestrict'). Thus we can

config.mak.uname

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -439,7 +439,7 @@ endif
439439
compat/win32/pthread.o compat/win32/syslog.o \
440440
compat/win32/trace2_win32_process_info.o \
441441
compat/win32/dirent.o compat/win32/fscache.o
442-
COMPAT_CFLAGS = -D__USE_MINGW_ACCESS -DDETECT_MSYS_TTY -DNOGDI -DHAVE_STRING_H -Icompat -Icompat/regex -Icompat/win32 -DSTRIP_EXTENSION=\".exe\"
442+
COMPAT_CFLAGS = -D__USE_MINGW_ACCESS -DDETECT_MSYS_TTY -DENSURE_MSYSTEM_IS_SET -DNOGDI -DHAVE_STRING_H -Icompat -Icompat/regex -Icompat/win32 -DSTRIP_EXTENSION=\".exe\"
443443
BASIC_LDFLAGS = -IGNORE:4217 -IGNORE:4049 -NOLOGO -ENTRY:wmainCRTStartup -SUBSYSTEM:CONSOLE
444444
# invalidcontinue.obj allows Git's source code to close the same file
445445
# handle twice, or to access the osfhandle of an already-closed stdout
@@ -662,7 +662,7 @@ else
662662
endif
663663
CC = gcc
664664
COMPAT_CFLAGS += -D__USE_MINGW_ANSI_STDIO=0 -DDETECT_MSYS_TTY \
665-
-fstack-protector-strong
665+
-DENSURE_MSYSTEM_IS_SET -fstack-protector-strong
666666
EXTLIBS += -lntdll
667667
INSTALL = /bin/install
668668
NO_R_TO_GCC_LINKER = YesPlease

t/t0060-path-utils.sh

Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -495,4 +495,42 @@ test_expect_success MINGW 'is_valid_path() on Windows' '
495495
"PRN./abc"
496496
'
497497

498+
test_expect_success MINGW 'MSYSTEM/PATH is adjusted if necessary' '
499+
mkdir -p "$HOME"/bin pretend/mingw64/bin \
500+
pretend/mingw64/libexec/git-core pretend/usr/bin &&
501+
cp "$GIT_EXEC_PATH"/git.exe pretend/mingw64/bin/ &&
502+
cp "$GIT_EXEC_PATH"/git.exe pretend/mingw64/libexec/git-core/ &&
503+
echo "env | grep MSYSTEM=" | write_script "$HOME"/bin/git-test-home &&
504+
echo "echo mingw64" | write_script pretend/mingw64/bin/git-test-bin &&
505+
echo "echo usr" | write_script pretend/usr/bin/git-test-bin2 &&
506+
507+
(
508+
MSYSTEM= &&
509+
GIT_EXEC_PATH= &&
510+
pretend/mingw64/libexec/git-core/git.exe test-home >actual &&
511+
pretend/mingw64/libexec/git-core/git.exe test-bin >>actual &&
512+
pretend/mingw64/bin/git.exe test-bin2 >>actual
513+
) &&
514+
test_write_lines MSYSTEM=$MSYSTEM mingw64 usr >expect &&
515+
test_cmp expect actual
516+
'
517+
518+
test_lazy_prereq RUNTIME_PREFIX '
519+
test true = "$RUNTIME_PREFIX"
520+
'
521+
522+
test_lazy_prereq CAN_EXEC_IN_PWD '
523+
cp "$GIT_EXEC_PATH"/git$X ./ &&
524+
./git rev-parse
525+
'
526+
527+
test_expect_success RUNTIME_PREFIX,CAN_EXEC_IN_PWD 'RUNTIME_PREFIX works' '
528+
mkdir -p pretend/git pretend/libexec/git-core &&
529+
echo "echo HERE" | write_script pretend/libexec/git-core/git-here &&
530+
cp "$GIT_EXEC_PATH"/git$X pretend/git/ &&
531+
GIT_EXEC_PATH= ./pretend/git/git here >actual &&
532+
echo HERE >expect &&
533+
test_cmp expect actual
534+
'
535+
498536
test_done

0 commit comments

Comments
 (0)