| 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 |