From 033c2812c29b0e81e6c055b80e0334ba5ed1f871 Mon Sep 17 00:00:00 2001 From: Ori Bernstein Date: Tue, 4 Jun 2019 22:36:32 -0700 Subject: [PATCH] Make 'g' grep recursively by default. --- rc/bin/g | 32 +++++++++++++++++++------------- sys/man/1/grep | 7 ++++++- 2 files changed, 25 insertions(+), 14 deletions(-) diff --git a/rc/bin/g b/rc/bin/g index 69656dfcc..10468b3d2 100755 --- a/rc/bin/g +++ b/rc/bin/g @@ -1,23 +1,29 @@ #!/bin/rc rfork e -flags=() -while(! ~ $#* 1 && ~ $1 -* && ! ~ $1 --){ - flags=($flags $1); - shift +nl=' +' +flags=() +recurse=() +while(! ~ $#* 1 && ~ $1 -* && ! ~ $1 --){ + if(~ $1 '-n') + recurse=-n1 + if not + flags=($flags $1); + shift } if(~ $1 --) - shift + shift switch($#*){ case 0 - echo 'usage: g [flags] pattern [files]' >[1=2] - exit usage + echo 'usage: g [flags] pattern [files]' >[1=2] + exit usage case 1 - pattern=$1 - files=(`{ls *.[bcChlmsy] *.asm *.awk *.cc *.cgi *.cpp *.cs *.go *.goc *.java *.lx *.ms *.pl *.py *.rc *.tex *.xy >[2]/dev/null}) + pattern=$1 + files=`$nl{walk -f $recurse | grep '\.([bcChlmsy]|asm|awk|cc|cgi|cpp|cs|go|goc|java|lx|ms|pl|py|rc|tex|xy)$' >[2]/dev/null} case * - pattern=$1 - shift - files=($*) + pattern=$1 + shift + files=($*) } -grep -n $flags -- $pattern $files /dev/null +grep -n $flags -- $pattern $files /dev/null \ No newline at end of file diff --git a/sys/man/1/grep b/sys/man/1/grep index 433c2370e..2a5a98cfa 100644 --- a/sys/man/1/grep +++ b/sys/man/1/grep @@ -113,11 +113,16 @@ with .B -n (plus aditional flags, if provided) and forces tagging of output lines by file name. If no files -are listed, it searches all files matching +are listed, it recursively searches the current directory for +all files matching .B *.b *.c *.C *.h *.l *.m *.s *.y .B *.asm *.cc *.cs *.lx *.cgi *.pl .B *.py *.tex *.ms *.java *.xy *.go .B *.goc *.cpp +.PP +The recursive search can be suppressed by passing g the +.B -n +flag. .SH SOURCE .B /sys/src/cmd/grep .br