要创建一个新分支,只保留原有分支的文件而不保留其提交历史,可以通过以下步骤完成。这种做法实质上是在新分支上重新开始一个干净的提交历史,但保留了工作目录中的文件状态。
-
确保工作目录是干净的:首先,确保你的工作目录没有未提交的更改。可以使用
git status
来检查。如果有未提交的更改,请先提交或暂存这些更改。git status
如果工作目录不干净,可以暂存更改并提交:
git add . git commit -m "临时保存工作进度"
-
创建并切换到新分支:使用
git checkout
或git switch
(Git 2.23及以上版本)命令创建并切换到一个新的分支。这里以git switch
为例,如果你的Git版本较低,请使用git checkout -b 新分支名
。git switch -c 新分支名
-
删除新分支上的所有提交:一旦在新分支上,可以通过创建一个“孤儿”分支(一个没有父提交的分支)来去除所有先前的提交记录,但这需要一些步骤来保留当前的文件状态。
首先,使用下面的命令创建一个孤儿分支:
git checkout --orphan temp-branch
这会创建一个名为
temp-branch
的新分支,其中不包含任何提交历史。然而,工作目录和暂存区的状态会被保留下来。 -
添加所有文件并提交:由于工作目录的状态被保留下来了,你现在可以添加所有文件到暂存区,并提交它们到这个全新的分支中。
git add . git commit -m "初始化提交"
-
[可选] 删除旧分支:如果你不再需要旧的分支,可以将其删除。注意,这会永久删除旧分支的提交历史,请确保你不会丢失任何重要信息。
git branch -D 旧分支名
-
[可选] 重命名孤儿分支:如果你想要将这个孤儿分支重命名回你想要的名字,首先需要切换到另一个分支,然后删除原来的新分支,最后将孤儿分支重命名。
git switch main # 切换到另一个分支 git branch -D 新分支名 # 删除原新分支 git branch -m temp-branch 新分支名 # 将temp-branch重命名为新分支名
通过以上步骤,你可以在新分支上开始一个干净的提交历史,同时保留了文件的当前状态。这对于重置项目历史或将项目拆分为多个子项目时非常有用。