You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
113 lines
3.3 KiB
113 lines
3.3 KiB
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
|
|
|