feature分支
添加一个新功能时,你肯定不希望因为一些实验性质的代码,把主分支搞乱了,所以,每添加一个新功能,最好新建一个feature分支,在上面开发,完成后,合并,最后,删除该feature分支。
现在,你终于接到了一个新任务:开发代号为Vulcan的新功能,该功能计划用于下一代星际飞船。
于是准备开发:
$ git switch -c feature-vulcan
Switched to a new branch 'feature-vulcan'
若干天后,开发完毕:
$ git commit vulcan.py -m "add feature vulcan"
[feature-vulcan 096d4e8] add feature vulcan
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 vulcan.py
切回dev准备合并:
一切顺利的话,feature分支和bug分支是类似的,合并,然后删除。
但是!
就在此时,接到上级命令,因经费不足,新功能必须取消!
虽然白干了,但是这个包含机密资料的分支还是必须就地销毁:
但我中途发现一个问题,我在feature分支上新建的dev分支并切换到dev分支,删掉feature后,feature提交的add feature vulcan版本转移到了dev上
(main)
$ git switch -c feature-vulcan
Switched to a new branch 'feature-vulcan'
(feature-vulcan)
$ touch vulcan.py
(feature-vulcan)
$ git add vulcan.py
(feature-vulcan)
$ git commit vulcan.py -m "add feature vulcan"
[feature-vulcan 096d4e8] add feature vulcan
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 vulcan.py
(feature-vulcan)
$ git switch -c dev
Switched to a new branch 'dev'
(dev)
$ git branch -d feature-vulcan
Deleted branch feature-vulcan (was 096d4e8).
(dev)
$ git log
commit 096d4e86c555f8787fbbf55ac48df423fff46b8f (HEAD -> dev)
Author: Bob <884851491@qq.com>
Date: Sun Aug 7 14:56:32 2022 +0800
这说明feature作为“父分支”,在其上创建了“子分支”dev下删除feature这个“父分支”的结果是,dev会代替feature,HEAD指针原先指向feature,现在会指向dev
对此结果我做记录并存疑
但这也是我犯下的错误,正确操作应该是dev作为由main创建操作干活的主要分支,应该在dev下创建子分支来实现功能再换回dev进行合并,合并完删除此子分支。
在正确操作下:
$ git branch -d feature-vulcan
error: The branch 'feature-vulcan' is not fully merged.
If you are sure you want to delete it, run 'git branch -D feature-vulcan'.
销毁失败。Git友情提醒,feature-vulcan分支还没有被合并,如果删除,将丢失掉修改,如果要强行删除,需要使用大写的-D参数。。(只要文件不为空,但feature中文件如果为空会删除成功)
$ git branch -D feature-vulcan
Deleted branch feature-vulcan (was 287773e).
进行强行删除。