diff options
| author | Junio C Hamano <gitster@pobox.com> | 2016-03-08 15:47:57 -0800 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2016-03-10 15:35:43 -0800 | 
| commit | 71b401032b9e5b0a71e41d95ae0998858787700c (patch) | |
| tree | f69cf92990eb06865b3bac4d9690a4d80c1e16f0 | |
| parent | 833e48259e23aea76f3765d28d1b2200332301f7 (diff) | |
| download | git-71b401032b9e5b0a71e41d95ae0998858787700c.tar.gz | |
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>
| -rw-r--r-- | Makefile | 6 | ||||
| -rw-r--r-- | config.mak.uname | 1 | ||||
| -rw-r--r-- | configure.ac | 7 | ||||
| -rw-r--r-- | git-sh-setup.sh | 4 | 
4 files changed, 15 insertions, 3 deletions
| @@ -266,6 +266,9 @@ all::  #  # 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  # used to optimize git-gui for your system.  Only used if NO_TCLTK  # 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):\  	$(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  $(RM) $@ $@+ && \  sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \ @@ -1740,6 +1743,7 @@ sed -e '1s|#!.*/sh|#!$(SHELL_PATH_SQ)|' \      -e $(BROKEN_PATH_FIX) \      -e 's|@@GITWEBDIR@@|$(gitwebdir_SQ)|g' \      -e 's|@@PERL@@|$(PERL_PATH_SQ)|g' \ +    -e 's|@@SANE_TEXT_GREP@@|$(SANE_TEXT_GREP)|g' \      $@.sh >$@+  endef diff --git a/config.mak.uname b/config.mak.uname index 943c43965e..a7064749fc 100644 --- a/config.mak.uname +++ b/config.mak.uname @@ -37,6 +37,7 @@ ifeq ($(uname_S),Linux)  	HAVE_CLOCK_GETTIME = YesPlease  	HAVE_CLOCK_MONOTONIC = YesPlease  	HAVE_GETDELIM = YesPlease +	SANE_TEXT_GREP=-a  endif  ifeq ($(uname_S),GNU/kFreeBSD)  	HAVE_ALLOCA_H = YesPlease diff --git a/configure.ac b/configure.ac index 1f55009bba..6fd7b8edce 100644 --- a/configure.ac +++ b/configure.ac @@ -471,6 +471,13 @@ if test -n "$ASCIIDOC"; then  	esac  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.  AC_MSG_NOTICE([CHECKS for libraries]) diff --git a/git-sh-setup.sh b/git-sh-setup.sh index 4691fbcb64..c48139a494 100644 --- a/git-sh-setup.sh +++ b/git-sh-setup.sh @@ -168,11 +168,11 @@ git_pager() {  }  sane_grep () { -	GREP_OPTIONS= LC_ALL=C grep "$@" +	GREP_OPTIONS= LC_ALL=C grep @@SANE_TEXT_GREP@@ "$@"  }  sane_egrep () { -	GREP_OPTIONS= LC_ALL=C egrep "$@" +	GREP_OPTIONS= LC_ALL=C egrep @@SANE_TEXT_GREP@@ "$@"  }  is_bare_repository () { | 
