mirror of
https://github.com/facebook/zstd.git
synced 2025-11-27 00:05:09 -05:00
Merge pull request #1430 from lzutao/fix-zstdgrep
Fix #1428 - zstdgrep now returns 1 on unmatch
This commit is contained in:
commit
f6591e4a04
@ -31,94 +31,101 @@ grep_args=""
|
|||||||
hyphen=0
|
hyphen=0
|
||||||
silent=0
|
silent=0
|
||||||
|
|
||||||
prg=$(basename $0)
|
prg=$(basename "$0")
|
||||||
|
|
||||||
# handle being called 'zegrep' or 'zfgrep'
|
# handle being called 'zegrep' or 'zfgrep'
|
||||||
case ${prg} in
|
case "${prg}" in
|
||||||
*zegrep)
|
*zegrep) grep_args="-E";;
|
||||||
grep_args="-E";;
|
*zfgrep) grep_args="-F";;
|
||||||
*zfgrep)
|
|
||||||
grep_args="-F";;
|
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# skip all options and pass them on to grep taking care of options
|
# skip all options and pass them on to grep taking care of options
|
||||||
# with arguments, and if -e was supplied
|
# with arguments, and if -e was supplied
|
||||||
|
|
||||||
while [ $# -gt 0 -a ${endofopts} -eq 0 ]
|
while [ "$#" -gt 0 ] && [ "${endofopts}" -eq 0 ]; do
|
||||||
do
|
case "$1" in
|
||||||
case $1 in
|
|
||||||
# from GNU grep-2.5.1 -- keep in sync!
|
# from GNU grep-2.5.1 -- keep in sync!
|
||||||
-[ABCDXdefm])
|
-[ABCDXdefm])
|
||||||
if [ $# -lt 2 ]
|
if [ "$#" -lt 2 ]; then
|
||||||
then
|
printf '%s: missing argument for %s flag\n' "${prg}" "$1" >&2
|
||||||
echo "${prg}: missing argument for $1 flag" >&2
|
exit 1
|
||||||
exit 1
|
fi
|
||||||
fi
|
case "$1" in
|
||||||
case $1 in
|
-e)
|
||||||
-e)
|
pattern="$2"
|
||||||
pattern="$2"
|
pattern_found=1
|
||||||
pattern_found=1
|
shift 2
|
||||||
shift 2
|
break
|
||||||
break
|
;;
|
||||||
;;
|
*)
|
||||||
*)
|
;;
|
||||||
;;
|
esac
|
||||||
esac
|
grep_args="${grep_args} $1 $2"
|
||||||
grep_args="${grep_args} $1 $2"
|
shift 2
|
||||||
shift 2
|
;;
|
||||||
;;
|
--)
|
||||||
--)
|
shift
|
||||||
shift
|
endofopts=1
|
||||||
endofopts=1
|
;;
|
||||||
;;
|
-)
|
||||||
-)
|
hyphen=1
|
||||||
hyphen=1
|
shift
|
||||||
shift
|
;;
|
||||||
;;
|
-h)
|
||||||
-h)
|
silent=1
|
||||||
silent=1
|
shift
|
||||||
shift
|
;;
|
||||||
;;
|
-*)
|
||||||
-*)
|
grep_args="${grep_args} $1"
|
||||||
grep_args="${grep_args} $1"
|
shift
|
||||||
shift
|
;;
|
||||||
;;
|
*)
|
||||||
*)
|
# pattern to grep for
|
||||||
# pattern to grep for
|
endofopts=1
|
||||||
endofopts=1
|
;;
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
# if no -e option was found, take next argument as grep-pattern
|
# if no -e option was found, take next argument as grep-pattern
|
||||||
if [ ${pattern_found} -lt 1 ]
|
if [ "${pattern_found}" -lt 1 ]; then
|
||||||
then
|
if [ "$#" -ge 1 ]; then
|
||||||
if [ $# -ge 1 ]; then
|
pattern="$1"
|
||||||
pattern="$1"
|
shift
|
||||||
shift
|
elif [ "${hyphen}" -gt 0 ]; then
|
||||||
elif [ ${hyphen} -gt 0 ]; then
|
pattern="-"
|
||||||
pattern="-"
|
|
||||||
else
|
else
|
||||||
echo "${prg}: missing pattern" >&2
|
printf '%s: missing pattern\n' "${prg}" >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
EXIT_CODE=0
|
||||||
# call grep ...
|
# call grep ...
|
||||||
if [ $# -lt 1 ]
|
if [ "$#" -lt 1 ]; then
|
||||||
then
|
|
||||||
# ... on stdin
|
# ... on stdin
|
||||||
${zcat} -fq - | ${grep} ${grep_args} -- "${pattern}" -
|
set -f # Disable file name generation (globbing).
|
||||||
|
# shellcheck disable=SC2086
|
||||||
|
"${zcat}" -fq - | "${grep}" ${grep_args} -- "${pattern}" -
|
||||||
|
EXIT_CODE=$?
|
||||||
|
set +f
|
||||||
else
|
else
|
||||||
# ... on all files given on the command line
|
# ... on all files given on the command line
|
||||||
if [ ${silent} -lt 1 -a $# -gt 1 ]; then
|
if [ "${silent}" -lt 1 ] && [ "$#" -gt 1 ]; then
|
||||||
grep_args="-H ${grep_args}"
|
grep_args="-H ${grep_args}"
|
||||||
fi
|
fi
|
||||||
while [ $# -gt 0 ]
|
CUR_EXIT_CODE=0
|
||||||
do
|
EXIT_CODE=1
|
||||||
${zcat} -fq -- "$1" | ${grep} --label="${1}" ${grep_args} -- "${pattern}" -
|
set -f
|
||||||
shift
|
while [ "$#" -gt 0 ]; do
|
||||||
|
# shellcheck disable=SC2086
|
||||||
|
"${zcat}" -fq -- "$1" | "${grep}" --label="${1}" ${grep_args} -- "${pattern}" -
|
||||||
|
CUR_EXIT_CODE=$?
|
||||||
|
if [ "${CUR_EXIT_CODE}" -eq 0 ] && [ "${EXIT_CODE}" -ne 1 ]; then
|
||||||
|
EXIT_CODE=0
|
||||||
|
fi
|
||||||
|
shift
|
||||||
done
|
done
|
||||||
|
set +f
|
||||||
fi
|
fi
|
||||||
|
|
||||||
exit 0
|
exit "${EXIT_CODE}"
|
||||||
|
|||||||
@ -320,7 +320,7 @@ test32: test-zstd32 test-fullbench32 test-fuzzer32 test-zstream32
|
|||||||
test-all: test test32 valgrindTest test-decodecorpus-cli
|
test-all: test test32 valgrindTest test-decodecorpus-cli
|
||||||
|
|
||||||
|
|
||||||
.PHONY: test-zstd test-zstd32 test-zstd-nolegacy
|
.PHONY: test-zstd test-zstd32 test-zstd-nolegacy test-zstdgrep
|
||||||
test-zstd: ZSTD = $(PRGDIR)/zstd
|
test-zstd: ZSTD = $(PRGDIR)/zstd
|
||||||
test-zstd: zstd
|
test-zstd: zstd
|
||||||
|
|
||||||
@ -352,6 +352,10 @@ test-gzstd: gzstd
|
|||||||
$(PRGDIR)/zstd -dcf - <hello_zst_gz_txt.gz
|
$(PRGDIR)/zstd -dcf - <hello_zst_gz_txt.gz
|
||||||
$(RM) *.gz *.zst README2.md gz_zstd zstd_gz hello.txt
|
$(RM) *.gz *.zst README2.md gz_zstd zstd_gz hello.txt
|
||||||
|
|
||||||
|
test-zstdgrep: gzstd
|
||||||
|
@echo a | $(PRGDIR)/zstd | $(PRGDIR)/zstdgrep a
|
||||||
|
@echo a | $(PRGDIR)/zstd | $(PRGDIR)/zstdgrep b && return 1 || return 0
|
||||||
|
|
||||||
test-fullbench: fullbench datagen
|
test-fullbench: fullbench datagen
|
||||||
$(QEMU_SYS) ./fullbench -i1
|
$(QEMU_SYS) ./fullbench -i1
|
||||||
$(QEMU_SYS) ./fullbench -i1 -P0
|
$(QEMU_SYS) ./fullbench -i1 -P0
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user