git-rm: update to saner semantics

This updates the "git rm" command with saner semantics suggested
on the list earlier with:

	Message-ID: <Pine.LNX.4.64.0612020919400.3476@woody.osdl.org>
	Message-ID: <Pine.LNX.4.64.0612040737120.3476@woody.osdl.org>

The command still validates that the given paths all talk about
sensible paths to avoid mistakes (e.g. "git rm fiel" when file
"fiel" does not exist would error out -- user meant to remove
"file"), and it has further safety checks described next.  The
biggest difference is that the paths are removed from both index
and from the working tree (if you have an exotic need to remove
paths only from the index, you can use the --cached option).

The command refuses to remove if the copy on the working tree
does not match the index, or if the index and the HEAD does not
match.  You can defeat this check with -f option.

This safety check has two exceptions: if the working tree file
does not exist to begin with, that technically does not match
the index but it is allowed.  This is to allow this CVS style
command sequence:

	rm <path> && git rm <path>

Also if the index is unmerged at the <path>, you can use "git rm
<path>" to declare that the result of the merge loses that path,
and the above safety check does not trigger; requiring the file
to match the index in this case forces the user to do "git
update-index file && git rm file", which is just crazy.

To recursively remove all contents from a directory, you need to
pass -r option, not just the directory name as the <path>.

