简体中文 ▾ 主题 ▾ 最新版本 ▾ git-mv 最后更新于 2.50.0

名称

git-mv - 移动或重命名文件、目录或符号链接

概要

git mv [-v] [-f] [-n] [-k] <source> <destination>
git mv [-v] [-f] [-n] [-k] <source>... <destination-directory>

描述

移动或重命名文件、目录或符号链接。

在第一种形式中,它将 <source> 重命名为 <destination>,其中 <source> 必须存在,且必须是文件、符号链接或目录。在第二种形式中,<destination-directory> 必须是已存在的目录;给定的源将被移动到此目录中。

成功完成后索引会更新,但更改仍必须提交。

选项

-f
--force

即使 <destination> 已存在,也强制重命名或移动文件。

-k

跳过会导致错误条件的移动或重命名操作。当源既不存在也不受 Git 控制,或者在未给出 -f 的情况下会覆盖现有文件时,会发生错误。

-n
--dry-run

不执行任何操作;仅显示将要发生的情况

-v
--verbose

在移动文件时报告文件名。

子模块

使用 gitfile 移动子模块(意味着它们是使用 Git 1.7.8 或更高版本克隆的)将更新 gitfile 和 core.worktree 设置,使子模块在新位置正常工作。它还会尝试更新 gitmodules[5] 文件中的 submodule.<name>.path 设置并暂存该文件(除非使用了 -n)。

BUG

每当父项目更新移动了一个已检出的子模块时(例如在移动前后的提交之间切换时),旧位置会残留一个过时的子模块检出,而新位置会出现一个空目录。用户随后必须运行 "git submodule update" 才能在新位置重新填充子模块。只有当子模块使用 gitfile 时,删除旧目录才是安全的,否则子模块的历史记录也会被删除。当递归子模块更新实现后,这两个步骤都将变得不再必要。

GIT

Git[1] 套件的一部分