1

我正在尝试使用 Git 分支以从主服务器中创建功能,但我经常会弄乱我的 git 存储库:/

我在 Stack Overflow 上搜索了我想要实现的目标,通常我可以找到如何合并/分支/还原/等,但在我面临的工作流程中却找不到,这对我来说是经常发生的事情。

这是我作为工作流程要做的事情:

  • 在 master 上有一个基础项目
  • 创建一个新分支,并在其上工作(创建/修改、提交、推送)
  • 返回 master(或其他分支)并应用一些修改(紧急错误修复)
  • 将这些更改从 master 合并到我当前的工作分支中(以减少冲突问题)
  • 完成后,将我的分支合并到 master 中,准备部署!

其中一些操作似乎很容易,但中间部分(切换回,掌握,应用更改然后再次进入分支)对我来说似乎是不可能的:/

这是我所在的位置:

(假设项目已经在 git 上,部分工作已经推送到 master 上)

git branch feature
git checkout feature

# do some add/edit, commit, push on that branch

# Now I need to fix a bug in master :
git checkout master
# how can I get my files in the master state ?
# My best guest so far :
git revert HEAD

# do some add/edit, commit, push on master

# Finished to fix the bug, going back to continue my feature :
git checkout feature
# Again, how can I get my files to match the current state of the branch feature ?
git revert HEAD # And git asks me about a revert ? what ? I'm lost :/

# getting the recent changes from master into feature, in order to avoid later conflicts
# This can also be made often if you work with others
git fetch origin
git rebase origin/feature
git rebase origin/master

# do some add/edit, commit, push on master

# And when you have finish, merge feature into master :
git checkout master
git pull origin master
git merge feature
git branch -d feature # if you want to remove it.

这是我目前假定的工作流程,但我不确定revert HEAD这是一个好的解决方案,当我回去时,Git 更加证实了这一点,它要求我恢复到我必须推送的先前状态(?!) .

有人可以帮我澄清我的情况和/或指导我做一个很好的(但请,非常简单)解释来做我正在尝试的事情吗?

非常感谢,我真的很感激!

4

1 回答 1

1

git checkout master应该已经“让你的文件处于主状态”。它失败的最常见情况是您有未提交的更改。但是你可以用git stash. 或者只是通过提交您的功能分支,您可以随时取消该分支。

git revert旨在取消您无法再消除的提交(例如,已发布的历史记录),并通过创建额外的提交来撤消其影响。它与 Subversion 和/或 Mercurial 命名非常不同,而且需要的频率要少得多。

于 2013-11-13T17:54:00.250 回答