HG(ADDREMOVE) HG(ADDREMOVE)

hg addremove - add all new files, delete all missing files

hg addremove [OPTION]... [FILE]...

Add all new files and remove all missing files from the repository.

Unless names are given, new files are ignored if they match any of the patterns in .hgignore. As with add, these changes take effect at the next commit.

Use the -s/--similarity option to detect renamed files. This option takes a percentage between 0 (disabled) and 100 (files must be identical) as its parameter. With a parameter greater than 0, this compares every removed file with every added file and records those similar enough as renames. Detecting renamed files this way can be expensive. After using this option, hg status -C can be used to check which files were identified as moved or renamed. If not specified, -s/--similarity defaults to 100 and only renames of identical files are detected.

Examples:

  • A number of files (bar.c and foo.c) are new, while foobar.c has been removed (without using hg remove) from the repository:
    $ ls
    bar.c foo.c
    $ hg status
    ! foobar.c
    ? bar.c
    ? foo.c
    $ hg addremove
    adding bar.c
    adding foo.c
    removing foobar.c
    $ hg status
    A bar.c
    A foo.c
    R foobar.c
    
  • A file foobar.c was moved to foo.c without using hg rename. Afterwards, it was edited slightly:
    $ ls
    foo.c
    $ hg status
    ! foobar.c
    ? foo.c
    $ hg addremove --similarity 90
    removing foobar.c
    adding foo.c
    recording removal of foobar.c as rename to foo.c (94% similar)
    $ hg status -C
    A foo.c
      foobar.c
    R foobar.c
    

    Returns 0 if all files are successfully added.

guess renamed files by similarity (0<=s<=100)
recurse into subrepositories
include names matching the given patterns
exclude names matching the given patterns
do not perform actions, just print output

[+] marked option can be specified multiple times