X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=zgrep.in;h=aec4a670acbd82a801ba9f6396a094f9c36a926b;hb=f2be148c3d956c2dd19bd6fdbe6de977e86cba35;hp=6afa62cf64851eb253b8160db95985b18237ee21;hpb=50ee35c903cdecf6c643d107015125f517620102;p=debian%2Fgzip diff --git a/zgrep.in b/zgrep.in index 6afa62c..aec4a67 100644 --- a/zgrep.in +++ b/zgrep.in @@ -28,10 +28,10 @@ case $1 in esac PATH=$bindir:$PATH -grep='${GREP-grep}' +grep='${GREP-'\''@GREP@'\''}' version='zgrep (gzip) @VERSION@ -Copyright (C) 2010 Free Software Foundation, Inc. +Copyright (C) 2010-2012 Free Software Foundation, Inc. This is free software. You may redistribute copies of it under the terms of the GNU General Public License . There is NO WARRANTY, to the extent permitted by law. @@ -47,14 +47,13 @@ OPTIONs are the same as for 'grep'. Report bugs to ." # sed script to escape all ' for the shell, and then (to handle trailing -# newlines correctly) turn trailing X on last line into '. +# newlines correctly) append ' to the last line. escape=' s/'\''/'\''\\'\'''\''/g - $s/X$/'\''/ + $s/$/'\''/ ' operands= have_pat=0 -pat_on_stdin=0 files_with_matches=0 files_without_matches=0 no_filename=0 @@ -66,8 +65,8 @@ while test $# -ne 0; do optarg= case $option in - (-[0123456789EFGHIKLPRTUVZabchilnoqrsuvwxyz]?*) - arg2=-\'$(expr "X${option}X" : 'X-.[0-9]*\(.*\)' | sed "$escape") + (-[0123456789EFGHIKLPRTUVZabchilnoqrsuvwxyz]*[!0123456789]*) + arg2=-\'$(expr "X$option" : 'X-.[0-9]*\(.*\)' | sed "$escape") eval "set -- $arg2 "'${1+"$@"}' option=$(expr "X$option" : 'X\(-.[0-9]*\)');; (--binary-*=* | --[lm]a*=* | --reg*=*) @@ -75,11 +74,23 @@ while test $# -ne 0; do (-[ABCDXdefm] | binary-* | --file | --[lm]a* | --reg*) case ${1?"$option option requires an argument"} in (*\'*) - optarg=" '"$(printf '%sX\n' "$1" | sed "$escape");; + optarg=" '"$(printf '%s\n' "$1" | sed "$escape");; (*) optarg=" '$1'";; esac shift;; + (-f?*\'*) + optarg=" '"$(expr "X$option" : 'X-f\(.*\)' | sed "$escape") + option=-f;; + (-f?*) + optarg=" '"$(expr "X$option" : 'X-f\(.*\)')\' + option=-f;; + (--file=*\'*) + optarg=" '"$(expr "X$option" : 'X--file=\(.*\)' | sed "$escape") + option=--file;; + (--file=*) + optarg=" '"$(expr "X$option" : 'X--file=\(.*\)')\' + option=--file;; (--) break;; (-?*) @@ -87,7 +98,7 @@ while test $# -ne 0; do (*) case $option in (*\'*) - operands="$operands '"$(printf '%sX\n' "$option" | sed "$escape");; + operands="$operands '"$(printf '%s\n' "$option" | sed "$escape");; (*) operands="$operands '$option'";; esac @@ -99,33 +110,18 @@ while test $# -ne 0; do (-[drRzZ] | --di* | --exc* | --inc* | --rec* | --nu*) printf >&2 '%s: %s: option not supported\n' "$0" "$option" exit 2;; - (-[ef]* | --file | --file=* | --reg*) + (-e* | --reg*) + have_pat=1;; + (-f | --file) # The pattern is coming from a file rather than the command-line. # If the file is actually stdin then we need to do a little - # magic, (since we use stdin to pass the gzip output to grep). - # So find a free fd and change the argument to then use this - # file descriptor for the pattern. + # magic, since we use stdin to pass the gzip output to grep. + # Turn the -f option into an -e option by copying the file's + # contents into OPTARG. case $optarg in (" '-'" | " '/dev/stdin'" | " '/dev/fd/0'") - pat_on_stdin=1 - eval 'test -e .' 2>/dev/null \ - && eval 'exists(){ test -e "$@"; }' \ - || eval 'exists(){ test -r "$@" || test -w "$@"; }' - # Start search from 6 since the script already uses 3 and 5 - fd=6 - pat_fd= - while : ; do - if ! exists /proc/$$/fd/$fd; then - pat_fd=$fd - break; - fi - fd=$(expr $fd + 1) - if test $fd = 255; then - printf >&2 '%s: no free file descriptor\n' "$0" - exit 2 - fi - done - optarg=/dev/fd/$pat_fd; + option=-e + optarg=" '"$(sed "$escape") || exit 2;; esac have_pat=1;; (--h | --he | --hel | --help) @@ -149,7 +145,7 @@ while test $# -ne 0; do case $option in (*\'?*) - option=\'$(expr "X${option}X" : 'X\(.*\)' | sed "$escape");; + option=\'$(printf '%s\n' "$option" | sed "$escape");; (*) option="'$option'";; esac @@ -162,7 +158,7 @@ eval "set -- $operands "'${1+"$@"}' if test $have_pat -eq 0; then case ${1?"missing pattern; try \`$0 --help' for help"} in (*\'*) - grep="$grep -- '"$(printf '%sX\n' "$1" | sed "$escape");; + grep="$grep -- '"$(printf '%s\n' "$1" | sed "$escape");; (*) grep="$grep -- '$1'";; esac @@ -181,9 +177,6 @@ do # Fail if gzip or grep (or sed) fails. gzip_status=$( exec 5>&1 - if test $pat_on_stdin -eq 1; then - eval "exec $pat_fd<&0" - fi (gzip -cdfq -- "$i" 5>&-; echo $? >&5) 3>&- | if test $files_with_matches -eq 1; then eval "$grep" >/dev/null && { printf '%s\n' "$i" || exit 2; } @@ -217,14 +210,11 @@ do (eval "$grep" 4>&-; echo $? >&4) 3>&- | sed "$sed_script" >&3 4>&- ) && exit $r r=$? - test $r -gt 128 && test $r -le 143 && exit $r || exit 2 + test 1 -lt $r && exit $r || exit 2 fi >&3 5>&- ) r=$? - if test $r -gt 128 && test $r -le 143; then - kill -$(($r-128)) $$ - exit $r - fi + test 128 -lt $r && exit $r test "$gzip_status" -eq 0 || test "$gzip_status" -eq 2 || r=2 test $res -lt $r && res=$r done