232

I use this to remove a file from the repo:

hg remove <full file path> 

What command can you use to do an hg remove on all files that have been deleted locally?

By deleted locally, I mean those showing up with an ! when you do hg status.

For adds, you can just do hg add to add all new files (those prefixed with ?).

Marcus Leon
  • 55,199
  • 118
  • 297
  • 429

4 Answers4

377

This will add all new files that are not ignored, and remove all locally missing files

hg addremove

Either of these will remove all locally missing files(They are the same command)

hg remove --after
hg remove -A
mfperzel
  • 4,924
  • 1
  • 18
  • 13
35

If you intend to do addremove and commit, it can be joined with '-A' option as shown here:

hg commit -A -m 'Commit with addremove'
DaveShaw
  • 52,123
  • 16
  • 112
  • 141
tsenapathy
  • 5,646
  • 3
  • 26
  • 26
5

The original question asked how to remove (i.e. forget) files that show up as "!" when using hg st. A direct approach which has the advantage of transparency is to use hg st with the -n option:

hg -v forget $(hg st -nd)

(Of course the files will only be forgotten at the next commit.)

The flags are well-documented elsewhere (e.g. by the hg command itself), but in brief:

  • -n means "filename only"
  • -d means "select files that have been deleted"
Grijesh Chauhan
  • 57,103
  • 20
  • 141
  • 208
peak
  • 105,803
  • 17
  • 152
  • 177
1

If you want to addremove and commit, but are not ready to commit the rest of your changes, I think you still have to enumerate them:

$ hg st
M modified-file
A added-file
R removed-file-1
R removed-file-2

$ hg commit -m"remove removed-file-1 and removed-file-2" removed-file-*
abort: removed-file-*: No such file or directory

$ hg commit -m"remove removed-file-1 and removed-file-2" removed-file-1 removed-file-2
committed changeset 185:628800a7af84
Dan Ross
  • 87
  • 6