Provided by: nim_1.6.4-1_amd64 bug

NAME

       nimgrep - Nimgrep

DESCRIPTION

       nimgrep - Nim Grep Searching and Replacement Utility Version 1.6.0

              (c) 2012-2020 Andreas Rumpf

       Usage:

   * To search::
              nimgrep [options] PATTERN [(FILE/DIRECTORY)*/-]

   * To replace::
              nimgrep [options] PATTERN --replace REPLACEMENT (FILE/DIRECTORY)*/-

   * To list file names::
              nimgrep [options] --filenames [PATTERN] [(FILE/DIRECTORY)*]

       Positional  arguments,  from left to right: 1) PATTERN is either Regex (default) or Peg if
       `--peg` is specified.

              PATTERN and REPLACEMENT should be skipped when `--stdin` is specified.

       2) REPLACEMENT supports `$1`, `$#` notations for captured groups in PATTERN.

              .. DANGER:: `--replace` mode **DOES NOT** ask confirmation

              unless `--confirm` is specified!

       3) Final arguments are a list of paths (FILE/DIRECTORY) or a standalone

              minus `-` or not specified (empty):

              * empty, current directory `.` is assumed (not with `--replace`)

              .. Note:: so when no FILE/DIRECTORY/`-` is specified nimgrep

              does **not** read the pipe, but searches files in the current dir instead!

              * `-`, read buffer once from stdin: pipe or terminal input;

              in `--replace` mode the result is directed to  stdout;  it's  not  compatible  with
              `--stdin`, `--filenames`, or `--confirm`

              For  any  given  DIRECTORY  nimgrep  searches  only  its  immediate  files  without
              traversing sub-directories unless `--recursive` is specified.

       In replacement mode we require all 3 positional arguments to avoid damaging.

OPTIONS

   * Mode of operation:
       --find, -f
              find the PATTERN (default)

       --replace, -!
              replace the PATTERN to REPLACEMENT, rewriting the files

       --confirm
              confirm each occurrence/replacement; there is a chance to abort  any  time  without
              touching the file

       --filenames
              just  list  filenames.  Provide  a  PATTERN to find it in the filenames (not in the
              contents of a file) or run with empty pattern to just list all files::

       nimgrep --filenames
              # In current dir

       nimgrep --filenames "" DIRECTORY
              # Note empty pattern "", lists all files in DIRECTORY

   * Interprete patterns:
       --peg  PATTERN and PAT are Peg

       --re   PATTERN and PAT are regular expressions (default)

       --rex, -x
              use the "extended" syntax for the regular expression  so  that  whitespace  is  not
              significant

       --word, -w
              matches should have word boundaries (buggy for pegs!)

       --ignoreCase, -i
              be case insensitive in PATTERN and PAT

       --ignoreStyle, -y
              be style insensitive in PATTERN and PAT

              .. Note:: PATERN and patterns PAT (see below in other options) are all either

              Regex  or  Peg  simultaneously  and  options `--rex`, `--word`, `--ignoreCase`, and
              `--ignoreStyle` are applied to all of them.

   * File system walk:
       --recursive, -r
              process directories recursively

       --follow
              follow all symlinks when processing recursively

       --ext:EX1|EX2|...
              only search the files with the given extension(s), empty one ("--ext") means  files
              with missing extension

       --noExt:EX1|...
              exclude  files  having  given  extension(s),  use  empty  one to skip files with no
              extension (like some binary files are)

       --includeFile:PAT
              search only files whose names contain pattern PAT

       --excludeFile:PAT
              skip files whose names contain pattern PAT

       --includeDir:PAT
              search only files with their whole directory path containing PAT

       --excludeDir:PAT
              skip directories whose name (not path) contain pattern PAT

       --if,--ef,--id,--ed
              abbreviations of the 4 options above

       --sortTime, -s[:asc|desc]
              order files by the last modification time (default: off): ascending  (recent  files
              go last) or descending

   * Filter file content:
       --match:PAT
              select files containing a (not displayed) match of PAT

       --noMatch:PAT
              select files not containing any match of PAT

       --bin:on|off|only
              process  binary files? (detected by \0 in first 1K bytes) (default: on - binary and
              text files treated the same way)

       --text, -t
              process only text files, the same as `--bin:off`

   * Represent results:
       --nocolor
              output will be given without any colors

       --color[:on]
              force color even if output is redirected (default: auto)

       --colorTheme:THEME
              select color THEME from `simple` (default), `bnw`  (black  and  white),  `ack`,  or
              `gnu` (GNU grep)

       --count
              only print counts of matches for files that matched

       --context:N, -c:N
              print N lines of leading context before every match and N lines of trailing context
              after it (default N: 0)

       --afterContext:N, -a:N
              print N lines of trailing context after every match

       --beforeContext:N, -b:N
              print N lines of leading context before every match

       --group, -g
              group matches by file

       --newLine, -l
              display every matching line starting from a new line

       --cols[:N]
              limit max displayed columns/width of output  lines  from  files  by  N  characters,
              cropping overflows (default: off)

       --cols:auto, -%
              calculate columns from terminal width for every line

       --onlyAscii, -@
              display  only  printable ASCII Latin characters 0x20-0x7E substitutions: 0 -> ^@, 1
              -> ^A, ... 0x1F -> ^_,

              0x7F -> '7F, ..., 0xFF -> 'FF

   * Miscellaneous:
       --threads:N, -j:N
              speed up search by N additional workers (default: 0, off)

       --stdin
              read PATTERN from stdin (to avoid the shell's  confusing  quoting  rules)  and,  if
              `--replace` given, REPLACEMENT

       --verbose
              be verbose: list every processed file

       --help, -h
              shows this help

       --version, -v
              shows the version

REPORTING BUGS

       https://github.com/nim-lang/Nim/issues

SEE ALSO

       The nim-doc package.