|  | git-mv(1) | 
|  | ========= | 
|  |  | 
|  | NAME | 
|  | ---- | 
|  | git-mv - Move or rename a file, a directory, or a symlink | 
|  |  | 
|  |  | 
|  | SYNOPSIS | 
|  | -------- | 
|  | [verse] | 
|  | 'git mv' <options>... <args>... | 
|  |  | 
|  | DESCRIPTION | 
|  | ----------- | 
|  | Move or rename a file, directory or symlink. | 
|  |  | 
|  | git mv [-v] [-f] [-n] [-k] <source> <destination> | 
|  | git mv [-v] [-f] [-n] [-k] <source> ... <destination directory> | 
|  |  | 
|  | In the first form, it renames <source>, which must exist and be either | 
|  | a file, symlink or directory, to <destination>. | 
|  | In the second form, the last argument has to be an existing | 
|  | directory; the given sources will be moved into this directory. | 
|  |  | 
|  | The index is updated after successful completion, but the change must still be | 
|  | committed. | 
|  |  | 
|  | OPTIONS | 
|  | ------- | 
|  | -f:: | 
|  | --force:: | 
|  | Force renaming or moving of a file even if the target exists | 
|  | -k:: | 
|  | Skip move or rename actions which would lead to an error | 
|  | condition. An error happens when a source is neither existing nor | 
|  | controlled by Git, or when it would overwrite an existing | 
|  | file unless `-f` is given. | 
|  | -n:: | 
|  | --dry-run:: | 
|  | Do nothing; only show what would happen | 
|  |  | 
|  | -v:: | 
|  | --verbose:: | 
|  | Report the names of files as they are moved. | 
|  |  | 
|  | SUBMODULES | 
|  | ---------- | 
|  | Moving a submodule using a gitfile (which means they were cloned | 
|  | with a Git version 1.7.8 or newer) will update the gitfile and | 
|  | core.worktree setting to make the submodule work in the new location. | 
|  | It also will attempt to update the submodule.<name>.path setting in | 
|  | the linkgit:gitmodules[5] file and stage that file (unless -n is used). | 
|  |  | 
|  | BUGS | 
|  | ---- | 
|  | Each time a superproject update moves a populated submodule (e.g. when | 
|  | switching between commits before and after the move) a stale submodule | 
|  | checkout will remain in the old location and an empty directory will | 
|  | appear in the new location. To populate the submodule again in the new | 
|  | location the user will have to run "git submodule update" | 
|  | afterwards. Removing the old directory is only safe when it uses a | 
|  | gitfile, as otherwise the history of the submodule will be deleted | 
|  | too. Both steps will be obsolete when recursive submodule update has | 
|  | been implemented. | 
|  |  | 
|  | GIT | 
|  | --- | 
|  | Part of the linkgit:git[1] suite |