- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我是 GIT 的新手,我不知道我的问题是否已经有了答案。请在将其标记为重复之前仔细阅读。
我有一个分支,我们称它为 public
,它被推送并与 origin
同步。有一次,我创建了另一个分支,private
,它从 public
中 pop ,因为我想做很多我想保密的工作。所以我只在 private
上工作,比方说,我做了 10 次提交,直到我最终达到可以公开的状态。
现在,我显然不想对public
进行快进 merge ,因为所有中间提交都会出现在远程服务器上。如果 public
分支没有偏离创建 private
的点,我该如何做 rebase
。
显然,我想在 public
分支上创建一个新提交,其中包含来自 10 个 private
提交的所有修改。我知道这会转化为 rebase
,但我不知道该怎么做。
最佳答案
首先,public
正在跟踪 位于origin
上的远程分支这一事实并不意味着本地分支public
相当于远程分支origin/public
。
由于 git 的分布式特性,只要不推送,您就可以在本地 public
分支上进行大量提交,而无需将任何内容发送到服务器。
关于您在给定系统当前状态下尝试执行的操作,这里有一些详细步骤,假设您不关心保留最初的 10 次提交。
开始针对远程服务器的当前状态进行交互式 rebase 。
git checkout private
git rebase -i origin/public
将 pop 一个编辑器。具体的编辑器将取决于平台和环境变量设置。在此编辑器中,您将看到 10 次提交的哈希值,左侧栏中带有“pick”一词。对于第一行,保留 pick
。对于后续行,将 pick
替换为 squash
。保存文件并退出编辑器。
此时,git
会将 10 个提交 merge 为一个提交,因此我们可以 merge 到 public
中并推送。
git checkout public
git merge private
git push
如果您想在本地 private
分支上保留原来的 10 次提交,您可以改为快进 merge 到本地 public
分支并在那里 rebase .
git checkout public
git merge private
git rebase -i origin/public
# Do the same rebase steps as above
git push
关于git - rebase 而不是快进,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29842140/
我正在使用 just_audio而且效果很好。 但似乎找不到快进或倒带的方法。 更新:原来 just_audio 是 audio_service 的一部分包,使用 audio_service 为我解决
我让它快进了,但我想在快进时听到音乐。我怎样才能做到这一点?这是我的代码: if node.name == "left" { var time = musicPlayer.cu
可以假设快进意味着所有提交都在目标分支上重播并且 HEAD 设置为该分支上的最后一次提交吗? 最佳答案 当您尝试将一个提交与一个可以通过跟踪第一个提交的历史记录到达的提交 merge 时,Git 会通
关闭。这个问题需要更多 focused .它目前不接受答案。 想改进这个问题?更新问题,使其仅关注一个问题 editing this post . 8年前关闭。 Improve this questi
我有一个音频播放器,可以播放从 Core Date 检索到的音频。播放和暂停工作正常。我正在尝试实现“向前跳转 30 秒”按钮,并寻求有关我将如何实现的任何指示。 “播放/暂停”按钮的代码 @IBAc
Git merge 允许我们执行快进和非快进分支 merge 。什么时候使用快进 merge 以及什么时候不使用快进 merge 有什么想法吗? 最佳答案 --no-ff 选项在您想要清楚地了解您的功
我有这种情况:在一些 testBranch 上工作了一段时间,我想与 master 同步所以我做了git checkout testBranch 和git merge master/testBranc
所以我正在做一个项目,我有很长的 for 循环,当接近循环结束时我通常会遇到问题,但是通过进入循环数百万次手动到达那里几乎是不可能的。我知道我可以只更改计数器变量,但在这种情况下它不起作用,因为每次迭
我正在我的 Mp3 播放器中制作快进按钮。我已经为此编写了代码,但是有问题如何实现计时器向前跳 5%?我的意思是,当我按下按钮时,计时器应该比总长歌曲向前跳 5%。这是我的 fastForward 方
MediaPlayer 的 pause() 方法使 Media 稍微“寻找”一下。确实很烦人,但是没找到问题出在哪里。 private void playPauseClicked()
我有一个包含两个分支 master 和 entidades 的 GIT 存储库。我需要将 entidades 分支中的一些内容 merge 到 master 分支。看一下图像,标记为 EntityBu
假设有一个功能分支'my-feature'。在我开发该功能时,有人将它从“我的功能” merge 到“主控”中。因为这是一个快进 merge ,所以没有提交。我所做的一些更改还没有准备好用于 mast
换句话说,快进 merge 是否能保证生成与要 merge 的源分支的 HEAD 相同的 GIT SHA? 我在终端中测试了此行为,它适用于我的测试场景: $ git rev-parse some-b
换句话说,快进 merge 是否能保证生成与要 merge 的源分支的 HEAD 相同的 GIT SHA? 我在终端中测试了此行为,它适用于我的测试场景: $ git rev-parse some-b
这个关于 git 的陈述是真的吗,merge(其中快进是可能的)基本上与使 git reset --hard 到 HEAD 相同要 merge 到的分支? (当merge不是fast-forward时
最近,我创建了newbranch,并创建了一个到Master分支的 merge 请求。在 TeamLead 接受 merge 请求到 Master 分支之前,另一个团队成员向同一个分支(新分支)提交了
我是一名优秀的程序员,十分优秀!