Documentation / git-rm.txton commit git-svn: extra error check to ensure we open a file correctly (006ede5)
   1git-rm(1)
   2=========
   3
   4NAME
   5----
   6git-rm - Remove files from the working tree and from the index
   7
   8SYNOPSIS
   9--------
  10'git-rm' [-f] [-n] [-v] [--] <file>...
  11
  12DESCRIPTION
  13-----------
  14A convenience wrapper for git-update-index --remove. For those coming
  15from cvs, git-rm provides an operation similar to "cvs rm" or "cvs
  16remove".
  17
  18
  19OPTIONS
  20-------
  21<file>...::
  22        Files to remove from the index and optionally, from the
  23        working tree as well.
  24
  25-f::
  26        Remove files from the working tree as well as from the index.
  27
  28-n::
  29        Don't actually remove the file(s), just show if they exist in
  30        the index.
  31
  32-v::
  33        Be verbose.
  34
  35\--::
  36        This option can be used to separate command-line options from
  37        the list of files, (useful when filenames might be mistaken
  38        for command-line options).
  39
  40
  41DISCUSSION
  42----------
  43
  44The list of <file> given to the command is fed to `git-ls-files`
  45command to list files that are registered in the index and
  46are not ignored/excluded by `$GIT_DIR/info/exclude` file or
  47`.gitignore` file in each directory.  This means two things:
  48
  49. You can put the name of a directory on the command line, and the
  50  command will remove all files in it and its subdirectories (the
  51  directories themselves are never removed from the working tree);
  52
  53. Giving the name of a file that is not in the index does not
  54  remove that file.
  55
  56
  57EXAMPLES
  58--------
  59git-rm Documentation/\\*.txt::
  60
  61        Removes all `\*.txt` files from the index that are under the
  62        `Documentation` directory and any of its subdirectories. The
  63        files are not removed from the working tree.
  64+
  65Note that the asterisk `\*` is quoted from the shell in this
  66example; this lets the command include the files from
  67subdirectories of `Documentation/` directory.
  68
  69git-rm -f git-*.sh::
  70
  71        Remove all git-*.sh scripts that are in the index. The files
  72        are removed from the index, and (because of the -f option),
  73        from the working tree as well. Because this example lets the
  74        shell expand the asterisk (i.e. you are listing the files
  75        explicitly), it does not remove `subdir/git-foo.sh`.
  76
  77See Also
  78--------
  79gitlink:git-add[1]
  80
  81Author
  82------
  83Written by Linus Torvalds <torvalds@osdl.org>
  84
  85Documentation
  86--------------
  87Documentation by Junio C Hamano and the git-list <git@vger.kernel.org>.
  88
  89GIT
  90---
  91Part of the gitlink:git[7] suite
  92