|  | git-rm(1) | 
|  | ========= | 
|  |  | 
|  | NAME | 
|  | ---- | 
|  | git-rm - Remove files from the working tree and from the index | 
|  |  | 
|  | SYNOPSIS | 
|  | -------- | 
|  | 'git rm' [-f | --force] [-n] [-r] [--cached] [--ignore-unmatch] [--quiet] [--] <file>... | 
|  |  | 
|  | DESCRIPTION | 
|  | ----------- | 
|  | Remove files from the index, or from the working tree and the index. | 
|  | 'git-rm' will not remove a file from just your working directory. | 
|  | (There is no option to remove a file only from the work tree | 
|  | and yet keep it in the index; use `/bin/rm` if you want to do that.) | 
|  | The files being removed have to be identical to the tip of the branch, | 
|  | and no updates to their contents can be staged in the index, | 
|  | though that default behavior can be overridden with the `-f` option. | 
|  | When '--cached' is given, the staged content has to | 
|  | match either the tip of the branch or the file on disk, | 
|  | allowing the file to be removed from just the index. | 
|  |  | 
|  |  | 
|  | OPTIONS | 
|  | ------- | 
|  | <file>...:: | 
|  | Files to remove. Fileglobs (e.g. `*.c`) can be given to | 
|  | remove all matching files. If you want git to expand | 
|  | file glob characters, you may need to shell-escape them. | 
|  | A leading directory name | 
|  | (e.g. `dir` to remove `dir/file1` and `dir/file2`) can be | 
|  | given to remove all files in the directory, and recursively | 
|  | all sub-directories, | 
|  | but this requires the `-r` option to be explicitly given. | 
|  |  | 
|  | -f:: | 
|  | --force:: | 
|  | Override the up-to-date check. | 
|  |  | 
|  | -n:: | 
|  | --dry-run:: | 
|  | Don't actually remove any file(s). Instead, just show | 
|  | if they exist in the index and would otherwise be removed | 
|  | by the command. | 
|  |  | 
|  | -r:: | 
|  | Allow recursive removal when a leading directory name is | 
|  | given. | 
|  |  | 
|  | \--:: | 
|  | This option can be used to separate command-line options from | 
|  | the list of files, (useful when filenames might be mistaken | 
|  | for command-line options). | 
|  |  | 
|  | --cached:: | 
|  | Use this option to unstage and remove paths only from the index. | 
|  | Working tree files, whether modified or not, will be | 
|  | left alone. | 
|  |  | 
|  | --ignore-unmatch:: | 
|  | Exit with a zero status even if no files matched. | 
|  |  | 
|  | -q:: | 
|  | --quiet:: | 
|  | 'git-rm' normally outputs one line (in the form of an "rm" command) | 
|  | for each file removed. This option suppresses that output. | 
|  |  | 
|  |  | 
|  | DISCUSSION | 
|  | ---------- | 
|  |  | 
|  | The <file> list given to the command can be exact pathnames, | 
|  | file glob patterns, or leading directory names. The command | 
|  | removes only the paths that are known to git. Giving the name of | 
|  | a file that you have not told git about does not remove that file. | 
|  |  | 
|  | File globbing matches across directory boundaries. Thus, given | 
|  | two directories `d` and `d2`, there is a difference between | 
|  | using `git rm \'d\*\'` and `git rm \'d/\*\'`, as the former will | 
|  | also remove all of directory `d2`. | 
|  |  | 
|  | EXAMPLES | 
|  | -------- | 
|  | git rm Documentation/\\*.txt:: | 
|  | Removes all `\*.txt` files from the index that are under the | 
|  | `Documentation` directory and any of its subdirectories. | 
|  | + | 
|  | Note that the asterisk `\*` is quoted from the shell in this | 
|  | example; this lets git, and not the shell, expand the pathnames | 
|  | of files and subdirectories under the `Documentation/` directory. | 
|  |  | 
|  | git rm -f git-*.sh:: | 
|  | Because this example lets the shell expand the asterisk | 
|  | (i.e. you are listing the files explicitly), it | 
|  | does not remove `subdir/git-foo.sh`. | 
|  |  | 
|  | SEE ALSO | 
|  | -------- | 
|  | linkgit:git-add[1] | 
|  |  | 
|  | Author | 
|  | ------ | 
|  | Written by Linus Torvalds <torvalds@osdl.org> | 
|  |  | 
|  | Documentation | 
|  | -------------- | 
|  | Documentation by Junio C Hamano and the git-list <git@vger.kernel.org>. | 
|  |  | 
|  | GIT | 
|  | --- | 
|  | Part of the linkgit:git[1] suite |