%%s 0/0/0 %%d D 1.1 25-Mar-82 12:06:14 v1.1 1 0 %%c Version 1.1 is the Spring 1982 Distribution of the LBL/Hughes release %%c of the Software Tools Virtual Operating System software and documentation. %%T %%I 1 #-h- find.r 2437 asc 25-mar-82 07:56:18 v1.1 (sw-tools v1.1) #-h- defns 163 asc 25-mar-82 07:56:06 v1.1 (sw-tools v1.1) ## definitions for the FIND tool # put on a file named 'defns' # Used by the find tool define(NEXPR,10) # maximum number of expressions allowed on cmd line #-h- main 1668 asc 25-mar-82 07:56:07 v1.1 (sw-tools v1.1) DRIVER(find) character exp(MAXARG,NEXPR), lin(MAXLINE), arg(MAXARG), tmplin(MAXLINE) integer pat(MAXPAT, NEXPR) integer i, getarg, except, andpat, count, elevel, itoc, getpat, mcount, getlin, matchd, status, gmatch, index, casind string usestr "usage: find [-acix] expression [expression] ..." data except/NO/ data andpat/NO/ data count /NO/ data casind /NO/ data elevel/0/ call query(usestr) for (i=1; getarg(i, arg, MAXARG) != EOF; i=i+1) if (arg(1) == '-') { call strcpy( arg, lin) call fold(lin) if (index(lin, 'a') > 0) andpat = YES if (index(lin, 'c') > 0) count = YES if (index(lin, 'i') > 0 ) casind = YES if (index(lin, 'x') > 0) except = YES } else if (elevel < NEXPR) { elevel = elevel + 1 if ( casind == YES ) call fold(arg) call strcpy( arg, exp(1, elevel)) } else { call putlin("Maximum number of expressions permitted is ", ERROUT) status = itoc(NEXPR, arg, MAXARG) call error(arg) } if (elevel == 0) call error(usestr) for (i=1; i <= elevel; i=i+1) if (getpat(exp(1,i), pat(1,i)) == ERR) { call putlin("illegal pattern: ", ERROUT) call error(exp(1,i)) } mcount = 0 while (getlin(lin, STDIN) != EOF) { if( casind == NO ) matchd = gmatch(lin, pat, elevel, andpat) else { call strcpy( lin, tmplin) call fold(tmplin) matchd = gmatch( tmplin, pat, elevel, andpat) } if ((matchd == YES & except == NO) | (matchd == NO & except == YES)) if (count == YES) mcount = mcount + 1 else call putlin(lin, STDOUT) } if (count == YES) { call putdec(mcount, 1) call putc('@n') } DRETURN end #-h- gmatch 387 asc 25-mar-82 07:56:08 v1.1 (sw-tools v1.1) integer function gmatch(lin, pat, elevel, andpat) integer elevel, andpat, match, i, status character lin(ARB) integer pat(MAXPAT, NEXPR) gmatch = andpat for (i=1; i <= elevel; i=i+1) { status = match(lin, pat(1,i)) if (andpat == NO & status == YES) { gmatch = YES break } else if (andpat == YES & status == NO) { gmatch = NO break } } return end #-h- find.fmt 3055 asc 25-mar-82 07:56:20 v1.1 (sw-tools v1.1) .so ~bin/manhdr .hd Find (1) 3-Mar-78 search a file for text patterns .sy find [-acix] expression [expression] ... .ds find searches the standard input file for lines matching the text patterns "expression" (up to 9 patterns may be specified) according to the matching criterion specified by the switches. (A text pattern is a subset of a "regular expression"--see the writeup on "ed" for a complete description of regular expressions.) Unless the -c option is specified, each matching line is copied to the standard output. By default, any line which matches any one of the expressions is considered a matching line. If the -a flag is specified, only lines which match all expressions in any order are considered to match. If the -x flag is specified, all lines which don't satisfy the above criteria are considered matching lines. If the -c option is specified, matching lines are counted instead of being copied to the standard output, and the final count is written to the standard output. Finally, if the -i option is specified, the pattern matching becomes case insensitive. A text pattern consists of the following elements: .nf c literal character ? any character except newline % beginning of line $ end of line (null string before newline) [...] character class (any one of these characters) [!...] negated character class (all but these characters) * closure (zero or more occurrences of previous pattern) + anchored closure (one or more occurrences of previous pattern) @c escaped character (e.g., @%, @[, @*) .fi Any special meaning of characters in a text pattern is lost when escaped, inside [...], or for: .nf % not at beginning $ not at end * at beginning + at beginning .fi A character class consists of zero or more of the following elements, surrounded by [ and ]: .nf c literal character, including [ a-b range of characters (digits, lower or upper case) ! negated character class if at beginning @c escaped character (@! @- @@ @]) .fi Special meaning of characters in a character class is lost when escaped or for .nf ! not at beginning - at beginning or end .fi An escape sequence consists of the character @ followed by a single character: .nf @f formfeed @l linefeed @n newline @r carriage return @t tab @c c (including @@) .fi For a complete description, see "Software Tools" pages 135-154. Care should be taken when using the characters % $ [ ] ! * + @ and any shell characters in the text pattern. It is often necessary to enclose the entire substitution pattern in quotes. .fl none .sa tr, ed, ch and the UNIX grep command. .br xfind - extended find utility .di An error message is printed if one of the patterns given is illegal. .au Originally from Kernighan & Plauger's "Software Tools", with major modifications by Joe Sventek. .bu An expression may not start with a minus sign(-). %%E 1