Jeff King f55527f802 rm: loosen safety valve for empty files
If a file is different between the working tree copy, the index, and the
HEAD, then we do not allow it to be deleted without --force.

However, this is overly tight in the face of "git add --intent-to-add":

  $ git add --intent-to-add file
  $ : oops, I don't actually want to stage that yet
  $ git rm --cached file
  error: 'empty' has staged content different from both the
  file and the HEAD (use -f to force removal)
  $ git rm -f --cached file

Unfortunately, there is currently no way to distinguish between an empty
file that has been added and an "intent to add" file. The ideal behavior
would be to disallow the former while allowing the latter.

This patch loosens the safety valve to allow the deletion only if we are
deleting the cached entry and the cached content is empty.  This covers
the intent-to-add situation, and assumes there is little harm in not
protecting users who have legitimately added an empty file.  In many
cases, the file will still be empty, in which case the safety valve does
not trigger anyway (since the content remains untouched in the working
tree). Otherwise, we do remove the fact that no content was staged, but
given that the content is by definition empty, it is not terribly
difficult for a user to recreate it.

However, we still document the desired behavior in the form of two
tests. One checks the correct removal of an intent-to-add file. The other
checks that we still disallow removal of empty files, but is marked as
expect_failure to indicate this compromise. If the intent-to-add feature
is ever extended to differentiate between normal empty files and
intent-to-add files, then the safety valve can be re-tightened.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2008-10-22 17:16:07 -07:00
2008-10-21 13:47:22 -07:00
2008-09-25 08:41:07 -07:00
2008-10-22 17:16:07 -07:00
2008-07-19 11:25:51 -07:00
2008-06-30 22:45:50 -07:00
2008-07-19 11:17:43 -07:00
2007-05-30 15:03:50 -07:00
2008-10-21 17:58:11 -07:00
2008-08-31 16:22:05 -07:00
2007-06-07 00:04:01 -07:00
2008-10-12 13:21:17 -07:00
2008-10-19 16:07:07 -07:00
2008-08-28 20:50:10 -07:00
2008-09-10 15:00:17 -07:00
2008-10-19 16:06:21 -07:00
2008-08-03 14:14:10 -07:00
2008-10-08 08:05:43 -07:00
2008-09-15 23:11:35 -07:00
2008-09-25 09:39:24 -07:00
2008-09-07 23:45:56 -07:00
2008-10-10 08:39:20 -07:00
2008-10-10 08:39:20 -07:00
2008-08-28 21:49:51 -07:00
2008-09-25 09:39:24 -07:00
2008-09-25 08:41:42 -07:00
2007-06-07 00:04:01 -07:00
2008-09-30 14:30:06 -07:00
2008-02-25 23:57:35 -08:00
2008-08-16 02:32:36 -07:00
2008-08-05 21:21:08 -07:00
2008-07-13 14:12:48 -07:00
2008-10-19 16:06:31 -07:00
2008-07-13 14:12:48 -07:00
2008-07-13 14:12:48 -07:00
2008-09-12 16:18:47 -07:00
2008-09-25 08:00:28 -07:00
2008-09-07 23:52:16 -07:00
2008-10-21 13:47:22 -07:00
2008-07-21 19:11:50 -07:00
2008-07-21 19:11:50 -07:00
2007-12-13 23:04:26 -08:00
2008-09-10 15:00:17 -07:00
2008-07-13 14:12:48 -07:00
2008-07-25 21:29:44 -07:00
2008-08-06 13:50:48 -07:00
2008-08-06 13:50:48 -07:00
2008-07-21 19:11:50 -07:00
2008-10-21 17:58:11 -07:00
2008-09-19 23:15:13 -07:00
2008-10-21 17:58:11 -07:00
2008-07-21 19:11:50 -07:00
2008-09-18 20:18:37 -07:00
2008-09-18 20:18:37 -07:00
2007-11-09 21:14:10 -08:00
2008-10-06 00:37:30 -07:00
2008-10-21 17:58:11 -07:00
2008-07-21 19:11:50 -07:00
2008-07-25 17:09:38 -07:00
2008-07-21 19:11:50 -07:00
2008-07-21 19:11:50 -07:00
2008-03-02 15:11:07 -08:00
2005-11-02 16:50:58 -08:00
2006-03-25 16:35:43 -08:00
2007-05-01 02:59:08 -07:00
2008-10-21 17:58:01 -07:00
2008-10-09 11:26:17 -07:00
2008-09-29 07:30:16 -07:00
2008-07-30 11:42:01 -07:00
2008-10-17 01:52:32 -07:00

////////////////////////////////////////////////////////////////

	GIT - the stupid content tracker

////////////////////////////////////////////////////////////////

"git" can mean anything, depending on your mood.

 - random three-letter combination that is pronounceable, and not
   actually used by any common UNIX command.  The fact that it is a
   mispronunciation of "get" may or may not be relevant.
 - stupid. contemptible and despicable. simple. Take your pick from the
   dictionary of slang.
 - "global information tracker": you're in a good mood, and it actually
   works for you. Angels sing, and a light suddenly fills the room.
 - "goddamn idiotic truckload of sh*t": when it breaks

Git is a fast, scalable, distributed revision control system with an
unusually rich command set that provides both high-level operations
and full access to internals.

Git is an Open Source project covered by the GNU General Public License.
It was originally written by Linus Torvalds with help of a group of
hackers around the net. It is currently maintained by Junio C Hamano.

Please read the file INSTALL for installation instructions.
See Documentation/tutorial.txt to get started, then see
Documentation/everyday.txt for a useful minimum set of commands,
and "man git-commandname" for documentation of each command.
CVS users may also want to read Documentation/cvs-migration.txt.

Many Git online resources are accessible from http://git.or.cz/
including full documentation and Git related tools.

The user discussion and development of Git take place on the Git
mailing list -- everyone is welcome to post bug reports, feature
requests, comments and patches to git@vger.kernel.org. To subscribe
to the list, send an email with just "subscribe git" in the body to
majordomo@vger.kernel.org. The mailing list archives are available at
http://marc.theaimsgroup.com/?l=git and other archival sites.

The messages titled "A note from the maintainer", "What's in
git.git (stable)" and "What's cooking in git.git (topics)" and
the discussion following them on the mailing list give a good
reference for project status, development direction and
remaining tasks.
Description
No description provided
Readme 612 MiB
Languages
C 50.5%
Shell 38.7%
Perl 4.5%
Tcl 3.2%
Python 0.8%
Other 2.1%