sane_grep: pass "-a" if grep accepts it
Newer versions of GNU grep is reported to be pickier when we feed a non-ASCII input and break some Porcelain scripts. As we know we do not feed random binary file to our own sane_grep wrapper, allow us to always pass "-a" by setting SANE_TEXT_GREP=-a Makefile variable to work it around. Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
833e48259e
commit
71b401032b
6
Makefile
6
Makefile
@ -266,6 +266,9 @@ all::
|
|||||||
#
|
#
|
||||||
# Define NO_TCLTK if you do not want Tcl/Tk GUI.
|
# Define NO_TCLTK if you do not want Tcl/Tk GUI.
|
||||||
#
|
#
|
||||||
|
# Define SANE_TEXT_GREP to "-a" if you use recent versions of GNU grep
|
||||||
|
# and egrep that are pickier when their input contains non-ASCII data.
|
||||||
|
#
|
||||||
# The TCL_PATH variable governs the location of the Tcl interpreter
|
# The TCL_PATH variable governs the location of the Tcl interpreter
|
||||||
# used to optimize git-gui for your system. Only used if NO_TCLTK
|
# used to optimize git-gui for your system. Only used if NO_TCLTK
|
||||||
# is not set. Defaults to the bare 'tclsh'.
|
# is not set. Defaults to the bare 'tclsh'.
|
||||||
@ -1728,7 +1731,7 @@ common-cmds.h: $(wildcard Documentation/git-*.txt)
|
|||||||
|
|
||||||
SCRIPT_DEFINES = $(SHELL_PATH_SQ):$(DIFF_SQ):$(GIT_VERSION):\
|
SCRIPT_DEFINES = $(SHELL_PATH_SQ):$(DIFF_SQ):$(GIT_VERSION):\
|
||||||
$(localedir_SQ):$(NO_CURL):$(USE_GETTEXT_SCHEME):$(SANE_TOOL_PATH_SQ):\
|
$(localedir_SQ):$(NO_CURL):$(USE_GETTEXT_SCHEME):$(SANE_TOOL_PATH_SQ):\
|
||||||
$(gitwebdir_SQ):$(PERL_PATH_SQ)
|
$(gitwebdir_SQ):$(PERL_PATH_SQ):$(SANE_TEXT_GREP)
|
||||||
define cmd_munge_script
|
define cmd_munge_script
|
||||||
$(RM) $@ $@+ && \
|
$(RM) $@ $@+ && \
|
||||||
sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
|
sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
|
||||||
@ -1740,6 +1743,7 @@ sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \
|
|||||||
-e $(BROKEN_PATH_FIX) \
|
-e $(BROKEN_PATH_FIX) \
|
||||||
-e 's|@@GITWEBDIR@@|$(gitwebdir_SQ)|g' \
|
-e 's|@@GITWEBDIR@@|$(gitwebdir_SQ)|g' \
|
||||||
-e 's|@@PERL@@|$(PERL_PATH_SQ)|g' \
|
-e 's|@@PERL@@|$(PERL_PATH_SQ)|g' \
|
||||||
|
-e 's|@@SANE_TEXT_GREP@@|$(SANE_TEXT_GREP)|g' \
|
||||||
$@.sh >$@+
|
$@.sh >$@+
|
||||||
endef
|
endef
|
||||||
|
|
||||||
|
@ -37,6 +37,7 @@ ifeq ($(uname_S),Linux)
|
|||||||
HAVE_CLOCK_GETTIME = YesPlease
|
HAVE_CLOCK_GETTIME = YesPlease
|
||||||
HAVE_CLOCK_MONOTONIC = YesPlease
|
HAVE_CLOCK_MONOTONIC = YesPlease
|
||||||
HAVE_GETDELIM = YesPlease
|
HAVE_GETDELIM = YesPlease
|
||||||
|
SANE_TEXT_GREP=-a
|
||||||
endif
|
endif
|
||||||
ifeq ($(uname_S),GNU/kFreeBSD)
|
ifeq ($(uname_S),GNU/kFreeBSD)
|
||||||
HAVE_ALLOCA_H = YesPlease
|
HAVE_ALLOCA_H = YesPlease
|
||||||
|
@ -471,6 +471,13 @@ if test -n "$ASCIIDOC"; then
|
|||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if grep -a ascii configure.ac >/dev/null; then
|
||||||
|
AC_MSG_RESULT([Using 'grep -a' for sane_grep])
|
||||||
|
SANE_TEXT_GREP=-a
|
||||||
|
else
|
||||||
|
SANE_TEXT_GREP=
|
||||||
|
fi
|
||||||
|
GIT_CONF_SUBST([SANE_TEXT_GREP])
|
||||||
|
|
||||||
## Checks for libraries.
|
## Checks for libraries.
|
||||||
AC_MSG_NOTICE([CHECKS for libraries])
|
AC_MSG_NOTICE([CHECKS for libraries])
|
||||||
|
@ -168,11 +168,11 @@ git_pager() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
sane_grep () {
|
sane_grep () {
|
||||||
GREP_OPTIONS= LC_ALL=C grep "$@"
|
GREP_OPTIONS= LC_ALL=C grep @@SANE_TEXT_GREP@@ "$@"
|
||||||
}
|
}
|
||||||
|
|
||||||
sane_egrep () {
|
sane_egrep () {
|
||||||
GREP_OPTIONS= LC_ALL=C egrep "$@"
|
GREP_OPTIONS= LC_ALL=C egrep @@SANE_TEXT_GREP@@ "$@"
|
||||||
}
|
}
|
||||||
|
|
||||||
is_bare_repository () {
|
is_bare_repository () {
|
||||||
|
Loading…
Reference in New Issue
Block a user