草庐IT

git:为什么我不能在 Squash merge 后删除我的分支?

我有一个带有mainline的git仓库(相当于master)和一些局部特征分支。例如:$gitbranch*mainlinefeature1feature2feature3当我执行以下操作时,我能够将我在功能分支中的所有编辑merge到一个对mainline的提交中。:$gitcheckoutmainline$gitpull$gitcheckoutfeature1$gitrebasemainline$gitcheckoutmainline$gitmerge--squashfeature1$gitcommit$gitpush我的问题是,此时,当我尝试删除feature1时分支,它告诉我

git:为什么我不能在 Squash merge 后删除我的分支?

我有一个带有mainline的git仓库(相当于master)和一些局部特征分支。例如:$gitbranch*mainlinefeature1feature2feature3当我执行以下操作时,我能够将我在功能分支中的所有编辑merge到一个对mainline的提交中。:$gitcheckoutmainline$gitpull$gitcheckoutfeature1$gitrebasemainline$gitcheckoutmainline$gitmerge--squashfeature1$gitcommit$gitpush我的问题是,此时,当我尝试删除feature1时分支,它告诉我

git - 如何在 SourceTree 中使用 VS Code 作为 merge 和差异工具?

Thisquestion和其他一些人讨论这如何在Mac上工作,但我无法从Microsoft或Atlassian找到有关在Windows上执行此操作的方法的文档,试图使其成为全局Git设置。(我只是喜欢尽可能在IDE中更改内容。)SourceTree的“选项”对话框“差异”选项卡中的“自定义”设置使用哪些参数,用于与VS-Code进行差异化和merge? 最佳答案 可能还有其他更好的变体,但经过一些实验后我发现这些变体效果很好......为“外部差异工具”和“merge工具”选择“自定义”两种情况下的“差异命令”都是安装VS-Code

git - 如何在 SourceTree 中使用 VS Code 作为 merge 和差异工具?

Thisquestion和其他一些人讨论这如何在Mac上工作,但我无法从Microsoft或Atlassian找到有关在Windows上执行此操作的方法的文档,试图使其成为全局Git设置。(我只是喜欢尽可能在IDE中更改内容。)SourceTree的“选项”对话框“差异”选项卡中的“自定义”设置使用哪些参数,用于与VS-Code进行差异化和merge? 最佳答案 可能还有其他更好的变体,但经过一些实验后我发现这些变体效果很好......为“外部差异工具”和“merge工具”选择“自定义”两种情况下的“差异命令”都是安装VS-Code

git - 如何撤消 git merge squash?

我刚刚做了一个gitmerge--squashfeature-branch进入我的develop分支。问题是上面的命令在没有创建新提交的情况下更新了头部。我的意图是创建一个单独的提交以应用于develop的负责人。所以简而言之,merge前后develop分支的日志是完全一样的。有没有办法将develop恢复到gitmerge之前的状态?谢谢。解决方案根据DanD.的评论和下面接受的答案,我能够解决我的问题。看看下面我做了什么,以防你在同一条船上:1-我运行了gitreflog,它列出了我对我的develop分支所做的所有提交和checkout。2-我没有按照建议执行gitresetH

git - 如何撤消 git merge squash?

我刚刚做了一个gitmerge--squashfeature-branch进入我的develop分支。问题是上面的命令在没有创建新提交的情况下更新了头部。我的意图是创建一个单独的提交以应用于develop的负责人。所以简而言之,merge前后develop分支的日志是完全一样的。有没有办法将develop恢复到gitmerge之前的状态?谢谢。解决方案根据DanD.的评论和下面接受的答案,我能够解决我的问题。看看下面我做了什么,以防你在同一条船上:1-我运行了gitreflog,它列出了我对我的develop分支所做的所有提交和checkout。2-我没有按照建议执行gitresetH

Git:将旧提交 merge 到当前头版本

有一个文件有两个感兴趣的提交,都在Master分支上,都只修改一个文件foo:一个先前的提交AA,以及HEAD中的当前版本。我想将文件的两个版本merge到Master上的HEAD中,同时保留两个版本。我做了我认为可行的最简单的事情:gitcheckout-bmerge-purgatoryAAgitcommit-m"pulledfoobackfrompreviouscommitformergingintoHEAD."gitcheckoutmastergitmergemerge-purgatory它只是用AA版本覆盖foo的当前HEAD版本。也尝试了更详细的gitcheckout-m,同

Git:将旧提交 merge 到当前头版本

有一个文件有两个感兴趣的提交,都在Master分支上,都只修改一个文件foo:一个先前的提交AA,以及HEAD中的当前版本。我想将文件的两个版本merge到Master上的HEAD中,同时保留两个版本。我做了我认为可行的最简单的事情:gitcheckout-bmerge-purgatoryAAgitcommit-m"pulledfoobackfrompreviouscommitformergingintoHEAD."gitcheckoutmastergitmergemerge-purgatory它只是用AA版本覆盖foo的当前HEAD版本。也尝试了更详细的gitcheckout-m,同

git - 为什么 git svn dcommit 会丢失本地分支的 merge 提交历史?

我有一个使用gitsvnclone创建的本地git存储库。我创建了一个本地分支,进行了一些更改,然后切换回master,gitsvnrebase如果一切正常,我将我的分支merge回master。然后树看起来像这样:alttexthttp://img.skitch.com/20090108-cjguu3hcci9x2k17mcftamw8f1.jpg有时,稍后当我再次gitsvnrebase并进行一些远程更改时,它会丢失a_branch被merge到主线中的事实,树看起来像这样:alttexthttp://img.skitch.com/20090108-kn3bn1qgi5ijw8ja

git - 为什么 git svn dcommit 会丢失本地分支的 merge 提交历史?

我有一个使用gitsvnclone创建的本地git存储库。我创建了一个本地分支,进行了一些更改,然后切换回master,gitsvnrebase如果一切正常,我将我的分支merge回master。然后树看起来像这样:alttexthttp://img.skitch.com/20090108-cjguu3hcci9x2k17mcftamw8f1.jpg有时,稍后当我再次gitsvnrebase并进行一些远程更改时,它会丢失a_branch被merge到主线中的事实,树看起来像这样:alttexthttp://img.skitch.com/20090108-kn3bn1qgi5ijw8ja