зеркало из https://github.com/microsoft/git.git
t800[12]: work around MSys limitation
MSys works very hard to convert Unix-style paths into DOS-style ones. *Very* hard. So hard, indeed, that git blame -L/hello/,/green/ is translated into something like git blame -LC:/msysgit/hello/,C:/msysgit/green/ As seen in msys_p2w in src\msys\msys\rt\src\winsup\cygwin\path.cc, line 3204ff: case '-': // // here we check for POSIX paths as attributes to a POSIX switch. // ... seemingly absolute POSIX paths in single-letter options get expanded by msys.dll unless they contain '=' or ';'. So a quick and very dirty fix is to use '-L/;*evil/'. (Using an equal sign works only when it is before a comma, so in the above example, /=*green/ would still be converted to a DOS-style path.) The -L mangling can be done by the script, just before the parameter is passed to the executable. This version does not modify the body of the tests and is active on MinGW only. Commit-message-by: Johannes Schindelin <johannes.schindelin@gmx.de> Author: Stepan Kasal <kasal@ucw.cz> Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> Signed-off-by: Stepan Kasal <kasal@ucw.cz> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Родитель
44cf1c0ef1
Коммит
e8d08871c9
|
@ -1,6 +1,17 @@
|
|||
# This file isn't used as a test script directly, instead it is
|
||||
# sourced from t8001-annotate.sh and t8002-blame.sh.
|
||||
|
||||
if test_have_prereq MINGW
|
||||
then
|
||||
sanitize_L () {
|
||||
echo "$1" | sed 'sX\(^-L\|,\)\^\?/X&\\;*Xg'
|
||||
}
|
||||
else
|
||||
sanitize_L () {
|
||||
echo "$1"
|
||||
}
|
||||
fi
|
||||
|
||||
check_count () {
|
||||
head= &&
|
||||
file='file' &&
|
||||
|
@ -10,6 +21,7 @@ check_count () {
|
|||
case "$1" in
|
||||
-h) head="$2"; shift; shift ;;
|
||||
-f) file="$2"; shift; shift ;;
|
||||
-L*) options="$options $(sanitize_L "$1")"; shift ;;
|
||||
-*) options="$options $1"; shift ;;
|
||||
*) break ;;
|
||||
esac
|
||||
|
|
Загрузка…
Ссылка в новой задаче