Signed-off-by: Junio C Hamano <junkio@cox.net>
1 file changed
tree: 564e4455799c64ff93c62335ef6c8b96596dd566
  1. arm/
  2. compat/
  3. contrib/
  4. Documentation/
  5. gitweb/
  6. mozilla-sha1/
  7. perl/
  8. ppc/
  9. t/
  10. templates/
  11. xdiff/
  12. .gitignore
  13. alloc.c
  14. archive-tar.c
  15. archive-zip.c
  16. archive.h
  17. base85.c
  18. blob.c
  19. blob.h
  20. builtin-add.c
  21. builtin-annotate.c
  22. builtin-apply.c
  23. builtin-archive.c
  24. builtin-blame.c
  25. builtin-branch.c
  26. builtin-cat-file.c
  27. builtin-check-ref-format.c
  28. builtin-checkout-index.c
  29. builtin-commit-tree.c
  30. builtin-count-objects.c
  31. builtin-diff-files.c
  32. builtin-diff-index.c
  33. builtin-diff-stages.c
  34. builtin-diff-tree.c
  35. builtin-diff.c
  36. builtin-fmt-merge-msg.c
  37. builtin-for-each-ref.c
  38. builtin-grep.c
  39. builtin-init-db.c
  40. builtin-log.c
  41. builtin-ls-files.c
  42. builtin-ls-tree.c
  43. builtin-mailinfo.c
  44. builtin-mailsplit.c
  45. builtin-merge-file.c
  46. builtin-mv.c
  47. builtin-name-rev.c
  48. builtin-pack-objects.c
  49. builtin-pack-refs.c
  50. builtin-prune-packed.c
  51. builtin-prune.c
  52. builtin-push.c
  53. builtin-read-tree.c
  54. builtin-repo-config.c
  55. builtin-rerere.c
  56. builtin-rev-list.c
  57. builtin-rev-parse.c
  58. builtin-rm.c
  59. builtin-runstatus.c
  60. builtin-shortlog.c
  61. builtin-show-branch.c
  62. builtin-show-ref.c
  63. builtin-stripspace.c
  64. builtin-symbolic-ref.c
  65. builtin-tar-tree.c
  66. builtin-unpack-objects.c
  67. builtin-update-index.c
  68. builtin-update-ref.c
  69. builtin-upload-archive.c
  70. builtin-verify-pack.c
  71. builtin-write-tree.c
  72. builtin.h
  73. cache-tree.c
  74. cache-tree.h
  75. cache.h
  76. check-builtins.sh
  77. check-racy.c
  78. color.c
  79. color.h
  80. combine-diff.c
  81. commit.c
  82. commit.h
  83. config.c
  84. config.mak.in
  85. configure.ac
  86. connect.c
  87. convert-objects.c
  88. copy.c
  89. COPYING
  90. csum-file.c
  91. csum-file.h
  92. ctype.c
  93. daemon.c
  94. date.c
  95. delta.h
  96. describe.c
  97. diff-delta.c
  98. diff-lib.c
  99. diff.c
  100. diff.h
  101. diffcore-break.c
  102. diffcore-delta.c
  103. diffcore-order.c
  104. diffcore-pickaxe.c
  105. diffcore-rename.c
  106. diffcore.h
  107. dir.c
  108. dir.h
  109. dump-cache-tree.c
  110. entry.c
  111. environment.c
  112. exec_cmd.c
  113. exec_cmd.h
  114. fetch-pack.c
  115. fetch.c
  116. fetch.h
  117. fsck-objects.c
  118. generate-cmdlist.sh
  119. git-add--interactive.perl
  120. git-am.sh
  121. git-applymbox.sh
  122. git-applypatch.sh
  123. git-archimport.perl
  124. git-bisect.sh
  125. git-checkout.sh
  126. git-clean.sh
  127. git-clone.sh
  128. git-commit.sh
  129. git-compat-util.h
  130. git-cvsexportcommit.perl
  131. git-cvsimport.perl
  132. git-cvsserver.perl
  133. git-fetch.sh
  134. git-instaweb.sh
  135. git-lost-found.sh
  136. git-ls-remote.sh
  137. git-merge-octopus.sh
  138. git-merge-one-file.sh
  139. git-merge-ours.sh
  140. git-merge-resolve.sh
  141. git-merge-stupid.sh
  142. git-merge.sh
  143. git-p4import.py
  144. git-parse-remote.sh
  145. git-pull.sh
  146. git-quiltimport.sh
  147. git-rebase.sh
  148. git-relink.perl
  149. git-repack.sh
  150. git-request-pull.sh
  151. git-rerere.perl
  152. git-reset.sh
  153. git-resolve.sh
  154. git-revert.sh
  155. git-send-email.perl
  156. git-sh-setup.sh
  157. git-svn.perl
  158. git-svnimport.perl
  159. git-tag.sh
  160. git-verify-tag.sh
  161. GIT-VERSION-GEN
  162. git.c
  163. git.spec.in
  164. gitk
  165. grep.c
  166. grep.h
  167. hash-object.c
  168. help.c
  169. http-fetch.c
  170. http-push.c
  171. http.c
  172. http.h
  173. ident.c
  174. imap-send.c
  175. index-pack.c
  176. INSTALL
  177. interpolate.c
  178. interpolate.h
  179. list-objects.c
  180. list-objects.h
  181. local-fetch.c
  182. lockfile.c
  183. log-tree.c
  184. log-tree.h
  185. Makefile
  186. merge-base.c
  187. merge-file.c
  188. merge-index.c
  189. merge-recursive.c
  190. merge-tree.c
  191. mktag.c
  192. mktree.c
  193. object-refs.c
  194. object.c
  195. object.h
  196. pack-check.c
  197. pack-redundant.c
  198. pack.h
  199. pager.c
  200. patch-delta.c
  201. patch-id.c
  202. path-list.c
  203. path-list.h
  204. path.c
  205. peek-remote.c
  206. pkt-line.c
  207. pkt-line.h
  208. quote.c
  209. quote.h
  210. read-cache.c
  211. README
  212. receive-pack.c
  213. refs.c
  214. refs.h
  215. revision.c
  216. revision.h
  217. rsh.c
  218. rsh.h
  219. run-command.c
  220. run-command.h
  221. send-pack.c
  222. server-info.c
  223. setup.c
  224. sha1_file.c
  225. sha1_name.c
  226. shell.c
  227. show-index.c
  228. sideband.c
  229. sideband.h
  230. ssh-fetch.c
  231. ssh-pull.c
  232. ssh-push.c
  233. ssh-upload.c
  234. strbuf.c
  235. strbuf.h
  236. tag.c
  237. tag.h
  238. tar.h
  239. test-date.c
  240. test-delta.c
  241. test-sha1.c
  242. test-sha1.sh
  243. trace.c
  244. tree-diff.c
  245. tree-walk.c
  246. tree-walk.h
  247. tree.c
  248. tree.h
  249. unpack-file.c
  250. unpack-trees.c
  251. unpack-trees.h
  252. update-server-info.c
  253. upload-pack.c
  254. usage.c
  255. utf8.c
  256. utf8.h
  257. var.c
  258. write_or_die.c
  259. wt-status.c
  260. wt-status.h
  261. xdiff-interface.c
  262. xdiff-interface.h